当前位置:首页 > 全部子站 > IT > 思科认证

企业内部网中使用Policy文件来设置Java的安全策略

来源:长理培训发布时间:2017-12-23 16:11:24

 百度广告

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

  一. Java中安全策略的概念

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


  二. Policy文件的格式

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


"keystore_type";
grant [SignedBy "signer_names"] 
Permission permission_class_name 
[, "action"] [, SignedBy "signer_names"];
};









*当前目录的所有文件
- 当前目录下的所有文件,包括子目录
对于java.io.FilePermission,action可以是:
对于java.net.SocketPermission,action可以是:
---- 1.3 Policy文件中的属性扩展(Property Expansion) 
---- 属性扩展与shell中使用的变量扩展类似,它的格式为: 
"${some.property}"
permission java.io.FilePermission 
"${user.home}"的值为"d:"Project",
permission java.io.FilePermission "
  三. 实例

  ---- 当初始化Policy时,首先装载系统Policy,然后再增加用户Policy,如果两者都不存在,则使用缺省的Policy,即原始的沙箱模型。 
---- 系统Policy文件的缺省位置为: 
{java.home}/lib/security/java.policy (Solaris)
用户Policy文件的缺省位置为:
{user.home}".java.policy (Windows)



//对系统和用户目录"读"的权限
"user.dir", "read";
"user.home", "read";
"java.home", "read";
"java.class.path", "read";
"user.name", "read"; 
//对线程和线程组的操作权限
"modifyThread";
"modifyThreadGroup";
//操作Socket端口的各种权限
"-", "listen";
"-", "accept";
"-", "connect";
permission java.net.SocketPermission "-", "write";
//读写文件的权限
permission java.io.FilePermission "-", "write";
//退出系统的权限,例如System.exit(0)
};
---- 对于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.
---- pURL为Policy文件的位置。下面,是一个实际的例子,以当前目录的.java.policy文件所指定的安全策略运行当前目录的LanServerTalk.html(文件中装载并运行LanServerTalk.java): 
appletviewer -J-Djava.security.policy
---- 这种方法使用灵活,特别是作为一个软件包在企业内部网中发布时,安装、设置和迁移软件,基本无须修改Policy文件的内容,使用起来相当简单,而且,安全许可的范围控制较精细。

责编:罗莉

发表评论(共0条评论)
请自觉遵守互联网相关政策法规,评论内容只代表网友观点,发表审核后显示!

国家电网校园招聘考试直播课程通关班

  • 讲师:刘萍萍 / 谢楠
  • 课时:160h
  • 价格 4580

特色双名师解密新课程高频考点,送国家电网教材讲义,助力一次通关

配套通关班送国网在线题库一套

课程专业名称
讲师
课时
查看课程

国家电网招聘考试录播视频课程

  • 讲师:崔莹莹 / 刘萍萍
  • 课时:180h
  • 价格 3580

特色解密新课程高频考点,免费学习,助力一次通关

配套全套国网视频课程免费学习

课程专业名称
讲师
课时
查看课程
在线题库
面授课程更多>>
图书商城更多>>
在线报名
  • 报考专业:
    *(必填)
  • 姓名:
    *(必填)
  • 手机号码:
    *(必填)
返回顶部