分享
 
 
 

对Java Applet和Java Web Start进行数字签名

王朝java/jsp·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

对Java Applet和Java Web Start进行数字签名

我们知道Java Applet和Java Web Start程序在运行的时候受到安全限制,例如不能够访问本地文件系统,不能够随意访问网络。本文将演示如何对代码做数字签名,让客户在运行时选择是否信任你的签名,以使你的程序具有更多的权限。在这里我们不打算购买证书。

我的计算机环境如下:

Windows2000 professional sp3

SUN JDK1.4.0

IE6.0

JAVA_HOME、PATH、CLASSPATH等环境变量均已设置

客户端需求:

客户端浏览器需要安装Java插件,这里的Java插件是安装JDK时一起安装的。如果客户端不需要做Java开发,可以去下载SUN的网站下载JRE到客户端安装。

接下来看看下面这个Applet,它只有一个按钮,点击这个按钮程序就在本地建立一个文件,如果成功,弹出一个对话框显示成功消息,如果发生异常(安全异常或者IO异常),也弹出一个显示错误的对话框。源文件如下:

源文件test\TestApplet.java

package test;

import java.applet.*;

import java.io.*;

import java.awt.event.*;

import javax.swing.*;

public class TestApplet

extends Applet {

public void init() {

JButton button = new JButton("Create a file");

button.addActionListener(new ActionListener(){

public void actionPerformed(ActionEvent evt){

File file = new File("c:\\a.txt");

try {

file.createNewFile();

JOptionPane.showMessageDialog(null,"成功创建文件c:\\a.txt",

"消息",JOptionPane.INFORMATION_MESSAGE );

}catch (Exception ex) {

JOptionPane.showMessageDialog(

null,ex.getMessage(),"错误",JOptionPane.ERROR_MESSAGE);

}

}

});

add(button);

}

}

在与test目录的父目录编译这个Applet

javac test\TestApplet.java

打包,生成test.jar文件

jar -cvf test.jar test

以下是使用Applet的HTML页面test.html

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=GB2312">

<title>

HTML Test Page

</title>

</head>

<body>

test.Applet1 will appear below in a Java enabled browser.<br>

<applet

codebase = "."

code = "test.TestApplet.class"

name = "TestApplet"

archive = "test.jar"

width = "400"

height = "300"

hspace = "0"

vspace = "0"

align = "middle"

>

</applet>

</body>

</html>

现在就让我们运行一下,打开test.html。点击按钮,你看到了什么?非常不幸,我们没有经过数字签名的Applet在默认情况下没有写本地文件的权限。那么让我们准备签名代码吧。

首先用keytool命令产生用来签名的key。下面这个命令产生一个叫"mykey"的key,它存储在我们新建的叫"mystore"的keystore中。

keytool -genkey -alias mykey -keystore mystore

接下来它会问一些问题包括keystore的密码,key的密码等,如下所示:

输入keystore密码: storepass

您的名字与姓氏是什么?

[Unknown]: AYellow

您的组织单位名称是什么?

[Unknown]: 我的组织单位

您的组织名称是什么?

[Unknown]: 我的组织

您所在的城市或区域名称是什么?

[Unknown]: 北京

您所在的州或省份名称是什么?

[Unknown]: 北京

该单位的两字母国家代码是什么

[Unknown]: CN

CN=AYellow, OU=我的组织单位, O=我的组织, L=北京, ST=北京, C=CN 正确吗?

[否]: Y

输入<mykey>的主密码

(如果和 keystore 密码相同,按回车): keypass

完成后会在当前目录下生成一个叫mystore的文件,这个文件包含了我们的key。用jarsigner命令签名我们的代码test.jar(需要输入keystore和key的密码):

jarsigner -keystore mystore test.jar mykey

Enter Passphrase for keystore: storepass

Enter key password for mykey: keypass

再次运行Applet,在Applet加载的时候会出现一个对话框,说该Applet由不可信任的发行者签名并宣称代码是安全的,是不是要对Applet授权。选择"授权于会话",然后点击我们的按钮,看看是不是成功的创建了文件?

对于Java Web Start程序,签名jar文件的过程是一样的。但是需要在jnlp文件中做一些修改。例如在jnlp根元素下加上一下部分:

<security>

<all-permissions/>

</security>

运行程序,在第一次启动的时候出现以下对话框:

选择"启动",以后启动时这个对话框再也不会出现,因为Java Web Start启动后相当于一个安装在本地的程序,既然第一次客户选择了信任,以后这个对话框就再没有必要出现了。当然,对于上面的Applet例子我们也可以选择"总是授权"。

与大家讨论:仔细查看一下,我们可以发现Applet和Java Web Start出的对话框的措辞是不一样的,而且很显然前者措辞不当,在这种情况下,客户很可能对不可信任的程序授权,造成安全上的隐患。如果前面我们创建keystore的时候在"我的组织"中填上"Microsoft",又会怎么样?对于一个不可信任的程序,前者默认的按钮居然是"授权",而后者是"退出"。Applet的安全为什么会是这样?

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有