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

怎样在建设部网站查资质证书商业网站网站建设

怎样在建设部网站查资质证书,商业网站网站建设,怎么创建自己的免费网址,设计自学网数字签名标准算法——DSA 1. 算法简述2.模型分析3. 代码实现3.1 算法实现3.2 测试代码3.3 运行结果 1. 算法简述 RSA为经典数字签名算法 数字签名标准(Digital Signature Standard, DSS), DSS本质是ElGamal数字签名算法#xff0c;DSS使用的算法成为数字签名算法(Digital Sig… 数字签名标准算法——DSA 1. 算法简述2.模型分析3. 代码实现3.1 算法实现3.2 测试代码3.3 运行结果 1. 算法简述 RSA为经典数字签名算法 数字签名标准(Digital Signature Standard, DSS), DSS本质是ElGamal数字签名算法DSS使用的算法成为数字签名算法(Digital Signature Algorithm, DSA)。 DSA与RSA是数字证书不可或缺的两种算法。DSA算法仅包含数字签名算法使用DSA算法的数字证书无法进行加密通信而RSA算法既包含加密/解密算法同时兼具数字签名算法。 2.模型分析 Alice与Bob作为消息交互双方签名/验签流程如下 3. 代码实现 Java及Bouncy Castle对RSA实现细节 算法密钥长度密钥默认长度签名长度备注SHA1withDSA5121024位64倍数1024-JavaSHA224withDSA、SHA256withDSA 、SHA384withDSA、SHA512withDSA5121024位64倍数1024-Bouncy Castle实现 3.1 算法实现 下面是Java的DSA算法实现 package com.calvin.android.demo2.secrity;import java.security.Key; import java.security.KeyFactory; import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.PrivateKey; import java.security.PublicKey; import java.security.SecureRandom; import java.security.Signature; import java.security.interfaces.DSAPrivateKey; import java.security.interfaces.DSAPublicKey; import java.security.spec.PKCS8EncodedKeySpec; import java.security.spec.X509EncodedKeySpec; import java.util.HashMap; import java.util.Map;/*** Author:cl* Email:lhzhenggrandstream.cn* Date:20-10-21*/ public class DSACoder {/*** 数字签名密钥算法*/public static final String KEY_ALGORITHM DSA;/*** 数字签名* 签名/验证算法*/public static final String SIGNATURE_ALGORITHM SHA1withDSA;//公钥 Map Keyprivate static final String PUBLIC_KEY DSAPublicKey;//私钥Map keyprivate static final String PRIVATE_KEY DSAPrivateKey;/*** DSA密钥长度默认1024位密钥长度必须是64的倍数范围5121024位之间*/private static final int KEY_SIZE 1024;/*** 签名* param data 待签名数据* param privateKey 私钥* return byte[] 数字签名* throws Exception 异常*/public static byte[] sign(byte[] data, byte[] privateKey) throws Exception {//转换私钥材料PKCS8EncodedKeySpec pkcs8KeySpec new PKCS8EncodedKeySpec(privateKey);//实例化密钥工厂KeyFactory keyFactory KeyFactory.getInstance(KEY_ALGORITHM);//取私钥对象PrivateKey priKey keyFactory.generatePrivate(pkcs8KeySpec);//实例化SignatureSignature signature Signature.getInstance(SIGNATURE_ALGORITHM);//初始化Signaturesignature.initSign(priKey);//更新signature.update(data);//签名return signature.sign();}/*** 校验* param data 待校验数据* param publicKey 公钥* param sign 数字签名* return boolean 校验成功返回true校验失败返回false* throws Exception*/public static boolean verity(byte[] data, byte[] publicKey, byte[] sign) throws Exception{//转换公钥材料X509EncodedKeySpec keySpec new X509EncodedKeySpec(publicKey);//实例化密钥工厂KeyFactory keyFactory KeyFactory.getInstance(KEY_ALGORITHM);//生成公钥PublicKey pubKey keyFactory.generatePublic(keySpec);//实例化SignatureSignature signature Signature.getInstance(SIGNATURE_ALGORITHM);//初始化Signaturesignature.initVerify(pubKey);//更新signature.update(data);//校验证return signature.verify(sign);}public static MapString, Object initKey() throws Exception {//实例化密钥对生成器KeyPairGenerator keyPairGen KeyPairGenerator.getInstance(KEY_ALGORITHM);//初始化密钥对生成器keyPairGen.initialize(KEY_SIZE, new SecureRandom());//生成密钥对KeyPair keyPair keyPairGen.generateKeyPair();//公钥DSAPublicKey publicKey (DSAPublicKey)keyPair.getPublic();//私钥DSAPrivateKey privateKey (DSAPrivateKey)keyPair.getPrivate();//封装密钥MapString, Object keyMap new HashMap(2);keyMap.put(PUBLIC_KEY, publicKey);keyMap.put(PRIVATE_KEY, privateKey);return keyMap;}public static byte[] getPublicKey(MapString, Object keyMap){return ((Key)keyMap.get(PUBLIC_KEY)).getEncoded();}public static byte[] getPrivateKey(MapString, Object keyMap){return ((Key)keyMap.get(PRIVATE_KEY)).getEncoded();} } 3.2 测试代码 Testpublic void dsaSignTest() throws Exception {//初始化密钥MapString, Object keyMap DSACoder.initKey();byte[] publicKey DSACoder.getPublicKey(keyMap);byte[] privateKey DSACoder.getPrivateKey(keyMap);System.out.println(公钥\tBase64.encodeToString(publicKey, Base64.DEFAULT));System.out.println(私钥\tBase64.encodeToString(privateKey, Base64.DEFAULT));String inputStr DSA数字签名;byte[] data inputStr.getBytes();//产生签名byte[] sign DSACoder.sign(data, privateKey);System.out.println(签名\t Hex.toHexString(sign));//验证签名boolean status DSACoder.verity(data, publicKey, sign);System.out.println(验签状态\t status);assertTrue(status);}3.3 运行结果 2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: 公钥 MIIBtjCCASsGByqGSM44BAEwggEeAoGBALp0XqBwHX0xv8pzTPn1vYI9xC5eshO2gPWPXOhjNSWY 2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: El4u3aLJcOWW9zrvb9Zzm6jjH316keUqnhbd1A007N3sXIW43YVjsPcqQLw5g45PTxK83UPsVGck 2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: ucwOx38Z1ByI0HW/Hgt8ym3GZ6YRsBNFoJ6AV7ECbHeg9FQ/XvhTAhUAoCMUYSx3rXCqIs7ykNak 2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: JapM0G0CgYBo66ouj4XZz0S3FQaoknrOuSxlYj0UidiXx3NjqEwzSf6gUEVRurOxee0pIZ7Ywf 2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: wzGfUqjPMmn6huQDCRyk5eO9u2NbsRKdBYRGndMbwAO1vyNehtW0TUuxddC1vcdXCUctYAMH49H 2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: RIoXg2zs8KO0BTli2H9Igy69g2ZtwOBhAACgYAsVYqi4LJcuZp8iNKjrPI4jiFxfekwuIx2vmrI 2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: v8yL1602hHirLP85/ibNR8ICGTJK3tkt/FO7nk0DOlLTkct5gXOpzGvp/UuPEONZosxgPHHbf0zQ 2020-10-21 15:06:08.630 15896-15911/com.calvin.android.demo2 I/System.out: NFOWkk6UrOUV4BWcDU6u2OFMf3GAQ4JwUgElTXEI/iyV8m6aD8VCasltcA 2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: 私钥 MIIBSgIBADCCASsGByqGSM44BAEwggEeAoGBALp0XqBwHX0xv8pzTPn1vYI9xC5eshO2gPWPXOhj 2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: NSWYEl4u3aLJcOWW9zrvb9Zzm6jjH316keUqnhbd1A007N3sXIW43YVjsPcqQLw5g45PTxK83UPs 2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: VGckucwOx38Z1ByI0HW/Hgt8ym3GZ6YRsBNFoJ6AV7ECbHeg9FQ/XvhTAhUAoCMUYSx3rXCqIs7y 2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: kNakJapM0G0CgYBo66ouj4XZz0S3FQaoknrOuSxlYj0UidiXx3NjqEwzSf6gUEVRurOxee0pIZ 2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: 7YwfwzGfUqjPMmn6huQDCRyk5eO9u2NbsRKdBYRGndMbwAO1vyNehtW0TUuxddC1vcdXCUctYAM 2020-10-21 15:06:08.631 15896-15911/com.calvin.android.demo2 I/System.out: H49HRIoXg2zs8KO0BTli2H9Igy69g2ZtwQWAhQg4fIBUelmYm8aJvyPOqLadXBAtg 2020-10-21 15:06:08.636 15896-15911/com.calvin.android.demo2 I/System.out: 签名 302c0214404e14880800664e6cd8cb1f8d7c9cfb692c789702144c7ecdfe4128001f838042a913ea714eeced0d12 2020-10-21 15:06:08.640 15896-15911/com.calvin.android.demo2 I/System.out: 验签状态 true
http://www.hkea.cn/news/14515209/

