Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 443|回复: 0

关于java.security.AccessControlException: access denied 的解决方法

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-6-27 22:06:09 | 显示全部楼层 |阅读模式

    今天调试了您的JDBCUpdateApplet程序.您说在直接用ie打开RunApplet.html文件.会在java控制台报java.security.AccessControlException: access denied
    (java.lang.RuntimePermission accessClassInPackage.sun.jdbc.odbc)错误.我这里也出现了这个错误提示!根据网上搜索的有关问题的分析.这是因为applet在没有被允许的情况下去获取系统资源.同时,错误提示需要一个RuntimePermission,它将使applet去获得sun.jdbc.odbc 包.所以可以在您系统的java运行时包修改一个关于安全的一文件.具体做法是:找到您的ie浏览器使用的jre包,我家的是:D:\Program Files\Java\jre1.6.0\lib\security,在这个包下面有个java.policy文件,打开编辑它:在grant里增加2个语句:permission java.lang.RuntimePermission "accessClassInPackage.sun.jdbc.odbc";
    permission java.util.PropertyPermission "file.encoding", "read"; 再关闭ie,重新运行就可以解决这个问题.我在家里的机子中,增加以后就没有在出现上面的错误信息了. 增加第二个语句是因为让applet能读一些二进制文件.不然可能会出现java.security.AccessControlException:
    access denied (java.lang.RuntimePermission
    file.encoding read)
    错误. 解决的方案来自于网上的讨论:http://java.sun.com/developer/onlineTraining/Programming/BasicJava1/dba.htmlhttp://www.javaworld.com.tw/jute/post/view?bid=29&id=71700&tpg=1&ppg=1&sty=1&age=0

    这两个地址是关于这个问题的讨论和分析.


    众所周知,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.2\jre\lib\security\java.policy文件和\jdk1.2\jre\lib\security\java.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是一个私有密钥(privatekeys)数据库和相应的数字签名,例如X.509证书。Policy文件中可能只有一条keystore记录(也可能不含有该记录),它可以出现在文件中grant记录以外的任何地方。Policy配置文件中指定的keystores用于寻找grant记录中指定的、签名者的公共密钥(publickeys),如果任何grant记录指定签名者(signer_names),那么,keystore记录必须出现在policy配置文件中。
      "some_keystore_url"是指keystore的URL位置,"keystore_type"是指keystore的类型。第二个选项是可选项,如果没有指定,该类型则假定由安全属性文件(java.security)中的"keystore.type"属性来确定。keystore类型定义了keystore信息的存储和数据格式,用于保护keystore中的私有密钥和keystore完整性的算法。SunMicrosystems支持的缺省类型为“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}\lib\security\java.policy (Windows)
    用户Policy文件的缺省位置为:
    {user.home}/.java.policy (Solaris)
    {user.home}\.java.policy (Windows)
      其实,在实际使用中,我们可能不会象上面介绍的那么复杂,特别是在不使用数字签名时。这时,我们完全可以借鉴JDK1.2提供给我们的现成的\jdk1.2\jre\lib\security\java.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文件拷贝到windows95/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文件的内容,使用起来相当简单,而且,安全许可的范围控制较精细

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-11 19:26 , Processed in 0.061646 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表