java 使用适当的签名_关于数字签名和policy文件设置!

目前做一项目,jbuilder4+oracle+windows2000(linux),打算用applet+servlet

做成分布式b/s结构,

其中有两个关键技术难点:

1:与word,excel等程序集成。

用jintegra解决(多谢路人甲等人的指点)

2:applet存取客户机(browser)上的本地文件(主要是office文档),并启动客户机上的

相应office程序。

这个问题涉及到java applet程序的安全限制,据说可以通过数字签名或policy文件设置,但目前还没有找到能够行得通的方法和资料。

情况紧急,望各位指点,多谢!

|

---- 众所周知,Java语言具有完善的安全框架,从编程语言,编译器、解释程序到Java虚拟机,都能确保Java系统不被无效的代码或敌对的编译器暗中破坏,基本上,它们保证了Java代码按预定的规则运作。但是,当我们需要逾越这些限制时,例如,读写文件,监听和读写Socket,退出Java系统等,就必须使用数字签名或安全策略文件(*.Policy)。

---- 在企业内部网中,本文提出了使用安全策略文件来设置java程序权限的一种简单的方法。由于企业内部网中各台计算机的位置、用途和安全性明确,更适于使用安全策略文件来设置java的权限,软件的安装、设置、升级和迁移都非常的方便,并且,还可以和数字签名配合使用,更重要的是,可以细分每个java程序的权限,使用起来灵活方便。

一. Java中安全策略的概念

---- Java应用程序环境的安全策略,详细说明了对于不同的代码所拥有的不同资源的许可,它由一个Policy对象来表达。为了让applet(或者运行在SecurityManager下的一个应用程序)能够执行受保护的行为,例如读写文件,applet(或Java应用程序)必须获得那项操作的许可,安全策略文件就是用来实现这些许可。

---- Policy对象可能有多个实体,虽然任何时候只能有一个起作用。当前安装的Policy对象,在程序中可以通过调用getPolicy方法得到,也可以通过调用setPolicy方法改变。Policy对象评估整个策略,返回一个适当的Permissions对象,详细说明那些代码可以访问那些资源。

---- 策略文件可以储存在无格式的ASCII文件,或Policy类的二进制文件,或数据库中。本文仅讨论无格式的ASCII文件的形式。

二. Policy文件的格式

---- 为了能够更好地理解下面的内容,建议在阅读时参照jdk1.2jrelibsecurityjava.policy文件和jdk1.2jrelibsecurityjava.security文件的内容。

---- 1. Policy文件的语法格式与说明

---- 一个Policy文件实质上是一个记录列表,它可能含有一个“keystore”记录,以及含有零个或多个“grant”记录。其格式如下:

keystore "some_keystore_url",

"keystore_type";

grant [SignedBy "signer_names"]

[, CodeBase "URL"] {

Permission permission_class_name

[ "target_name" ]

[, "action"] [, SignedBy "signer_names"];

Permission ...

};

---- 1.1"keystore"记录

---- 一个keystore是一个私有密钥(private keys)数据库和相应的数字签名,例如X.509证书。Policy文件中可能只有一条keystore记录(也可能不含有该记录),它可以出现在文件中grant记录以外的任何地方。Policy配置文件中指定的keystores用于寻找grant记录中指定的、签名者的公共密钥(public keys),如果任何grant记录指定签名者(signer_names),那么,keystore记录必须出现在policy配置文件中。

---- "some_keystore_url"是指keystore的URL位置,"keystore_type"是指keystore的类型。第二个选项是可选项,如果没有指定,该类型则假定由安全属性文件(java.security)中的"keystore.type"属性来确定。keystore类型定义了keystore信息的存储和数据格式,用于保护keystore中的私有密钥和keystore完整性的算法。Sun Microsystems支持的缺省类型为“JKS”。

---- 1.2"grant"记录

---- 在Policy文件中的每一个grant记录含有一个CodeSource(一个指定的代码)及其permission(许可)。

---- Policy文件中的每一条grant记录遵循下面的格式,以保留字“grant”开头,表示一条新的记录的开始,“Permission”是另一个保留字,在记录中用来标记一个新的许可的开始。每一个grant记录授予一个指定的代码(CodeBase)一套许可(Permissions)。

