当前位置: 首页 > wzjs >正文

廊坊文安建设局网站百度关键词挖掘工具

廊坊文安建设局网站,百度关键词挖掘工具,wordpress category 参数,win扁平风格的bootstrap响应式网站后台管理模板初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的,可以在任何平台上使用。 源码指引:github源…

初级代码游戏的专栏介绍与文章目录-CSDN博客

我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。

这些代码大部分以Linux为目标但部分代码是纯C++的,可以在任何平台上使用。

源码指引:github源码指引_初级代码游戏的博客-CSDN博客


目录

CA证书、客户端证书和私钥

emqx的MQTTS设置

客户端代码


CA证书、客户端证书和私钥

        使用单向认证时客户端只需要确认服务器证书有效(也可以不确认),一般服务器自签名证书需要将服务器证书的签发者CA的证书放在客户机的受信任的证书签发机构里或程序直接读取CA证书文件。

        证书包含公钥和CA的签名,别人通过验证证书正确性来确认你的身份,与证书对应的私钥则用来解密别人发给你的加密数据(用证书里的公钥加密,只有对应的私钥才能解密,这保证了只有你可以解密)。

        CA证书原则上可以通过操作系统预置加上互联网检索来验证,但是很多时候用的是自签名的CA证书,上互联网验证是没用的,需要手动安装证书告诉操作系统这个证书我认可或者程序直接读取证书文件。

        双向认证时服务端也要确认客户端的证书,因此客户端需要提供客户端证书和签发者的证书,并且客户端证书的签发机构也必须在服务器的受信任名单里。

        一般情况下我们用服务器给的客户端证书,编程的时候需要的就是服务端给的CA证书(同时也是服务器证书的签发者)和客户端证书。

        windows上包含私钥的证书多用pfx格式,unix/linux上则多用pem格式。格式的问题很头疼,我只能说我下面演示的代码在windows上正确执行了,不代表在linux上也能正确执行。

        很多库使用三个文件:CA证书、证书、私钥,CA证书文件其实可以包含多个根证书,后两个是服务器或客户端的证书和私钥,多为pem格式。如果使用pfx格式就只需要两个文件:CA证书和pfx文件(同时包含证书和私钥)。

        单独的证书和私钥多用.cer、.key的扩展名,其实格式一般也是pem文件,扩展名不同而已。pem文件格式可以包含多个私钥、证书(简单地堆进去即可)。

        从两个pem生成一个pfx:

openssl pkcs12 -export -out client.pfx -inkey client.key -in client.cer

        其中key和cer都是pem格式(有时候也用pem后缀名)。 

emqx的MQTTS设置

        在浏览器里设置:

        点击一下监听器的名称,右侧会显示详情,往下拉,重点在下面:

        “验证服务器证书”开关打开才能选择证书文件,这几个证书是emqx安装的时候自带的。感觉这个“服务器”其实是客户端的意思,MQTT概念里并没有服务器、客户端,只有代理(broker)、发布者、订阅者。

        verify_none不验证客户端证书,verify_peer验证客户端证书。

        “Fail If No Peer Cert”这个选项有点坑,如果前面不是verify_peer,而客户端没有客户端证书,这个选项为true就一定会导致连接失败。按照常理既然选择可不验证客户端,那么这个选项应该被忽略才对。

        上图的设置效果是必须使用双向验证。

客户端代码

//参数对象
MqttClientOptionsBuilder mqttClientOptions = new();//常规的IP端口等参数_ = mqttClientOptions.WithTcpServer(hostname, port)//.WithProtocolVersion(MQTTnet.Formatter.MqttProtocolVersion.V311).WithClientId(client_id).WithCleanSession(false).WithKeepAlivePeriod(TimeSpan.FromSeconds(30)).WithCredentials(userid, passwd);//构造认证所需的参数X509Certificate2 caCert = new(caCertpath);//受信任的CA证书文件X509Certificate2 clientCert = new(clientCertpath);//客户端证书和私钥,如果是密码保护的pfx文件,可以用(.pfx,passwd)var newCert = new X509Certificate2(clientCert.Export(X509ContentType.SerializedCert));//怀疑这步就是为了去掉密码保护X509Certificate2Collection certificates = [];_ = certificates.Add(caCert);_ = certificates.Add(newCert);MqttClientTlsOptions tlsOptions = new MqttClientTlsOptions{UseTls = true,AllowUntrustedCertificates = false,SslProtocol = SslProtocols.None, //根据需要选择 TLS 版本,None表示系统选择,Default已经废弃 ClientCertificatesProvider = new DefaultMqttCertificatesProvider(certificates),//加载证书CertificateValidationHandler = ValidateCertifiCertificates//避免证书验证,关键!没这个连接不返回也不报异常};_ = mqttClientOptions.WithTlsOptions(tlsOptions); // tls选项//连接,用的是MQTTnet.Client
public IMqttClient mqttClient;
mqttClient.ConnectAsync(mqttClientOptions.Build());

(这里是文档结束)

http://www.dtcms.com/wzjs/528846.html

相关文章:

  • 做外贸零售和批发批发网站网站推广软件有哪些
  • 目前做的最好的电子烟网站上海站群优化公司
  • 网站设计实验近期国内新闻热点事件
  • 如何做网站弹窗网站关键词优化方法
  • 深圳网址网站建设公司软文广告500字
  • 创新的菏泽网站建设seo外链是什么意思
  • 河南城乡建设厅网站南通企业网站制作
  • 网络销售网站设置域名权重是什么意思
  • 网站备案 法人代表信息检索关键词提取方法
  • 哈尔滨网站制作方案站长统计app软件下载2021
  • 有没有医学生做课件的网站百度官方电话号码
  • 邯郸网站制作公司北京seo公司
  • 重庆开县网站建设公司推荐淮北网站建设
  • 徐州提供网站建设报价表设计网站排行
  • 怎么简单做网站排名搜索引擎优化怎么做的
  • 任丘建设网站制作上海排名seo公司
  • 福州网站建设资讯b站推广在哪里
  • 木材网站建设哪家好外贸网站外链平台
  • 杭州如何设计公司网站百度推广运营
  • 乐山北京网站建设网站产品怎么优化
  • 网站内容与目录结构2023免费b站推广大全
  • 创业网站推广怎么做成功的网络营销案例
  • 泗水做网站刚开的店铺怎么做推广
  • 美食网站开发流程网页设计一般用什么软件
  • 松江新城投资建设发展有限公司网站今日国际新闻头条15条
  • 唐山网站建设外包公司软文营销的作用
  • wordpress去除标签层级推广优化网站排名教程
  • c 做网站 知乎0元做游戏代理
  • 老男孩设置wordpress数据库静态化优化大师手机版下载安装app
  • 商城网站制作的教程百度热点榜单