java 获得http下载文件的真实名称
发布网友
发布时间:2022-04-29 17:15
我来回答
共4个回答
热心网友
时间:2023-10-22 15:30
有两种获取链接文件名的方法:
第一种:从连接URL,从描述中获取
第二种:如果第一种获取不到,可以从URL地址中获取
比如这种地址:
http://book.booktxt.com/txtbuk/20130421/xuanhuan/20130421133601180.rar
热心网友
时间:2023-10-22 15:30
import java.net.*;
import java.io.*;
public class URLConnectionDemo{
public static void main(String[] args)throws Exception{
URL url = new URL("http://www.scp.e.cn/pantoschoolzz/BG/Bord/Message/DownloadMessageAttachment.aspx?ID=215");
URLConnection uc = url.openConnection();
String fileName = uc.getHeaderField(6);
fileName = URLDecoder.decode(fileName.substring(fileName.indexOf("filename=")+9),"UTF-8");
System.out.println("文件名为:"+fileName);
System.out.println("文件大小:"+(uc.getContentLength()/1024)+"KB");
String path = "D:"+File.separator+fileName;
FileOutputStream os = new FileOutputStream(path);
InputStream is = uc.getInputStream();
byte[] b = new byte[1024];
int len = 0;
while((len=is.read(b))!=-1){
os.write(b,0,len);
}
os.close();
is.close();
System.out.println("下载成功,文件保存在:"+path);
}
}
//输出内容:
文件名为:090602、09-10(1)校历.xls
文件大小:42KB
下载成功,文件保存在:D:\090602、09-10(1)校历.xls
热心网友
时间:2023-10-22 15:30
有两种获取链接文件名的方法:
第一种:从连接URL,从描述中获取
第二种:如果第一种获取不到,可以从URL地址中获取
比如这种地址:
http://book.booktxt.com/txtbuk/20130421/xuanhuan/20130421133601180.rar
热心网友
时间:2023-10-22 15:30
有两种获取链接文件名的方法:
第一种:从连接URL,从描述中获取
第二种:如果第一种获取不到,可以从URL地址中获取
比如这种地址:
http://book.booktxt.com/txtbuk/20130421/xuanhuan/20130421133601180.rar
热心网友
时间:2023-10-22 15:30
有两种获取链接文件名的方法:
第一种:从连接URL,从描述中获取
第二种:如果第一种获取不到,可以从URL地址中获取
比如这种地址:
http://book.booktxt.com/txtbuk/20130421/xuanhuan/20130421133601180.rar
热心网友
时间:2023-10-22 15:30
import java.net.*;
import java.io.*;
public class URLConnectionDemo{
public static void main(String[] args)throws Exception{
URL url = new URL("http://www.scp.e.cn/pantoschoolzz/BG/Bord/Message/DownloadMessageAttachment.aspx?ID=215");
URLConnection uc = url.openConnection();
String fileName = uc.getHeaderField(6);
fileName = URLDecoder.decode(fileName.substring(fileName.indexOf("filename=")+9),"UTF-8");
System.out.println("文件名为:"+fileName);
System.out.println("文件大小:"+(uc.getContentLength()/1024)+"KB");
String path = "D:"+File.separator+fileName;
FileOutputStream os = new FileOutputStream(path);
InputStream is = uc.getInputStream();
byte[] b = new byte[1024];
int len = 0;
while((len=is.read(b))!=-1){
os.write(b,0,len);
}
os.close();
is.close();
System.out.println("下载成功,文件保存在:"+path);
}
}
//输出内容:
文件名为:090602、09-10(1)校历.xls
文件大小:42KB
下载成功,文件保存在:D:\090602、09-10(1)校历.xls
热心网友
时间:2023-10-22 15:30
import java.net.*;
import java.io.*;
public class URLConnectionDemo{
public static void main(String[] args)throws Exception{
URL url = new URL("http://www.scp.e.cn/pantoschoolzz/BG/Bord/Message/DownloadMessageAttachment.aspx?ID=215");
URLConnection uc = url.openConnection();
String fileName = uc.getHeaderField(6);
fileName = URLDecoder.decode(fileName.substring(fileName.indexOf("filename=")+9),"UTF-8");
System.out.println("文件名为:"+fileName);
System.out.println("文件大小:"+(uc.getContentLength()/1024)+"KB");
String path = "D:"+File.separator+fileName;
FileOutputStream os = new FileOutputStream(path);
InputStream is = uc.getInputStream();
byte[] b = new byte[1024];
int len = 0;
while((len=is.read(b))!=-1){
os.write(b,0,len);
}
os.close();
is.close();
System.out.println("下载成功,文件保存在:"+path);
}
}
//输出内容:
文件名为:090602、09-10(1)校历.xls
文件大小:42KB
下载成功,文件保存在:D:\090602、09-10(1)校历.xls
热心网友
时间:2023-10-22 15:30
import java.net.*;
import java.io.*;
public class URLConnectionDemo{
public static void main(String[] args)throws Exception{
URL url = new URL("http://www.scp.e.cn/pantoschoolzz/BG/Bord/Message/DownloadMessageAttachment.aspx?ID=215");
URLConnection uc = url.openConnection();
String fileName = uc.getHeaderField(6);
fileName = URLDecoder.decode(fileName.substring(fileName.indexOf("filename=")+9),"UTF-8");
System.out.println("文件名为:"+fileName);
System.out.println("文件大小:"+(uc.getContentLength()/1024)+"KB");
String path = "D:"+File.separator+fileName;
FileOutputStream os = new FileOutputStream(path);
InputStream is = uc.getInputStream();
byte[] b = new byte[1024];
int len = 0;
while((len=is.read(b))!=-1){
os.write(b,0,len);
}
os.close();
is.close();
System.out.println("下载成功,文件保存在:"+path);
}
}
//输出内容:
文件名为:090602、09-10(1)校历.xls
文件大小:42KB
下载成功,文件保存在:D:\090602、09-10(1)校历.xls
热心网友
时间:2023-10-22 15:31
这个是不可能的。
解释:文件下载虽说是获取的真实文件内容,但是传递的时候可不是通过的整个文件,而是读取的文件内容为流,之后传递的,也就是说此过程实际上是文件内容的传递,所以是没法获取到的。
备注:这个要是能获取到,那可就危险了,随意知道开发者的文件路径,以后直接就能把开发者程序拿下来用,那问题就严重了。当前之有IE支持文件路径的读取了,其余浏览器都不会提供路径功能,都是直接文件名,路径都没有的。
热心网友
时间:2023-10-22 15:31
这个是不可能的。
解释:文件下载虽说是获取的真实文件内容,但是传递的时候可不是通过的整个文件,而是读取的文件内容为流,之后传递的,也就是说此过程实际上是文件内容的传递,所以是没法获取到的。
备注:这个要是能获取到,那可就危险了,随意知道开发者的文件路径,以后直接就能把开发者程序拿下来用,那问题就严重了。当前之有IE支持文件路径的读取了,其余浏览器都不会提供路径功能,都是直接文件名,路径都没有的。
热心网友
时间:2023-10-22 15:31
用httpclient试试吧
热心网友
时间:2023-10-22 15:31
这个是不可能的。
解释:文件下载虽说是获取的真实文件内容,但是传递的时候可不是通过的整个文件,而是读取的文件内容为流,之后传递的,也就是说此过程实际上是文件内容的传递,所以是没法获取到的。
备注:这个要是能获取到,那可就危险了,随意知道开发者的文件路径,以后直接就能把开发者程序拿下来用,那问题就严重了。当前之有IE支持文件路径的读取了,其余浏览器都不会提供路径功能,都是直接文件名,路径都没有的。
热心网友
时间:2023-10-22 15:31
这个是不可能的。
解释:文件下载虽说是获取的真实文件内容,但是传递的时候可不是通过的整个文件,而是读取的文件内容为流,之后传递的,也就是说此过程实际上是文件内容的传递,所以是没法获取到的。
备注:这个要是能获取到,那可就危险了,随意知道开发者的文件路径,以后直接就能把开发者程序拿下来用,那问题就严重了。当前之有IE支持文件路径的读取了,其余浏览器都不会提供路径功能,都是直接文件名,路径都没有的。
热心网友
时间:2023-10-22 15:31
用httpclient试试吧
热心网友
时间:2023-10-22 15:31
用httpclient试试吧
热心网友
时间:2023-10-22 15:31
用httpclient试试吧