---- permission_class_name必须是一个合格并存在的类名,例如java.io.FilePermission,不能使用缩写(例如,FilePermission)。

---- target_name用来指定目标类的位置,action用于指定目标类拥有的权限。

---- target_name可以直接指定类名(可以是绝对或相对路径),目录名,也可以是下面的通配符:

directory/* 目录下的所有文件

*当前目录的所有文件

directory/-目录下的所有文件,包括子目录

- 当前目录下的所有文件,包括子目录

《ALL FILES》文件系统中的所有文件

对于java.io.FilePermission,action可以是:

read, write, delete和execute。

对于java.net.SocketPermission,action可以是:

listen,accept,connect,read,write。

---- 1.3 Policy文件中的属性扩展(Property Expansion)

---- 属性扩展与shell中使用的变量扩展类似,它的格式为:

"${some.property}"

实际使用的例子为:

permission java.io.FilePermission

"${user.home}", "read";

"${user.home}"的值为"d:Project",

因此,下面的语句和上面的语句是一样的:

permission java.io.FilePermission "

d:Project ", "read";

三. 实例

---- 当初始化Policy时,首先装载系统Policy,然后再增加用户Policy,如果两者都不存在,则使用缺省的Policy,即原始的沙箱模型。

---- 系统Policy文件的缺省位置为:

{java.home}/lib/security/java.policy (Solaris)

{java.home}libsecurityjava.policy (Windows)

用户Policy文件的缺省位置为:

{user.home}/.java.policy (Solaris)

{user.home}.java.policy (Windows)

---- 其实,在实际使用中,我们可能不会象上面介绍的那么复杂,特别是在不使用数字签名时。这时,我们完全可以借鉴JDK 1.2提供给我们的现成的jdk1.2jrelibsecurityjava.policy文件,根据我们的需要作相应的修改,本文就针对不使用数字签名情况详细说明安全策略文件的用法。

---- 下面,是一个完整的在Windows 95/98/NT下使用的.java.policy文件。在文件中,分别使用注释的形式说明了每个“permission”记录的用途。

// For LanServerTalk.java and LanClientTalk.java

grant {

//对系统和用户目录“读”的权限

permission java.util.PropertyPermission

"user.dir", "read";

permission java.util.PropertyPermission

"user.home", "read";

permission java.util.PropertyPermission

"java.home", "read";

permission java.util.PropertyPermission

"java.class.path", "read";

permission java.util.PropertyPermission

"user.name", "read";

//对线程和线程组的操作权限

permission java.lang.RuntimePermission

"modifyThread";

permission java.lang.RuntimePermission

"modifyThreadGroup";

//操作Socket端口的各种权限

permission java.net.SocketPermission

"-", "listen";

permission java.net.SocketPermission

"-", "accept";

permission java.net.SocketPermission

"-", "connect";

permission java.net.SocketPermission "-", "read";

permission java.net.SocketPermission "-", "write";

//读写文件的权限

permission java.io.FilePermission "-", "read";

permission java.io.FilePermission "-", "write";

//退出系统的权限,例如System.exit(0)

permission java.lang.RuntimePermission "exitVM";

};

四. java.policy文件的使用

---- 对于windows 95/98/NT,使用.java.policy文件的方法主要有下面两种。

---- 1. 使用缺省目录

---- 我们可以简单地将编辑好的.java.policy文件拷贝到windows 95/98/NT的HOME目录,这时,所有的applet(或Java应用程序)可能都拥有某些相同的权限,使用起来简单,但不灵活(例如:对于java.io.FilePermission ,其目标类的target_name必须使用绝对路径),如果不是在企业内部网中使用,还可能存在一定安全隐患。

---- 2. 在命令行中指定

---- 在命令行,如果我们希望传递一个Policy文件给appletviewer,还可以使用"-J-Djava.security.policy"参数来指定policy的位置:

appletviewer -J-Djava.security.

policy=pURL myApplet

---- pURL为Policy文件的位置。下面,是一个实际的例子,以当前目录的.java.policy文件所指定的安全策略运行当前目录的LanServerTalk.html(文件中装载并运行LanServerTalk.java):

appletviewer -J-Djava.security.policy

=.java.policy LanServerTalk.html

---- 这种方法使用灵活,特别是作为一个软件包在企业内部网中发布时,安装、设置和迁移软件,基本无须修改Policy文件的内容,使用起来相当简单,而且,安全许可的范围控制较精细。

|

要用到证书之类的。前几天lmy2000将到这个问题。去找找吧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/502583.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql not in优化_实践中如何优化MySQL(收藏)

SQL语句的优化:1、尽量避免使用子查询3、用IN来替换OR4、LIKE前缀%号、双百分号、_下划线查询非索引列或*无法使用到索引,如果查询的是索引列则可以5、读取适当的记录LIMIT M,N,而不要读多余的记录6、避免数据类型不一致7、分组统计可以禁止排…

java 鼠标精灵_纯Java实现跨平台鼠标键盘模拟、找图找色,Java版按键精灵

由原本的Java使用JNI调用dll实现模拟辅助操作,升级到纯Java来实现,最新: https://github.com/xnx3/xnx31.[代码][Java]代码/*** 鼠标、键盘、延迟等基本操作*/public static void simple(){Robot robot new Robot();robot.delay(1000); //延…

o2oa二次开发比开发难吗_6年经验大牛,带你一起打开 Revit 二次开发的新世界大门...

​知乎视频​www.zhihu.com你好,这里是BIMBOX。一线的BIM工作者使用最多的软件是Revit,它功能强大,涵盖建筑、结构、MEP等专业,也正因为涵盖专业太多,它显得有点繁琐和笨拙,不仅约束了创造力,有…

java的迭代器类中有哪些类_java中的集合类 以及 迭代器

/*java中的集合类 实现了 Connection接口ArrayList这个集合类 java.util.*这个包的类toArray()方法可以返回一个 Object类型的对象数组我们部队 ArratList进行泛型规范那么就会警告 但是还是可以运行的这是因为JDK1.5中引进了泛型,但是你的ArrayList却没有采用&a…

python计算圆柱体体积代码_继承实现圆柱体面积体积的计算

一.编写一个圆类Circle,该类拥有:①一个成员变量Radius// 存放圆的半径;私有,浮点型②两个构造方法Circle( ) // 将半径设为0Circle(doubler ) //创建Circle对象时将半径初始化为r③三个成员方…

python spider怎么用_python爬虫入门(七)Scrapy框架之Spider类

Spider类Spider类定义了如何爬取某个(或某些)网站。包括了爬取的动作(例如:是否跟进链接)以及如何从网页的内容中提取结构化数据(爬取item)。换句话说,Spider就是您定义爬取的动作及分析某个网页(或者是有些网页)的地方。class scrapy.Spider是最基本的类&#xff0…

mysql5.7 存储二进制_mysql5.7二进制部署

1.解压及创建目录[roothadoop39 local]# tar xzvf mysql-5.7.11-linux-glibc2.5-x86_64.tar.gz[roothadoop39 local]# mv mysql-5.7.11-linux-glibc2.5-x86_64 mysql[roothadoop39 local]# mkdir mysql/arch mysql/data mysql/tmp2.创建my.cnf(见文件)[roothadoop39 local]# vi…

ctypes python3.7_装新的python3.7时ModuleNotFoundError: No module named '_ctypes'

在编译安装新的python3.7的时候报错 ModuleNotFoundError: No module named _ctypes,其实是缺少了一个新需要的开发包libffi-devel,安装后即可yum install libffi-devel -y (包在base)最终显示Installing collected packages: setuptools, pipSuccessful…

python中的str方法和repr方法_Python中 的 __str__ 方法和 __repr__ 方法的区别有哪些

Python中 的 __str__ 方法和 __repr__ 方法的区别有哪些发布时间:2020-11-05 17:11:48来源:亿速云阅读:95作者:Leah本篇文章给大家分享的是有关Python中 的 __str__ 方法和 __repr__ 方法的区别有哪些,小编觉得挺实用的…

requestbody前端怎么传_学习前端开发前的基础知识了解「V1001」

一、什么是http协议?什么是协议,就是一群人协商好了,统一认知的规则。【例】你,我,他,还有她他他,大家一致认定结婚的时候都要给份子钱,这种大家认同的就是协议。http协议,就规定了…

postmapping注解参数说明_从零搭建后端框架:优雅的参数校验Validator

前两天项目群里发生了关于参数校验的问题讨论,很多开发团队没有对这些做硬性规范时,还是有很多童鞋本着“不多事”的原则,产品文档里没有特别说明就不写。对于2B的产品经理来说,因为一次新迭代,可能回涉及到N多的页面&…

java竖线分割_Java String类的Split以竖线作为分隔符

版权声明:本文为博主原创文章,转载请写明出处。https://blog.csdn.net/wo541075754/article/details/50668160问题Java中String类的Split方法,当用“|”进行分割时,发现并不能达到预期的效果。比如:分割字符串“ABC|DE…

ups计算软件_浅析UPS与蓄电池与逆变器的区别

早期的电信机房中,通常采用将220V交流电源经过整流,为48V电池组充电,由电池组直接给程控交换机供电。随着计算机网络和通信网络在电信机房的应用,需要为其提供高质量的220V的交流电源。由于有现有的48V电池组,所以通常…

java字符转为数字_Java 判断字符串能否转化为数字的三种方法

linux shell 常用指令1. man 对你熟悉或不熟悉的命令提供帮助解释 eg:man ls 就可以查看ls相关的用法 注:按q键或者ctrlc退出,在linux下可以使用ctrlc终止当前程序运行. 2. ls 查看目 ...在uwp中复活常用的vb库函数这个博文是纯原创的,转载一定要说明作者是 Nukepayload2!! 在.…

python调用gpu进行运算_tensorflow指定CPU与GPU运算的方法实现

1.指定GPU运算如果安装的是GPU版本,在运行的过程中TensorFlow能够自动检测。如果检测到GPU,TensorFlow会尽可能的利用找到的第一个GPU来执行操作。如果机器上有超过一个可用的GPU,除了第一个之外的其他的GPU默认是不参与计算的。为了让Tensor…

java和网易我的世界有什么区别_网易我的世界手机版对比正版JAVA版我的世界有什么区别?...

你说的这部分都属于游戏内部机制问题首先网易手机版实质上就是基岩版,还是更新贼慢的基岩版(笑)。所以题主完全可以去minecraft wiki查找相关资料然后我说一下我知道的一些主要差异吧刷怪效率吧基岩版明显不如java版,所以通用的黑暗刷怪塔在基岩版是不怎…

python jieba词频统计英文文本_python实战,中文自然语言处理,应用jieba库来统计文本词频...

模块介绍安装:pip install jieba 即可jieba库,主要用于中文文本内容的分词,它有3种分词方法:1. 精确模式, 试图将句子最精确地切开,适合文本分析:2. 全模式,把句子中所有的可以成词的词语都扫描…

java修改已创建程序界面_Java应用程序的Web用户界面

应用服务器。您认为Tomcat在运行时占用空间、学习量或…?我倾向于选择与一个IDE有良好集成的东西。所以EclipseTomcat或者ApacheGeronimo,可能在里面WebSphere Community Edition伪装可以完成这项工作。从我所看到的情况来看,这些足以满足您的需求,而且学习曲线实际上是可以管…

python+selenium获取cookie session_selenium获取cookie及设置cookie

获取cookie:在打开的页面使用self.driver.get_cookies()返回下面数据:[{domain: .linkedin.com,expiry: 1553,httpOnly: False,name: liap,path: /,secure: False,value: true},{domain: .linkedin.com,expiry: 154613,httpOnly: False,name: lidc,path:…

js url解码gbk_JS中对URL进行转码与解码

1. escape 和 unescapeescape()不能直接用于URL编码,它的真正作用是返回一个字符的Unicode编码值。采用unicode字符集对指定的字符串除0-255以外进行编码。所有的空格符、标点符号、特殊字符以及更多有联系非ASCII字符都将被转化成%xx格式的字符编码(xx等于该字符在…