如何用Carlifornium实现使用PSK算法的DTLS协议
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,如何用Carlifornium实现使用PSK算法的DTLS协议,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Carlifornium是E
千家信息网最后更新 2025年12月01日如何用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安全错误
数据库的锁怎样保障安全
淮安营销软件开发系统
淮北网络安全中心
vb6的数据库应用
未将网络安全风险 处罚
直销软件开发如何选择
未来10年软件开发方向
网络技术 英语教学
TGP连接服务器
网络安全最高职位
青海星捷网络技术有限公司
何为数据库安全性
从网络安全性来看
建筑行业安全风险清单和数据库
方舟小宇服务器管理工具
网络安全龙头企业飞利信
软件开发公司该怎么找业务
数据库科学计数法转换
艺是网络技术有限公司怎么样
网络安全工程师通过率
蓝牙无线网络技术的应用
地理信息数据库招聘
网络营销对比软件开发
win服务器防御syn攻击
opc ua模拟服务器软件
工厂报表软件开发
幼儿教师网络安全周班会过程
关系数据库标准语言sql复习题
软件开发财务岗位
蓝牙无线网络技术的应用
极路由 打印服务器