7

我正在使用 MATLAB 的命令访问内部数据库urlread,一切正常,直到服务被移动到安全服务器(即使用 HTTPS 地址而不是 HTTP 地址)。现在urlread不再成功检索结果。它给出了一个错误:

下载网址时出错。您的网络连接可能已关闭或您的代理设置配置不正确。

我认为问题在于该服务使用了无效的数字证书,因为如果我尝试直接在 Web 浏览器中访问该资源,我会收到“不受信任的连接”警告,我可以通过将站点添加到例外列表来通过该警告。urlread没有明显的方法来处理这个问题。

幕后urlread使用 Java 访问 Web 资源,并在此行抛出错误:

inputStream = urlConnection.getInputStream;

urlConnectionJava 对象在哪里: sun.net.www.protocol.https.HttpsURLConnectionImpl.

有人建议解决此问题的方法吗?

4

3 回答 3

6

考虑以下 Java 类。我将此页面用作参考:

在 HTTPS 连接中禁用证书验证

C:\MATLAB\MyJavaClasses\com\stackoverflow\Downloader.java

package com.stackoverflow;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.security.cert.X509Certificate;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import javax.net.ssl.HostnameVerifier;

public class Downloader {
    public static String getData(String address) throws Exception {
        // Create a trust manager that does not validate certificate chains
        TrustManager[] trustAllCerts = new TrustManager[] {
            new X509TrustManager() {
                public java.security.cert.X509Certificate[] getAcceptedIssuers() {
                    return null;
                }
                public void checkClientTrusted(X509Certificate[] certs, String authType) {
                }
                public void checkServerTrusted(X509Certificate[] certs, String authType) {
                }
            }
        };

        // Create a host name verifier that always passes
        HostnameVerifier allHostsValid = new HostnameVerifier() {
            public boolean verify(String hostname, SSLSession session) {
                return true;
            }
        };

        // Install the all-trusting trust manager
        SSLContext sc = SSLContext.getInstance("SSL");
        sc.init(null, trustAllCerts, new java.security.SecureRandom());
        HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());

        // Install the all-trusting host verifier
        HttpsURLConnection.setDefaultHostnameVerifier(allHostsValid);

        // open connection
        URL page = new URL(address);
        HttpURLConnection conn = (HttpURLConnection) page.openConnection();
        BufferedReader buff = new BufferedReader(new InputStreamReader(conn.getInputStream()));

        // read text
        String line;
        StringBuffer text = new StringBuffer();
        while ( (line = buff.readLine()) != null ) {
            //System.out.println(line);
            text.append(line + "\n");
        }
        buff.close();

        return text.toString();
    }

    public static void main(String[] argv) throws Exception {
        String str = getData("https://expired.badssl.com/");
        System.out.println(str);
    }
}

MATLAB

首先我们编译Java类(我们必须使用与MATLAB兼容的JDK版本):

>> version -java
>> system('javac C:\MATLAB\MyJavaClasses\com\stackoverflow\Downloader.java');

接下来我们在 MATLAB 中实例化并使用它:

javaaddpath('C:\MATLAB\MyJavaClasses')
dl = com.stackoverflow.Downloader;
str = char(dl.getData('https://expired.badssl.com/'));
web(['text://' str], '-new')

以下是一些带有错误 SSL 证书的 URL 进行测试:

urls = {
    'https://expired.badssl.com/'       % expired
    'https://wrong.host.badssl.com/'    % wrong host
    'https://self-signed.badssl.com/'   % self-signed
    'https://revoked.grc.com/'          % revoked
};

更新:我应该提一下,从 R2014b 开始,MATLAB 有一个新功能webread可以取代urlread.

于 2009-10-28T21:02:18.830 回答
0

感谢您的解决方案。它有效,但是,有时,我收到以下异常“java.io.IOException:在受信任的 CA 列表中找不到颁发者”。我无法摆脱这个错误。

因此,我尝试了一种效果很好的替代解决方案。您可以在 Matlab 函数中使用以下 Java 代码:

 function str = ReadUrl(url)
     is = java.net.URL([], url, sun.net.www.protocol.https.Handler).openConnection().getInputStream(); 
     br = java.io.BufferedReader(java.io.InputStreamReader(is));
     str = char(br.readLine());
 end

最好的,一月

于 2012-08-02T13:13:59.003 回答
0

另请注意,解决此问题的“规范”方法是将证书导入 MATLAB 的密钥库(即,不是您的 JVM 的密钥库)。

这在此处记录:Mathworks on using untrusted SSL certificate

于 2013-12-05T13:57:43.343 回答