如何用Carlifornium实现使用PSK算法的DTLS协议
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,如何用Carlifornium实现使用PSK算法的DTLS协议,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Carlifornium是E
千家信息网最后更新 2025年02月03日如何用Carlifornium实现使用PSK算法的DTLS协议
如何用Carlifornium实现使用PSK算法的DTLS协议,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
Carlifornium是Eclipse上的一个CoAP+DTLS框架,CoAP和DTLS是啥就先不说了,上代码。
//指定公私钥文件信息private static final char[] KEY_STORE_PASSWORD = "123456".toCharArray();private static final String KEY_STORE_LOCATION = "demo2.jks";private static final char[] TRUST_STORE_PASSWORD = "123456".toCharArray();private static final String TRUST_STORE_LOCATION = "demo2.jks";......//加载公私钥文件SslContextUtil.Credentials clientCredentials = SslContextUtil.loadCredentials(SslContextUtil.CLASSPATH_SCHEME + KEY_STORE_LOCATION, "demo2", KEY_STORE_PASSWORD,KEY_STORE_PASSWORD);Certificate[] trustedCertificates = SslContextUtil.loadTrustedCertificates(SslContextUtil.CLASSPATH_SCHEME + TRUST_STORE_LOCATION, "demo2", TRUST_STORE_PASSWORD);DtlsConnectorConfig.Builder builder = new DtlsConnectorConfig.Builder();//指定PSK密钥builder.setPskStore(new StaticPskStore("Client_identity", "secretPSK".getBytes()));builder.setIdentity(clientCredentials.getPrivateKey(), clientCredentials.getCertificateChain(),CertificateType.RAW_PUBLIC_KEY, CertificateType.X_509);builder.setTrustStore(trustedCertificates);builder.setRpkTrustAll();builder.setConnectionThreadCount(1);dtlsConnector = new DTLSConnector(builder.build());
这里的demo2.jks,是用jdk的keytool生成的,我是偷懒了,用的同样的公私钥,KEY_STORE_LOCATION 应该是自己的密钥
keytool -genkey -alias demo2 -keypass 123456 -keyalg EC -keysize 256 -validity 3650 -keystore demo2.jks -storepass 123456
keytool生成的pass要与代码中的password一致, alias的名称也要一致。
客户端代码
DtlsConnectorConfig.Builder builder = new DtlsConnectorConfig.Builder();//指定PSK的密钥,字符串secretPSK就是密钥builder.setPskStore(new StaticPskStore("Client_identity", "secretPSK".getBytes()));builder.setConnectionThreadCount(1);//指定用PSK密钥,不然会自动查找ECDHE的公私钥builder.setSupportedCipherSuites("TLS_PSK_WITH_AES_128_GCM_SHA256");dtlsConnector = new DTLSConnector(builder.build());
交互过程抓包大约是这样:
在Server Hello 里能看到使用的是我们指定的PSK算法。
如果两边的配置密钥错误,能看到数据失败:
pom.xml中的依赖如下
org.eclipse.californium californium-core 2.3.0 org.eclipse.californium scandium 2.3.0 org.slf4j slf4j-api 1.7.30 org.apache.logging.log4j log4j-api 2.13.3 org.apache.logging.log4j log4j-core 2.13.3 org.apache.logging.log4j log4j-slf4j-impl 2.13.3
看完上述内容,你们掌握如何用Carlifornium实现使用PSK算法的DTLS协议的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注行业资讯频道,感谢各位的阅读!
密钥
公私
算法
一致
代码
内容
文件
方法
更多
问题
生成
束手无策
为此
上代
信息
原因
名称
字符
字符串
客户
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
深圳市带动美网络技术有限公司
手机网页需要服务器吗
苏宁控股集团的数据库有哪些
一台服务器可以装多少个小程序
常州做软件开发什么价位
db2 数据库分区
软件开发亿玛酷可靠5
电力监控系统网络安全检测
网络安全企业财务比较
嵌入式软件开发可以敏捷么
付款发票数据库表
最小linux代理服务器
数据库可以做小数据库吗
湖南服务器防火墙报价
关于网络安全的认识错误的有哪些
计算机软件开发商
2018网络安全宣传周注册
安图县网络安全宣传图片
保定网络安全卫士
达梦数据库ip限制
sql 数据库 内数据计算
客户达软件开发商
手机与服务器怎样绑定
密云区综合网络技术推广优点
易语言数据库写
榆树质量网络技术服务哪家好
数据库双机热备技术
国家网络安全第三方验证
果洛网络技术调试
典故取名软件开发