栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何使用自签名证书连接到Android(Paho客户端)中的Mqtt服务器?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何使用自签名证书连接到Android(Paho客户端)中的Mqtt服务器?

终于找到了解决办法。

根据此文档,Android API级别16(Android 4.1,Jelly
Bean)支持TLS 1.1和TLS 1.2。 但默认情况下, 直到API级别20+才 启用 (手表使用Android 4.4,Kitkat
Watch和手机5.0,Lollipop Android 5.0)。

因此,我们需要的是在代码中以图形方式启用它们。我们该怎么做?这里有解决此问题的方法,但是它只是解决了您要接受任何证书的情况下的问题。

我们需要做的是做同样的事情,但要使用我们自己的自签名证书。所以我们像下面这样
第一部分就像我之前所做的那样:(

keyStoreInputStream
是.pfx文件的输入流)

connection = createConnection(mqttCallback);MqttConnectOptions connOpts = optionsFromModel(connectionModel);connOpts.setSocketFactory(getSSLSocketFactory(keyStoreInputStream, keyStorePassword));connection.addConnectionOptions(connOpts);

getSSLSocketFactory
方法改变为:

 public SSLSocketFactory getSSLSocketFactory (InputStream keyStore, String password) throws MqttSecurityException {    try{        SSLContext ctx = null;        SSLSocketFactory sslSockFactory=null;        KeyStore ks;        ks = KeyStore.getInstance("PKCS12");        ks.load(keyStore, password.toCharArray());        TrustManagerFactory tmf = TrustManagerFactory.getInstance("X509");        tmf.init(ks);        TrustManager[] tm = tmf.getTrustManagers();        ctx = SSLContext.getInstance("TLS");        ctx.init(null, tm, null);        if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.KITKAT) { sslSockFactory = new TLSSocketFactory(tm);        } else { sslSockFactory = ctx.getSocketFactory();        }        return sslSockFactory;    } catch (KeyStoreException | CertificateException | IOException | NoSuchAlgorithmException | KeyManagementException e) {        throw new MqttSecurityException(e);    }}

TLSSocketFactory
类象下面这样:

import java.io.IOException;import java.net.InetAddress;import java.net.Socket;import java.net.UnknownHostException;import java.security.KeyManagementException;import java.security.NoSuchAlgorithmException;import javax.net.ssl.SSLContext;import javax.net.ssl.SSLSocket;import javax.net.ssl.SSLSocketFactory;import javax.net.ssl.TrustManager;public class TLSSocketFactory extends SSLSocketFactory {private SSLSocketFactory internalSSLSocketFactory;public TLSSocketFactory(TrustManager[] trustManagers) throws KeyManagementException, NoSuchAlgorithmException {    SSLContext context = SSLContext.getInstance("TLS");    context.init(null, trustManagers, null);    internalSSLSocketFactory = context.getSocketFactory();}@Overridepublic String[] getDefaultCipherSuites() {    return internalSSLSocketFactory.getDefaultCipherSuites();}@Overridepublic String[] getSupportedCipherSuites() {    return internalSSLSocketFactory.getSupportedCipherSuites();}@Overridepublic Socket createSocket() throws IOException {    return enableTLSonSocket(internalSSLSocketFactory.createSocket());}@Overridepublic Socket createSocket(Socket s, String host, int port, boolean autoClose) throws IOException {    return enableTLSonSocket(internalSSLSocketFactory.createSocket(s, host, port, autoClose));}@Overridepublic Socket createSocket(String host, int port) throws IOException, UnknownHostException {    return enableTLSonSocket(internalSSLSocketFactory.createSocket(host, port));}@Overridepublic Socket createSocket(String host, int port, InetAddress localHost, int localPort) throws IOException, UnknownHostException {    return enableTLSonSocket(internalSSLSocketFactory.createSocket(host, port, localHost, localPort));}@Overridepublic Socket createSocket(InetAddress host, int port) throws IOException {    return enableTLSonSocket(internalSSLSocketFactory.createSocket(host, port));}@Overridepublic Socket createSocket(InetAddress address, int port, InetAddress localAddress, int localPort) throws IOException {    return enableTLSonSocket(internalSSLSocketFactory.createSocket(address, port, localAddress, localPort));}private Socket enableTLSonSocket(Socket socket) {    if(socket != null && (socket instanceof SSLSocket)) {        ((SSLSocket)socket).setEnabledProtocols(new String[] {"TLSv1.2", "TLSv1.1"});    }    return socket;}}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/483696.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号