- 浏览: 261212 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (67)
- 面试总结 (2)
- 同时提交同时回滚的问题 (0)
- hibernate (10)
- 导出导入excel (5)
- Ajax (1)
- 正则表达式 (3)
- 网站收集 (1)
- 工具使用技巧 (1)
- Mysql函数收集 (1)
- Oracle时间处理 (1)
- lucus (0)
- spring 配置参数 (1)
- JSF基础知识 (2)
- flex传值 (4)
- javascript (2)
- webflow (1)
- ibatis (1)
- webService (2)
- db2 (1)
- seam集合 (1)
- EJB (1)
- 信道加密 (12)
- 非阻塞的Socket链接(来自老紫竹) (1)
- socket读取文件 并写入文件 (1)
- java反射 (1)
- 综合部分 (2)
- 优化 (1)
- Hibernate打出sql (3)
- jdbc (1)
最新评论
-
GGGGeek:
博主不再写博客了吗?好遗憾,很多博文写的真好啊
Tomcat - SSL操作大全 -
Jocson:
...
SSL与TLS 区别 以及介绍 -
Jocson:
不错啊
SSL与TLS 区别 以及介绍 -
LUCKYZHOUSTAR:
没有实例吗
SSL+socket 详解-概念 -
itshu:
...
https协议及 tomcat https访问设置 默认http也变成https
JavaGUI应用程序部署
JavaGUI程序发布分类
1) Applet:可以嵌入到浏览器中,通过网页的方式展示给用户
2) application :有两种发布方式
ü 打包成jar包通过bat的方式运行,或者通过第三方软件打成exe(后续会再详细介绍)
ü 通过Java Web Start的方式发布到服务器端,通过JNLP运行
相对来说第二种方式可能更好一些,免除了更新的麻烦。
用applet或者jws的方式发布,大部分都需要数字签名。
为什么要签名
其实签名不是必须的,如果你的程序只是单纯的绘图,显示,只要不访问网络资源也不访问本地文件,是不用签名的,
但是如果要访问本地或网上资源就必须签名,
比如读取本地文件或者访问数据库,这是由java的沙箱机制决定的,即jvm内部有一组安全检查规则,要通过检查之后才能访问特定资源。
如果要突破这个规则,可以有两个方法:
1) 修改jre权限文件如下
java.policy为grant {
permission java.security.AllPermission;
};
一般权限文件的目录如下C:"Program Files"Java"jre6"lib"security
但是修改每个客户端的权限文件,无论从时间还是操作上都是很麻烦的。
2) 签名,意思就是告诉用户,这个程序是谁发布的,是不是能信任,如果客户确定,ok,这个applet或者jws就可以访问外部资源了。
如何签名
1)首先确保你已经完全安装了Java2的环境,有keytool工具,它位于JDK的bin目录下。这一般不会有问题。
2)到Dos状态下,进入你需发布应用程序的jar包所在的目录,运行下面这句话
keytool -genkey -keystore myKeystore -alias jwstest -validity 1000
它将会提示你输入用户名、密码等,按照提示随便输入即可,不输入直接回车即可,
但一定要记住密码。运行结束它将会在当前路径下创建名为myKeystore的文件。
3)如果你想查看一下刚才生成的myKeystore文件的内容,可以使用下面这句话:
keytool -list -keystore myKeystore
显示出来应该类似如下:
Keystore type: jks
Keystore provider: SUN
Your keystore contains 1 entry:
jwstest, Tue Nov 23 19:29:32 PST 2001, keyEntry,
Certificate fingerprint (Test):
C3:A9:CD:F3:D3:AC:4D:3F:3C:5B:AF:9E:CF:0D:46:5C
4)对你需发布应用程序的jar包进行签名,运行下面这句话:
jarsigner -keystore myKeystore yourtest.jar jwstest
其中yourtest.jar是你的jar包名,你需要修改它,别的就不必修改了。
运行时会提示你输入密码,就是你刚才在生成myKeystore文件时设定的密码。
如果有很多jar包怎么办
在开发的过程中很可能会引用到第三方的jar包,而第三方的jar包又可能引用到其它的,所以可能有很多的jar包,需要和applet一起发布,有两个方法
1) 分别打包签名,使用于包比较少,比如只有3、4个的情况
2) 只 把applet的jar包签名,让用户确认访问授权,applet已经被用户授权,那么就可以在applet里改变安全管理器(SecurityManager)
只需要继承SecurityManager类,创建自己的安全管理器类,然后覆盖checkPermission方法,允许访问任何资源。
在applet的init方法中调用System.setSecurityManager把安全管理器设置为我们自定义的即可。
class CustomManager extends SecurityManager {
public void checkPermission(Permission perm, Object context) {
}
public void checkPermission(Permission perm) {
}
}
其它一些相关资料如下
JDK中keytool常用命令
-genkey 在用户主目录中创建一个默认文件".keystore",还会产生一个mykey的别名,mykey中包含用户的公钥、私钥和证书
-alias 产生别名
-keystore 指定密钥库的名称(产生的各类信息将不在.keystore文件中
-keyalg 指定密钥的算法
-validity 指定创建的证书有效期多少天
-keysize 指定密钥长度
-storepass 指定密钥库的密码
-keypass 指定别名条目的密码
-dname 指定证书拥有者信息 例如: "CN=sagely,OU=atr,O=szu,L=sz,ST=gd,C=cn"
-list 显示密钥库中的证书信息 keytool -list -v -keystore sage -storepass ....
-v 显示密钥库中的证书详细信息
-export 将别名指定的证书导出到文件 keytool -export -alias caroot -file caroot.crt
-file 参数指定导出到文件的文件名
-delete 删除密钥库中某条目 keytool -delete -alias sage -keystore sage
-keypasswd 修改密钥库中指定条目口令 keytool -keypasswd -alias sage -keypass .... -new .... -storepass ... -keystore sage
-import 将已签名数字证书导入密钥库 keytool -import -alias sage -keystore sagely -file sagely.crt
导入已签名数字证书用keytool -list -v 以后可以明显发现多了认证链长度,并且把整个CA链全部打印出来。
Keytool 是安全钥匙与证书的管理工具.它管理一个存储了私有钥匙和验证相应公共钥匙的与它们相关联的X.509 证书链的keystore(相当一个数据库).
Keytool 是一个有效的安全钥匙和证书的管理工具. 它能够使用户使用数字签名来管理他们自己的私有/公共钥匙对,管理用来作自我鉴定的相关的证书,管理数据完整性和鉴定服务.它还能使用户在通信时缓存它们的公共钥匙.
一个证书是某一实体(个人,公司等)的数字签名,指出其他实体的公共钥匙(或其他信息)的详细的值.当数据被签名后,这个签名信息被用来检验数据的完整性和真实性.完整性指数据没有被修改和篡改,真实性指数据从任何产生和签名的一方真正的传输到达.
Keytool 把钥匙和证书储存到一个keystore.默任的实现keystore的是一个文件.它用一个密码保护钥匙.
而另外的一个工具jarsigner用keystore中的信息产生或检验Java aRchive(jar文件)中的数字签名.
Keystore有两个不同的入口:
1.钥匙入口:保存了非常敏感的加密的钥匙信息,并且是用一个保护的格式存储以防止未被授权的访问.以这种形式存储的钥匙是秘密钥匙,或是一个对应证书链中公有钥匙的私有钥匙.
2.信任证书入口:包含一个属于其他部分的单一公共钥匙证书.它之所以被称为"信任证书",是因为keystore信任的证书中的公共钥匙真正属于证书所有者的身份识别.
Keystore的别名:
所有的keystore入口(钥匙和信任证书入口)是通过唯一的别名访问.别名是 不区分大小写的.如别名Hugo和hugo指向同一个keystore入口.
可以在加一个入口到keystore的时候使用-genkey参数来产生一个钥匙对(公共钥匙和私有钥匙)时指定别名.也可以用-import参数加一个证书或证书链到信任证书.
如:
keytool -genkey -alias duke -keypass dukekeypasswd
其中duke为别名,dukekeypasswd为duke别名的密码.这行命令的作用是产生一个新的公共/私有钥匙对.
假如你想修改密码,可以用:
keytool -keypasswd -alias duke -keypass dukekeypasswd -new newpass
将旧密码dukekeypasswd改为newpass.
Keystore的产生:
1.当使用-genkey 或-import或-identitydb命令添加数据到一个keystore,而当这个keystore不存在时,产生一个keystore.默认名是.keystore,存放到user-home目录.
2.当用-keystore指定时,将产生指定的keystore.
Keystore的实现:
Keytool 类位于java.security包下,提供一个非常好的接口去取得和修改一个keystore中的信息. 目前有两个命令行:keytool和jarsinger,一个GUI工具Policy 可以实现keystore.由于keystore是公开的,用户可以用它写一些额外的安全应用程序.
Keystore还有一个sun公司提供的內在实现.它把keystore作为一个文件来实现.利用了一个keystore类型(格式)"JKS".它用单独的密码保护每一个私有钥匙.也用可能不同的密码保护整个keystore的完整性.
支持的算法和钥匙大小:
keytool允许用户指定钥匙对和注册密码服务供应者所提供的签名算法.缺省的钥匙对产生算法是"DSA".假如私有钥匙是"DSA"类型,缺省签名算法是"SHA1withDSA",假如私有钥匙是"RSA"类型,缺省算法是"MD5withRSA".
当产生一个DSA钥匙对,钥匙必须在512-1024位之间.对任何算法的缺省钥匙大小是1024位.
证书:
一个证书是一个实体的数字签名,指出其他实体的公共钥匙有明确的值.
1.公共钥匙 :是同一个详细的实体的数字关联,并有意让所有想同这个实体发生信任关系的其他实体知道.公共钥匙用来检验签名;
2.数字签名:假如数据已被签名,并用身份存储在一个实体中,一个签名能够证明这个实体知道这个数据.这个数据用实体私有钥匙签名并递交;
3.身份:知道实体的方法.在一些系统中身份是公共钥匙,其他系统中可以是从一个X.509名字的邮件地址的Unix UID来的任何东西;
4.签名:一个签名用用实体私有钥匙来计算某些加密数据;
5.私有钥匙:是一些数字,每一个私有钥匙只能被特定的拥有该私有钥匙的实体知道.私有和公共钥匙存在所有用公共钥匙加密的系统的钥匙对中.一个公共钥匙加密(如DSA),一个私有钥匙与一个正确的公共钥匙通信.私有钥匙用来计算签名.
6.实体:一个实体可以是一个人,一个组织,一个程序,一台计算机,一个商业,一个银行,或其他你想信任的东西.
Keytool应用实例:
1.产生一个keystore:
keytool -genkey -alias User(keystore的别名) -keyalg RSA -validity 7 -keystore keystore(指定keystore).
运行这个命令,系统提示:
Enter keystore password:yourpassword(输入密码)
What is your first and last name?
[Unknown]: your name(输入你的名字)
What is the name of your organizational unit?
[Unknown]:your organizational(输入你所在组织单位的名字)
What is the name of your organization?
[Unknown]:your organization name (输入你所在组织的名字)
What is the name of your City or Locality?
[Unknown]:your city name(输入所在城市的名字)
What is the name of your State or Province?
[Unknown]:your provice name(输入所在省份名字)
What is the two-letter country code for this unit?
[Unknown]:cn(输入国家名字)
Is CN=your name, OU=your organizaion, O="your organization name",
L=your city name, ST=your province name, C=cn correct?
[no]: yes
2.检查一个keystore:
keytool -list -v -keystore keystore
Enter keystore password:your password(输入密码)
将显示keystore內容如:
Keystore type: jks
Keystore provider: SUN
Your keystore contains 1 entry
Alias name: yourname
Creation date: Dec 20, 2001
Entry type: keyEntry
Certificate chain length: 1
Certificate[1]:
Owner: CN=yourname, OU=your organization, O="your organization name",
L=your city name, ST=your province name, C=CN
Issuer: CN=Duke, OU=Java Software, O="Sun Microsystems, Inc.", L=Palo Alto, ST=CA, C=US
Serial number: 3c22adc1
Valid from: Thu Dec 20 19:34:25 PST 2001 until: Thu Dec 27 19:34:25 PST 2001
Certificate fingerprints:
MD5: F1:5B:9B:A1:F7:16:CF:25:CF:F4:FF:35:3F:4C:9C:F0
SHA1: B2:00:50:DD:B6:CC:35:66:21:45:0F:96:AA:AF:6A:3D:E4:03:7C:74
3.输出keystore到一个文件:testkey:
keytool -export -alias duke -keystore keystore -rfc -file testkey
系统输出:
Enter keystore password:your password(输入密码)
Certificate stored in file < td>
4.输入证书到一个新的truststore:
keytool -import -alias dukecert -file testkey -keystore truststore
Enter keystore password:your new password.(输入truststore新密码)
5.检查truststore:
keytool -list -v -keystore truststore
系统将显示truststore的信息.
现在可以用适当的keystore运行你的应用程序.如:
java -Djavax.net.ssl.keyStore=keystore -Djavax.net.ssl.keyStorePassword=password Server
和: java -Djavax.net.ssl.trustStore=truststore
-Djavax.net.ssl.trustStorePassword=trustword Client
发表评论
-
SSL+socket 详解-概念
2010-12-15 10:32 6931一、 SSL概述 SSL协议采用数字证书及数字 ... -
ssl+socket
2010-12-14 21:30 1958http://sariel.iteye.com/blog/46 ... -
HTTP错误403.9-禁止访问:连接的用户过多
2010-12-14 12:00 2798为什么我的本机上的IIS5.0有时会出现“HTT ... -
Tomcat - SSL操作大全
2010-12-13 16:05 1935简介 Tomcat 服务器是一 ... -
Java keytool工具的作用及使用方法
2010-12-13 14:30 3612Keytool 是安全钥匙与证书的管理工具.它管理一个存储了私 ... -
openssl 创建ssl证书
2010-12-13 11:20 13580http://han-zw.iteye.com/bl ... -
SSL与TLS 区别 以及介绍
2010-12-13 10:37 47130SSL:(Secure Socket Layer,安全套接 ... -
使用 HTTPS 编写客户端程序
2010-12-12 22:35 1837使用 HTTPS 编写客户端程 ... -
https协议及 tomcat https访问设置 默认http也变成https
2010-12-12 21:11 19436HTTPS(全称:Hypertext Tran ... -
tomcat双向加密
2010-12-11 21:59 3213Tomcat配置SSL的双向认证 证书保存在服务器端,用 ... -
ssl+tomcat 配置
2010-12-11 20:09 1864如何使用JDK自带的工具创建密匙库和信任库 WebServi ...
相关推荐
JavaGUI程序是基于Java平台的图形用户界面应用,它允许开发者创建丰富的交互式应用程序。在本项目中,开发者使用了BeautyEye库来设计GUI。BeautyEye是一个开源的Java外观和感觉实现,它提供了美观的界面设计,尤其...
Java学籍管理系统是一款基于Java GUI(图形用户界面)技术开发的应用程序,主要用于高效、便捷地管理学生的学籍信息。这个系统通常包含多个模块,如学生信息管理、成绩管理、课程管理、教师信息管理等,旨在简化学校...
车辆信息管理系统是一款基于Java GUI(图形用户界面)和MySQL数据库技术开发的应用软件,主要用于管理和跟踪车辆的相关信息。这个系统能够帮助用户高效地存储、检索和分析车辆数据,提高工作效率,适用于汽车租赁...
标题中的“第一次使用NetBeans及创建GUI应用程序”指的是在Java编程环境中使用NetBeans IDE来设计和构建图形用户界面(GUI)应用的过程。NetBeans是一款开源的集成开发环境,特别适合初学者和专业开发者进行Java应用...
### Web应用程序部署指南知识点 #### 一、文档概述与历史记录 - **文档版本**:该文档版本为4.1 Support Package 6,发布日期为2015年6月12日。 - **文档历史记录**:文档的第5页提供了关于此文档的历史版本记录,...
Java图形用户界面(GUI,Graphical User Interface)是Java编程中的一个重要组成部分,它允许开发者创建交互式的、视觉吸引人的应用程序。在"GUI.rar_java gui"这个压缩包中,包含了一个名为"GUI.txt"的文件,这很...
1. **Java GUI**:Java GUI(图形用户界面)是应用程序设计中的一个重要组成部分,用于创建用户友好的图形界面。在移动短信平台中,Java GUI可能采用了Swing或JavaFX库来构建窗口、按钮、文本框等组件,使得用户能够...
5.1和5.2节讲解了消息过滤和维护,6.1至6.4节涵盖了执行应用程序、拷贝/打印消息、查找对象和消息转发等功能。7.1至7.5节则涉及定制显示消息的数量、消息到达时的动作、快捷栏、消息窗口和窗口布局的个性化设置。 ...
Java小应用程序,通常被称为Applet,是用Java编程语言编写的一种小型程序,可以在网页上运行。这个特定的项目,"java小应用程序 计算器...通过分析和实现这样的项目,开发者可以深入理解Java语言和GUI应用的开发流程。
4. **配置文件**:如.properties或.xml文件,用于配置应用程序的行为和设置。 5. **构建脚本**:如build.gradle或Maven的pom.xml,用于自动化构建和依赖管理。 6. **文档**:可能包含教程、设计文档或README文件,...
在Java GUI应用中,可能会涉及到网络通信(如用户数据的远程验证)和程序设计的多个方面。 【主要内容】: 1. **NetBeans介绍**:NetBeans是一个开源的Java IDE,支持多种编程语言,包括Java、JavaScript、PHP等。...
Java桌面应用程序通常以JAR(Java Archive)文件的形式发布,但为了方便非开发人员或Windows用户,将JAR转换为可执行的.exe文件是很有必要的。exe4j和Inno Setup是两个常用的工具,用于创建Java桌面应用的Windows...
在MyEclipse中创建GUI应用程序,你需要: 1. 新建Java项目。 2. 添加源文件夹。 3. 创建新的Java类,继承自JFrame或其他GUI组件。 4. 在类中定义main函数,创建并显示GUI。 5. 使用MyEclipse的设计器工具拖放组件,...
【Java编写手机应用程序】 在移动通信领域,Java已经成为开发手机应用程序的重要语言,尤其对于早期的智能手机和平板设备。本文主要探讨如何使用Java来编写手机应用程序,以满足用户对多功能、便携式设备的需求。 ...
Java GUI编程打地鼠小游戏是一款基于Java图形用户界面(GUI)技术开发的娱乐应用程序,它利用了SpringTool作为开发环境。这个项目展示了如何利用Java的Swing或JavaFX库来创建一个互动的游戏体验。让我们深入探讨一下...
总的来说,这个项目涵盖了Java GUI编程、事件处理、算法设计以及人工智能的基础应用,对于学习Java编程和游戏开发的初学者来说,这是一个很好的实践项目。同时,对于想要深入理解人机对战策略和Java图形界面设计的...
Java桌面应用数据传输是将Java应用程序设计为桌面端软件,使得用户可以在本地计算机上运行,进行数据的交互和处理。这种技术主要依赖于Java的JavaFX或者Swing库来构建图形用户界面(GUI),并利用Java的网络通信功能...
10. **打包与部署**:将Java小应用程序打包成`.jar`文件,可以使用Java的`jar`命令行工具。为了让用户能够在浏览器中运行,还需创建HTML页面嵌入`<applet>`标签,并配置正确的类路径和参数。 总的来说,这个Java...
- **Launch4j**:这是一个流行的开源工具,用于将Java应用程序封装为可执行的Windows GUI或控制台应用程序。它不包含Java代码,而是创建一个Windows外壳,启动JRE并运行JAR文件。 - **JSmooth**:另一个开源工具,...
"java使用win32api创建gui窗体"这个主题就涉及到如何在Java程序中集成Win32 API来创建具有特殊需求的用户界面。 Win32 API是微软Windows操作系统提供的底层接口,它允许开发者直接与操作系统交互,执行许多低级别的...