当前位置:   article > 正文

Android小Demo——通过MQTT协议连接OneNet平台(新版)_mqtt连接新版one net平台时,设备id怎么看

mqtt连接新版one net平台时,设备id怎么看

详细的过程可参考:https://blog.csdn.net/weixin_51080921/article/details/124150694?spm=1001.2014.3001.5501

这里只是说明和旧版不一样的地方

第一个是服务器接入地址(非加密方式):

private static final String SERVER_URL = "tcp://mqtts.heclouds.com:1883";

第二个是设备ID(这里的设备ID直接是设备名字):

private static final String CLIENT_ID = "Android";

第三个是PASSWORD(这里的密码是Token生成的):

可参考:https://blog.csdn.net/weixin_51080921/article/details/124197691?spm=1001.2014.3001.5501

中的第三步做法

下面说说加密方式连接:

首先是证书,可参考:https://blog.csdn.net/weixin_51080921/article/details/124253434?spm=1001.2014.3001.5501

onenet文档中心下载的证书格式是.pem的,Android中要用到的得转为.bks格式。

然后是服务器接入地址(关于是tcp还是ssl看自己喜欢,但是一定要前后匹配):

private static final String SERVER_URL = "ssl://mqttstls.heclouds.com:8883";

前面说的前后匹配是指:

Server URI and supplied <code>SocketFactory</code> do not match.
URIs beginning <code>tcp://</code> must use a <code>javax.net.SocketFactory</code>,
and URIs beginning <code>ssl://</code> must use a <code>javax.net.ssl.SSLSocketFactory</code>.
  1. // 添加证书
  2. sslSocketFactory = getSocketFactory();
  3. conOpt.setSocketFactory(sslSocketFactory);

getSocketFactory()函数:

  1. private SSLSocketFactory getSocketFactory() {
  2. try {
  3. SSLContext context;
  4. KeyStore ts = KeyStore.getInstance("BKS");
  5. ts.load(getResources().openRawResource(R.raw.certificate), "123456".toCharArray());
  6. TrustManagerFactory tmf = TrustManagerFactory.getInstance("X509");
  7. tmf.init(ts);
  8. TrustManager[] tm = tmf.getTrustManagers();
  9. context = SSLContext.getInstance("TLS");
  10. context.init(null, tm, null);
  11. return context.getSocketFactory();
  12. } catch (Exception e) {
  13. Log.e(TAG, "认证失败", e);
  14. return null;
  15. }
  16. }
本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号