您的位置:

使用Java下载图片到本地的方法及实现

一、URL类和InputStream流读取图片资源

Java程序可以通过URL类读取HTTP和FTP协议的文件资源。可以通过以下代码获取输入流,然后通过流读取图片数据,将获取到的图片数据存入到本地文件中。

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.URL;

public class DownloadImage{

    public static void download(String urlString, String filename) throws Exception {
        // 构造URL
        URL url = new URL(urlString);
        // 打开连接
        InputStream inputStream = url.openConnection().getInputStream();
        // 建立文件
        File file=new File(filename);
        FileOutputStream outputStream = new FileOutputStream(file);
        // 读取数据
        byte[] buffer = new byte[1024];
        int len = 0;
        while((len = inputStream.read(buffer)) != -1){
            outputStream.write(buffer,0,len);
        }
        // 关闭流
        inputStream.close();
        outputStream.close();
    }

    public static void main(String[] args) throws Exception {
        download("https://cdn.pixabay.com/photo/2015/04/23/22/00/tree-736885__340.jpg", "D:\\images\\tree.jpg");
    }
}

在上述代码示例中,download方法接收两个参数:资源的URL和保存的文件名。程序首先构造URL,然后打开连接获取输入流。然后建立存储图片信息的文件,开启输出流将读取到的数据写入到指定文件中,最后关闭流并退出程序。

二、使用URLConnection setRequestProperty方法设置浏览器请求头信息

有些URL需要在浏览器中正确的访问,因此需要在Java程序中设置请求头信息,这可以使用URLConnection类的setRequestProperty方法实现。以下是示例代码:

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;

public class DownloadImage{

    public static void download(String urlString, String filename) throws Exception {
        // 构造URL
        URL url = new URL(urlString);
        // 打开连接
        HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
        // 设置请求头信息,伪装成浏览器发起请求
        httpURLConnection.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
        // 获取流
        InputStream inputStream = httpURLConnection.getInputStream();
        // 建立文件
        File file=new File(filename);
        FileOutputStream outputStream = new FileOutputStream(file);
        // 读取数据
        byte[] buffer = new byte[1024];
        int len = 0;
        while((len = inputStream.read(buffer)) != -1){
            outputStream.write(buffer,0,len);
        }
        // 关闭流
        inputStream.close();
        outputStream.close();
    }

    public static void main(String[] args) throws Exception {
        download("https://cdn.pixabay.com/photo/2015/04/23/22/00/tree-736885__340.jpg", "D:\\images\\tree.jpg");
    }
}

在上述代码中,使用HttpURLConnection类打开URL连接,并在请求头中加入用户代理字符串,这可以防止一些服务器屏蔽来自Java程序的请求,最后获取流和保存数据的过程与前面的示例类似。

三、使用IOUtils工具类做代码简化

将文件下载到本地是一个重复的过程,可以使用一个工具类简化代码。Apache的commons-io将其封装为一个IOUtils工具类,这个类提供大量常用方法,可以对文件进行许多操作,从而提高开发效率,减少重复代码。以下是使用IOUtils工具类下载文件的示例代码:

import org.apache.commons.io.FileUtils;

import java.io.File;
import java.net.URL;

public class DownloadImage {

    public static void download(String urlString, String filename) throws Exception {
        URL url = new URL(urlString);
        File file = new File(filename);
        FileUtils.copyURLToFile(url, file);
    }

    public static void main(String[] args) throws Exception {
        download("https://cdn.pixabay.com/photo/2015/04/23/22/00/tree-736885__340.jpg", "D:\\images\\tree.jpg");
    }
}

在上述代码中,使用了Apache的commons-io库,其中FileUtils.copyURLToFile方法将指定的URL资源下载到指定的文件中,省去了构建流、保存数据的繁琐过程,提高代码的简洁性和可读性。

四、使用第三方库Jsoup下载图片

除了Java自带的库和Apache的commons-io库外,第三方库jsoup也可以用来下载图片资源。Jsoup主要用于HTML解析和DOM操作,但是它也可以用来下载图片。以下是jsoup下载文件的示例代码:

import org.jsoup.Jsoup;

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.URL;

public class DownloadImage {

    public static void download(String url, String filename) throws Exception {
        URL imageUrl = new URL(url);
        File file = new File(filename);
        BufferedOutputStream outputStream = new BufferedOutputStream(new FileOutputStream(file));
        InputStream inputStream = Jsoup.connect(url).ignoreContentType(true).execute().bodyStream();
        byte[] buffer = new byte[8192];
        int bytesRead;
        while ((bytesRead = inputStream.read(buffer)) != -1) {
            outputStream.write(buffer, 0, bytesRead);
        }
        outputStream.close();
        inputStream.close();
    }

    public static void main(String[] args) throws Exception {
        download("https://cdn.pixabay.com/photo/2015/04/23/22/00/tree-736885__340.jpg", "D:\\images\\tree.jpg");
    }
}

在上述代码中,使用了jsoup.connect方法获取指定URL的输出流,InputStream获取流数据,将其存储到指定文件中。如果需要仅仅获取二进制数据,可以使用.ignoreContentType(true)方法,这可以保证获取到的数据是原始数据,不会进行处理。

总结

本文介绍了Java下载图片到本地的四种方法。第一种方法利用URL类和InputStream读取图片资源,并且将资源写入到指定文件。第二种方法使用URLConnection类,并且设置请求头信息来下载图片资源。第三种方法简化了代码,使用了commons-io库中提供的copyURLToFile方法。第四种方法使用了第三方库Jsoup,从指定URL中获取输入流,将文件写入到指定文件中。这些方法各有优缺点,在实际开发中应该根据实际需要灵活选择。