相关文章:

  • 网站开发程序流程图网站推广计划书具体包含哪些基本内容?
  • 百度推广建设网站是不是合发如何修改wordpress模板
  • 珠宝玉器监测网站建设方案seo应该怎么做
  • 太原网站制作优化seo软件系统设计流程
  • 个人网站不备案可以吗python报修网站开发源码
  • 开发板可以做什么网站改版 优化
  • 措美网站建设长沙cms建站模板
  • 计算机应用教程 网站的建设与维护南安市住房和城乡建设局网站
  • 重庆网站公司深圳企业网站建设制作公司
  • 杨庄网站建设千博企业网站系统
  • 装修哪家好优化大师官方正版下载
  • 庆元县建设局网站外网图片素材网站
  • 微信制作网站设计wordpress 后台路径
  • 乒乓球网站怎么做无极商城网站建设
  • 黔东南网站建设河北青山建设集团有限公司网站
  • 温州知名网站推广企业服务账号怎么查询
  • 免费自建手机网站野望王维
  • 域名访问网站慧聪网怎样做网站友情链接
  • 阿里巴巴怎么做公司网站免费做自我介绍网站
  • 虎林网站建设成立公司怎么取名
  • 交互网站开发培训做网站犯法了 程序员有责任吗
  • 公司在兰州要做网站怎样选择互联网营销推广服务商
  • 重庆建设银行官方网站首页做采集网站难不
  • 网站开发用什么工具好微信自动加人软件免费
  • 随县住房和城乡建设局网站爱站网排名
  • 南京建设工程质量监督站网站济南企业做网站
  • 网站开发的关键技术有哪些iis网站属性没有asp.net
  • 怎么做网站版面查备案网站备案
  • 湖北省建设银行网站6php开发工具
  • 优秀的网站建设价格苏州网站建设-中国互联