版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数字签名使用手册数字签名使用手册数字签名使用手册全文共7页,当前为第1页。数字签名使用手册全文共7页,当前为第1页。一.概述原理及特点每个人都有一对「钥匙」(数字身份),其中一个只有她/他本人知道(密钥),另一个公开的(公钥)。签名的时候用私钥,验证签名的时候用公钥。又因为任何人都可以落款申称她/他就是你,因此公钥必须向接受者信任的人(\o"身份认证机构"身份认证机构)来注册。注册后身份认证机构给你发一\o"数字证书"数字证书。对文件签名后,你把此数字证书连同文件及签名一起发给接受者,接受者向\o"身份认证机构"身份认证机构求证是否真地是用你的密钥签发的文件。在通讯中使用数字签名一般基于以下原因:鉴权:公钥加密系统允许任何人在发送信息时使用私钥进行加密,数字签名能够让信息接收者利用发送者的公钥确认发送者的身份。当然,接收者不可能百分之百确信发送者的真实身份,而只能在密码系统未被破译的情况下才有理由确信。鉴权的重要性在财务数据上表现得尤为突出。举个例子,假设一家银行将指令由它的分行传输到它的中央管理系统,指令的格式是(a,b),其中a是账户的账号,而b是账户的现有金额。这时一位远程客户可以先存入100元,观察传输的结果,然后接二连三的发送格式为(a,b)的指令。这种方法被称作重放攻击。完整性:传输数据的双方都总希望确认消息未在传输的过程中被修改。加密使得第三方想要读取数据十分困难,然而第三方仍然能采取可行的方法在传输的过程中修改数据。一个通俗的例子就是同形攻击:回想一下,还是上面的那家银行从它的分行向它的中央管理系统发送格式为(a,b)的指令,其中a是账号,而b是账户中的金额。一个远程客户可以先存100元,然后拦截传输结果,再传输(a,b3),这样他就立刻变成百万富翁了。不可否认性:在密文背景下,抵赖这个词指的是不承认与消息有关的举动(即声称消息来自第三方)。消息的接收方可以通过数字签名来防止所有后续的抵赖行为,因为接收方可以出示签名给别人看来证明信息的来源。数字签名使用手册全文共7页,当前为第2页。数字签名使用手册全文共7页,当前为第2页。二.平台实现渠道请求平台:渠道请求平台数据需要签名,然后综合接入平台需要使用渠道提供的公钥进行解密,确认平台推送交易结果综合接入平台会对推送的交易结果进行签名,推送给各个渠道,各个渠道在使用综合接入平台提供的公钥进行解密确认。三.数字签名的生成生成自签证书:个人或机构可以从信任的证书分发机构申请得到证书,比如说,可以从得到一个属于个人的证书。这里可以利用J2SDK的安全工具keytool手工产生自签证书,所谓自签证书是指证书中的“SubjectName”和“IssuerName”相同的证书。下面产生一个自签证书。安装完J2SDK(这里用的是J2SDK1.4)后,在J2SDK安装目录的bin目录下,有一个keytool的可执行程序。利用keytool产生自签证书的步骤如下:数字签名使用手册全文共7页,当前为第3页。第一步,用-genkey命令选项,产生公私密钥对。在控制台界面输入:keytool-genkey-aliastestkeypair-keyalgRSA-keysize1024-sigalgMD5withRSA。这里的-alias表示使用这对公私密钥产生新的keystore入口的别名(keystore是用来存放管理密钥对和证书链的,缺省位置是在使用者主目录下,以.keystore为名的隐藏文件,当然也可指定某个路径存放.keystore文件);-keyalg是产生公私钥对所用的算法,这里是RSA;-keysize定义密钥的长度;-sigalg是签名算法,选择MD5withRSA,即用RSA签名,然后用MD5哈希算法摘要。接下来,系统会提示进行一些输入:数字签名使用手册全文共7页,当前为第3页。第二步,导出自签证书,由上面两步产生的证书,已经存放在以“testkeypair”为别名的keystore入口了,如果使用其文件,必须导出证书。输入四.Java数字签名,验证例子packagecom.platform.digit;importjava.io.BufferedInputStream;importjava.io.FileInputStream;importjava.io.IOException;importjava.security.KeyStore;importjava.security.PrivateKey;importjava.security.PublicKey;importjava.security.Signature;importjava.security.cert.CertificateFactory;数字签名使用手册全文共7页,当前为第4页。importjava.security.cert.X509Certificate;数字签名使用手册全文共7页,当前为第4页。publicclassTestDigit{ /****@paramsigText*@paramKeyPasswordkeystore密码*@paramKeyStorePath公私密钥对,keystore是用来存放管理密钥对和证书链的*@paramalias表示使用这对公私密钥产生新的keystore入口的别名*@return*/ publicstaticStringsig(byte[]sigText,String KeyPassword,StringKeyStorePath,Stringalias){ char[]kpass; inti; StringencodeStr=null; try{ KeyStoreks=KeyStore.getInstance("JKS"); FileInputStreamksfis=newFileInputStream(KeyStorePath); BufferedInputStreamksbufin=newBufferedInputStream(ksfis); kpass=newchar[KeyPassword.length()]; for(i=0;i<KeyPassword.length();i++) kpass[i]=KeyPassword.charAt(i); ks.load(ksbufin,kpass); PrivateKeypriv=(PrivateKey)ks.getKey(alias,kpass); Signaturersa=Signature.getInstance("MD5withRSA"); rsa.initSign(priv); rsa.update(sigText); byte[]sig=rsa.sign(); sun.misc.BASE64Encoderbase64=newsun.misc.BASE64Encoder(); encodeStr=base64.encode(sig); System.out.println("sigisdone"+encodeStr); }catch(Exceptione){ e.printStackTrace(); }数字签名使用手册全文共7页,当前为第5页。 数字签名使用手册全文共7页,当前为第5页。 returnencodeStr; } /** * *@paramupdateData *@paramsigedText */ publicstaticvoidveriSig(byte[]updateData,byte[]sigedText){ try{ CertificateFactory certificatefactory=CertificateFactory.getInstance("X.509"); FileInputStreamfin=newFileInputStream("e://14_public.cer");//公钥路径 X509Certificate certificate=(X509Certificate)certificatefactory.generateCertificate(fin); PublicKeypub=certificate.getPublicKey(); Signaturersa=Signature.getInstance("MD5withRSA"); rsa.initVerify(pub); rsa.update(updateData); booleanverifies=rsa.verify(sigedText); System.out.println("verified"+verifies); if(verifies){ System.out.println("Verifyisdone!"); }else{ System.out.println("verifyisnotsuccessful"); } }catch(Exceptione){ e.printStackTrace(); } } publicstaticvoidcreateKeyPairs()throwsException{ } /** *@paramargs数字签名使用手册全文共7页,当前为第6页。 */数字签名使用手册全文共7页,当前为第6页。 publicstaticvoidmain(String[]args){ //TODOAuto-generatedmethodstub// StringencodeStr="fHvkfVPzuZgE+0XMH6qD1D9FgNrUL3XL4x8ZbOOoipLd03VvF06ZLZ4h/vFkeB4iF0Jn1h8+S5OV211LFlXJrw08DqmhH1Pp4J4SOaVgs6K0z/adRVUj5jfDoJOG0+mE9LdhIs9g62TUzVKtFpMKCratJZjdMuH3tbgzNqKXzRE="; // StringencodeStr="I2Q5IKEL5HaF/N4tVBbO+GaOkPShnblKP70HjoLhglTbtXBSx69fW/xWj27BEBloCkTlXOPwYN+vEdk+UvQfge90ACkXGtjG75o5Knx2fopgHEHcsMhbIB4tjbyvKyaQcJiFX4FougMvyhjVWljIpU8A6KzHMJRRFFE7jFWTTUQ="; Stringsss2="000<?xmlversion=\"1.0\"encoding=\"UTF-8\"?>\n<msg><headtranscode=\"000\"partnerid=\"14\"version=\"1.0\"time=\"2011041101802169\"/><body><msgerrorCode=\"9015\"msg=\"订单不存在\"/></body></msg>"; Stringsiger=null; siger=TestDigit.sig(sss2.getBytes(),"111111","e://14_private","500wan"); byte[]sigedText=null; sun.misc.BASE64Decoderbase64=newsun.misc.BASE6
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 会员生日关怀与惊喜服务流程
- 农用无人机电池维护保养规范
- 小儿推拿手法操作教程
- 客户入店接待服务流程
- 蔬菜农药残留快速检测技术指引
- 体质测试仪器操作规范
- 现场应急处置方案编制指南
- 大田蚜虫低毒农药防治作业实施规范
- 老人助浴服务安全操作执行标准
- 蛋鸡光照管理技术操作制度
- 2025年贵州省贵阳市初二地理生物会考考试试题及答案
- 2026年宁波市九年级中考语文一模试卷附答案解析
- 第13课 每个人都有梦想 课件(内嵌视频)2025-2026学年道德与法治二年级下册统编版
- 【完整版】施工现场群体性事件应急预案
- 2026年中考历史考前冲刺:小论文 满分方法指导讲义
- 2026年中职舞蹈教师考试试题
- 2026首创证券股份有限公司校园招聘备考题库附答案详解ab卷
- 《新能源汽车整车控制技术》课件-项目1 整车控制器系统概述
- 2025广东省低空经济产业发展有限公司招聘13人笔试历年典型考点题库附带答案详解
- 2025年公共卫生监测与防控指南
- 钢铁企业节能降耗培训
评论
0/150
提交评论