Java从指定URL下载⽂件并保存到指定⽬录1.基本流程
当我们想要下载⽹站上的某个资源时,我们会获取⼀个url,它是服务器定位资源的⼀个描述,下载的过程有如下⼏步:(1)客户端发起⼀个url请求,获取连接对象。
(2)服务器解析url,并且将指定的资源返回⼀个输⼊流给客户。
(3)建⽴存储的⽬录以及保存的⽂件名。
(4)输出了写数据。
(5)关闭输⼊流和输出流。
2.实现代码的⽅法
/**
* @从制定URL下载⽂件并保存到指定⽬录
* @param filePath ⽂件将要保存的⽬录
* @param method 请求⽅法,包括POST和GET
* @param url 请求的路径
* @return
*/
public static File saveUrlAs(String url,String filePath,String method){
//System.out.println("fileName---->"+filePath);
//创建不同的⽂件夹⽬录
File file=new File(filePath);
//判断⽂件夹是否存在
if (!ists())
{
//如果⽂件夹不存在,则创建新的的⽂件夹
file.mkdirs();
}
FileOutputStream fileOut = null;
HttpURLConnection conn = null;user是什么意思
InputStream inputStream = null;第一个javascript程序
try
{designer是什么意思
java下载过程// 建⽴链接
URL httpUrl=new URL(url);
conn=(HttpURLConnection) httpUrl.openConnection();
//以Post⽅式提交表单,默认get⽅式
conn.setRequestMethod(method);
conn.setDoInput(true);
conn.setDoOutput(true);
// post⽅式不能使⽤缓存
conn.setUseCaches(false);
//连接指定的资源
//获取⽹络输⼊流
InputStream();
BufferedInputStream bis = new BufferedInputStream(inputStream);
//判断⽂件的保存路径后⾯是否以/结尾
if (!dsWith("/")) {
filePath += "/";
}
//写⼊到⽂件(注意⽂件保存路径的后⾯⼀定要加上⽂件的名称)
fileOut = new FileOutputStream(filePath+"123.png");
BufferedOutputStream bos = new BufferedOutputStream(fileOut);
byte[] buf = new byte[4096];
int length = ad(buf);
//保存⽂件
while(length != -1)
{
structure数据
bos.write(buf, 0, length);
length = ad(buf);
}
bos.close();
bis.close();
conn.disconnect();
} catch (Exception e)
{
e.printStackTrace();
System.out.println("抛出异常!!");
}
return file;
}
3.测试类
/**
* @param args
*/
public static void main(String[] args)
{
类风湿病人忌吃什么String photoUrl = "123.png"; //⽂件URL地址
String fileName = photoUrl.substring(photoUrl.lastIndexOf("/")); //为下载的⽂件命名 String filePath = "d:"; //保存⽬录
File file = saveUrlAs(photoUrl, filePath + fileName,"GET");
}
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论