java获取网络地址上文件名
时间: 2023-10-18 18:57:27 浏览: 63
在Java中获取网络地址上的文件名可以使用Java的URL类。URL类提供了一个getFile()方法,用于获取URL中的文件路径及文件名。例如:
```java
URL url = new URL("http://example.com/path/to/file.txt");
String fileName = url.getFile(); // 获取文件名,即/path/to/file.txt
```
需要注意的是,如果URL中没有包含文件名,getFile()方法将返回空字符串。因此在使用该方法之前,需要先判断URL是否包含文件名。
相关问题
java InputStream 如何获取文件名
回答: 在Java中,InputStream类本身并没有提供直接获取文件名的方法。InputStream类是用于读取字节流的抽象类,它可以从各种来源读取数据,包括文件、网络连接等。要获取文件名,需要使用FileInputStream类的构造方法中传入文件路径或File对象来创建InputStream对象。然后可以通过File对象的getName()方法来获取文件名。例如,可以使用FileInputStream的构造方法打开文件,然后使用File对象的getName()方法获取文件名。
#### 引用[.reference_title]
- *1* [Java EE|File类的常用方法和InputStream, OutputStream 的用法](https://blog.csdn.net/m0_61925333/article/details/125577473)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [File 类的用法和 InputStream, OutputStream 的用法](https://blog.csdn.net/qq_60338902/article/details/126198459)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item]
- *3* [Java InputStream如何读取文件呢?](https://blog.csdn.net/qq_25073223/article/details/126314712)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
java 根据网络地址下载文件
你可以使用Java中的URLConnection类和InputStream类来实现根据网络地址下载文件的功能。
以下是一个基本的示例代码:
```java
import java.io.*;
import java.net.*;
public class Downloader {
public static void downloadFile(String fileURL, String saveDir) throws IOException {
URL url = new URL(fileURL);
HttpURLConnection httpConn = (HttpURLConnection) url.openConnection();
int responseCode = httpConn.getResponseCode();
// 检查 HTTP 响应是否成功
if (responseCode == HttpURLConnection.HTTP_OK) {
// 获取文件名
String fileName = "";
String disposition = httpConn.getHeaderField("Content-Disposition");
String contentType = httpConn.getContentType();
int contentLength = httpConn.getContentLength();
if (disposition != null) {
// 从 Content-Disposition 中获取文件名
int index = disposition.indexOf("filename=");
if (index > 0) {
fileName = disposition.substring(index + 10, disposition.length() - 1);
}
} else {
// 从 URL 中获取文件名
fileName = fileURL.substring(fileURL.lastIndexOf("/") + 1, fileURL.length());
}
// 输出文件信息
System.out.println("Content-Type = " + contentType);
System.out.println("Content-Disposition = " + disposition);
System.out.println("Content-Length = " + contentLength);
System.out.println("fileName = " + fileName);
// 打开网络输入流
InputStream inputStream = httpConn.getInputStream();
// 打开本地文件输出流
String saveFilePath = saveDir + File.separator + fileName;
FileOutputStream outputStream = new FileOutputStream(saveFilePath);
// 从网络输入流读取数据,写入本地文件输出流
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("文件下载成功");
} else {
System.out.println("文件下载失败,HTTP 响应状态码为 " + responseCode);
}
httpConn.disconnect();
}
public static void main(String[] args) {
String fileURL = "http://example.com/file.zip";
String saveDir = "C:/Downloads";
try {
downloadFile(fileURL, saveDir);
} catch (IOException e) {
e.printStackTrace();
}
}
}
```
在上面的代码中,`downloadFile`方法接收文件的URL和保存目录作为参数,并使用`HttpURLConnection`打开连接。我们检查响应代码以确保连接成功,然后解析响应头中的文件名和其他信息。最后,我们使用`InputStream`从网络输入流读取数据,并使用`FileOutputStream`将数据写入本地文件输出流。最后,我们关闭流并断开连接。