Java数字签名
2008-01-05 18:30:30 来源:WEB开发网1、建立applet的class文件,在Html中包含进去。
2、使用keytool-genkey建立一个self-signed签名。
3、使用keytool-certreq以此签名生成一个CSR(CertifiateSigningRequest)??(可选)
4、将此CSR递交CA等机构认证,返回一个.cer文件。??(可选)
5、将此.cer文件导入本地keystore(使用keytool-import)。??(可选)
6、使用jar将要发布的applet打包,并且在html中包含此包文件(archieve=XXX.jar)。
7、使用jarsigner和刚才导入keystore的key签名此包。
另:要求客户端必须安装java-plugin1.1以上的版本。
此方法为javasecurity1.1的安全方式,签名认证后,applet可以完全访问本地资源。
假如使用javasecurity1.2方式,则可以配置本地资源访问权限,但是首先要从keystore导出.cer文件,使用policytool制作java.policy文件,将两者随同applet一同发布,在客户端安装java.policy文件和.cer证书。具体细节参考javatuorial中javasecurity1.2。
步骤一:(打包class文件)
在命令行中执行以下的语句:jar-cvfMyApplet.jarclass
步骤二:(在网页中嵌入Applet)
这个网页的名字叫做FileReaderApplet.html,下面是嵌入Applet部分的写法:
<APPLET
CODEBASE="."
CODE="jcomponent.FileReaderApplet.class"
ARCHIVE="MyClass.jar"
NAME="TestApplet"
WIDTH=400
HEIGHT=300
HSPACE=0
VSPACE=0
ALIGN=middle
>
</APPLET>
完成这个步骤后,这个Applet已经可以显示了。但是还不能读写本地的文件系统。
步骤三:(生成证书及签名)
请在命令行环境下执行以下的命令:
1、keytool-genkey-keystorepepper.store-aliaspepper
这个命令用来产生一个密匙库,执行完毕后应该在c:/admin中产生一个pepper.store的文件,这里的pepper是我自己的名字,你可以对它进行修改。另外在执行命令的时候还有提示你输入密匙库的密码,这里你一定要记住,否则后面要用的时候无法输入。
2、keytool-eXPort-keystorepepper.store-aliaspepper-filepepper.cert
这个命令用来产生签名时所要用的证书,同样这里的pepper也可以换成你自己需要的名字。这个命令执行完后在c:/admin中产生一个pepper.cert的文件。
4、jarsigner-keystorepepper.storeMyApplet.jarpepper
这个命令用上面产生的证书将我们的jar文件进行了签名。
更多精彩
赞助商链接