java下载https图片 不需要证书cert

package com.example.card.util.httpsimage;

import javax.net.ssl.*;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;

public class HTTPSTrustManager implements X509TrustManager {
    static HostnameVerifier hv = new HostnameVerifier() {
        public boolean verify(String urlHostName, SSLSession session) {
            System.out.println("Warning: URL Host: " + urlHostName + " vs. "
                    + session.getPeerHost());
            return true;
        }
    };

    public final static String retrieveResponseFromServer(final String url) {
        HttpURLConnection connection = null;

        try {
            URL validationUrl = new URL(url);
            trustAllHttpsCertificates();
            HttpsURLConnection.setDefaultHostnameVerifier(hv);

            connection = (HttpURLConnection) validationUrl.openConnection();
            final BufferedReader in = new BufferedReader(new InputStreamReader(
                    connection.getInputStream()));

            String line;
            final StringBuffer stringBuffer = new StringBuffer(255);

            synchronized (stringBuffer) {
                while ((line = in.readLine()) != null) {
                    stringBuffer.append(line);
                    stringBuffer.append("\n");
                }
                return stringBuffer.toString();
            }

        } catch (final IOException e) {
            System.out.println(e.getMessage());
            return null;
        } catch (final Exception e1){
            System.out.println(e1.getMessage());
            return null;
        }finally {
            if (connection != null) {
                connection.disconnect();
            }
        }
    }

    public static void trustAllHttpsCertificates() throws Exception {
        TrustManager[] trustAllCerts = new TrustManager[1];
        TrustManager tm = new miTM();
        trustAllCerts[0] = tm;
        SSLContext sc = SSLContext
                .getInstance("SSL");
        sc.init(null, trustAllCerts, null);
        HttpsURLConnection.setDefaultSSLSocketFactory(sc
                .getSocketFactory());
    }

    @Override
    public void checkClientTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {

    }

    @Override
    public void checkServerTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {

    }

    @Override
    public X509Certificate[] getAcceptedIssuers() {
        return new X509Certificate[0];
    }

    static class miTM implements TrustManager,
            X509TrustManager {
        public X509Certificate[] getAcceptedIssuers() {
            return null;
        }

        public boolean isServerTrusted(
                X509Certificate[] certs) {
            return true;
        }

        public boolean isClientTrusted(
                X509Certificate[] certs) {
            return true;
        }

        public void checkServerTrusted(
                X509Certificate[] certs, String authType)
                throws CertificateException {
            return;
        }

        public void checkClientTrusted(
                X509Certificate[] certs, String authType)
                throws CertificateException {
            return;
        }
    }
}

package com.example.card.util.httpsimage;

import javax.net.ssl.HttpsURLConnection;
import java.io.*;
import java.net.URL;

/**
 * @author szc
 * @date 2021/4/21 - 16:42
 */
public class test4 {
    public static void main(String[] args) throws IOException {

        String strUrl = "https://xxx.xxx.xxx.xx:xxx/pic?0d4e00=5300ip-8eo081-070d587-495036ab9**631===sp**117=7t4265996=4l4*1046=5o9*0c25*a176od-a2l2064=005";
        HTTPSTrustManager.retrieveResponseFromServer(strUrl);
        URL url = new URL(strUrl);

        //构造连接
        HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();

        //这个网站要模拟浏览器才行
        conn.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; rv:11.0) like Gecko");

        //打开连接
        conn.connect();
        //打开这个网站的输入流
        InputStream inStream = conn.getInputStream();

        //用这个做中转站 ,把图片数据都放在了这里,再调用toByteArray()即可获得数据的byte数组
        ByteArrayOutputStream outStream = new ByteArrayOutputStream();
        //用这个是很好的,不用一次就把图片读到了文件中
        //要是需要把图片用作其他用途呢?所以直接把图片的数据弄成一个变量,十分有用
        //相当于操作这个变量就能操作图片了

        byte[] buf = new byte[1024];
        //为什么是1024?
        //1024Byte=1KB,分配1KB的缓存
        //这个就是循环读取,是一个临时空间,多大都没关系
        //这没有什么大的关系,你就是用999这样的数字也没有问题,就是每次读取的最大字节数。
        //byte[]的大小,说明你一次操作最大字节是多少
        //虽然读的是9M的文件,其实你的内存只用1M来处理,节省了很多空间.
        //当然,设得小,说明I/O操作会比较频繁,I/O操作耗时比较长,
        //这多少会有点性能上的影响.这看你是想用空间换时间,还是想用时间换空间了.
        //时间慢总比内存溢出程序崩溃强.如果内存足够的话,我会考虑设大点.
        int len = 0;
        //读取图片数据    
        while ((len = inStream.read(buf)) != -1) {
            System.out.println(len);
            outStream.write(buf, 0, len);
        }
        inStream.close();
        outStream.close();
        //把图片数据填入文件中
        File file = new File("d://0009//t.jpg");

        FileOutputStream op = new FileOutputStream(file);

        op.write(outStream.toByteArray());

        op.close();


    }
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好,关于Java请求HTTPS证书异常的问题,可能是由于以下原因导致的: 1. 证书不被信任:您需要确保证书是有效且被Java信任的。您可以通过安装证书来解决此问题。 2. 证书链不完整:如果证书链不完整,则可能导致Java无法验证证书。您需要确保证书链完整且正确。 3. 服务器配置错误:如果服务器配置错误,则可能导致Java请求证书异常。您需要检查服务器配置是否正确。 以下是一个简单的Java HTTPS请求示例,您可以参考一下: ``` import javax.net.ssl.HttpsURLConnection; import java.net.URL; import java.security.cert.X509Certificate; import javax.net.ssl.X509TrustManager; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManager; import java.security.SecureRandom; public class HttpsRequest { public static void main(String[] args) throws Exception { URL url = new URL("https://example.com"); SSLContext sslContext = SSLContext.getInstance("TLS"); TrustManager[] trustManagers = new TrustManager[] { new X509TrustManager() { public X509Certificate[] getAcceptedIssuers() { return null; } public void checkClientTrusted(X509Certificate[] certs, String authType) { } public void checkServerTrusted(X509Certificate[] certs, String authType) { } } }; sslContext.init(null, trustManagers, new SecureRandom()); HttpsURLConnection conn = (HttpsURLConnection) url.openConnection(); conn.setSSLSocketFactory(sslContext.getSocketFactory()); conn.setRequestMethod("GET"); conn.connect(); System.out.println(conn.getResponseCode()); } } ``` 希望这能够帮助您解决问题。如果还有其他问题,请随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值