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); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。