java 从服务器下载文件并保存到本地的示例
昨天在做一个项目时,用到了从服务器上下载文件并保存到本地的知识,以前也没有接触过,昨天搞了一天,这个小功能实现了,下面就简单的说一下实现过程;
1.基础知识
当我们想要下载网站上的某个资源时,我们会获取一个url,它是服务器定位资源的一个描述,下载的过程有如下几步:
(1)客户端发起一个url请求,获取连接对象。
(2)服务器解析url,并且将指定的资源返回一个输入流给客户。
(3)建立存储的目录以及保存的文件名。
(4)输出了写数据。
(5)关闭输入流和输出流。
2.实现代码的方法
/**
*@功能下载临时素材接口
*@paramfilePath文件将要保存的目录
*@parammethod请求方法,包括POST和GET
*@paramurl请求的路径
*@return
*/
publicstaticFilesaveUrlAs(Stringurl,StringfilePath,Stringmethod){
//System.out.println("fileName---->"+filePath);
//创建不同的文件夹目录
Filefile=newFile(filePath);
//判断文件夹是否存在
if(!file.exists())
{
//如果文件夹不存在,则创建新的的文件夹
file.mkdirs();
}
FileOutputStreamfileOut=null;
HttpURLConnectionconn=null;
InputStreaminputStream=null;
try
{
//建立链接
URLhttpUrl=newURL(url);
conn=(HttpURLConnection)httpUrl.openConnection();
//以Post方式提交表单,默认get方式
conn.setRequestMethod(method);
conn.setDoInput(true);
conn.setDoOutput(true);
//post方式不能使用缓存
conn.setUseCaches(false);
//连接指定的资源
conn.connect();
//获取网络输入流
inputStream=conn.getInputStream();
BufferedInputStreambis=newBufferedInputStream(inputStream);
//判断文件的保存路径后面是否以/结尾
if(!filePath.endsWith("/")){
filePath+="/";
}
//写入到文件(注意文件保存路径的后面一定要加上文件的名称)
fileOut=newFileOutputStream(filePath+"123.png");
BufferedOutputStreambos=newBufferedOutputStream(fileOut);
byte[]buf=newbyte[4096];
intlength=bis.read(buf);
//保存文件
while(length!=-1)
{
bos.write(buf,0,length);
length=bis.read(buf);
}
bos.close();
bis.close();
conn.disconnect();
}catch(Exceptione)
{
e.printStackTrace();
System.out.println("抛出异常!!");
}
returnfile;
}
3.代码测试类(主函数)
/**
*@paramargs
*/
publicstaticvoidmain(String[]args)
{
StringphotoUrl="https://ss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/img/logo/bd_logo1_31bdc765.png";
StringfileName=photoUrl.substring(photoUrl.lastIndexOf("/"));
//System.out.println("fileName---->"+fileName);
StringfilePath="d:";
Filefile=saveUrlAs(photoUrl,filePath+fileName,"GET");
System.out.println("Runok!/n
GetURLfile"+file);
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。