System.out.print("请输入要下载的文件的URL:"); String url = scanner.nextLine(); // 服务器上文件的URL System.out.print("请输入要保存的文件名:"); String fileName = scanner.nextLine(); // 文件名 URL fileUrl = new URL(url); URLConnection connection = fileUrl.openConnection(); InputStream inputStream = connection.getInputStream(); // 将服务器上的文件保存到本地 FileOutputStream outputStream = new FileOutputStream(fileName); byte[] buffer = new byte[4096]; int bytesRead = -1; while ((bytesRead = inputStream.read(buffer)) != -1) { outputStream.write(buffer, 0, bytesRead); } outputStream.close(); inputStream.close(); System.out.println("文件下载完成");改为下载普通文件
时间: 2024-03-31 09:36:29 浏览: 13
好的,以下是将文件下载改为下载普通文件的代码:
```java
import java.io.*;
import java.net.*;
public class DownloadFile {
public static void main(String[] args) {
try {
// 获取用户输入的文件 URL 和保存文件名
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
System.out.print("请输入要下载的文件的URL:");
String url = reader.readLine();
System.out.print("请输入要保存的文件名:");
String fileName = reader.readLine();
// 创建 URL 实例并打开连接
URL fileUrl = new URL(url);
HttpURLConnection connection = (HttpURLConnection) fileUrl.openConnection();
// 设置请求方法为 GET
connection.setRequestMethod("GET");
// 获取文件长度
int contentLength = connection.getContentLength();
// 创建输入流和输出流
InputStream inputStream = connection.getInputStream();
FileOutputStream outputStream = new FileOutputStream(fileName);
// 缓存区大小
byte[] buffer = new byte[4096];
// 已读取的字节数
int bytesRead = 0;
// 循环读取文件内容到缓存区并写入到本地文件
while ((bytesRead = inputStream.read(buffer)) != -1) {
outputStream.write(buffer, 0, bytesRead);
}
// 关闭输入流和输出流
inputStream.close();
outputStream.close();
System.out.println("文件下载完成");
} catch (IOException e) {
e.printStackTrace();
}
}
}
```
这个代码与之前的代码的主要区别在于,这个代码使用了 `HttpURLConnection` 类替代了 `URLConnection` 类,因为 `HttpURLConnection` 类支持 HTTP 协议的特性,可以更好地进行文件下载。同时,这个代码中将 `URLConnection` 类的 `getInputStream()` 方法改为了 `HttpURLConnection` 类的 `getInputStream()` 方法,以获得更好的性能。