当前位置:  技术问答>java相关

有三个问题,请帮忙给看一下,谢谢!

    来源: 互联网  发布时间:2015-04-18

    本文导语:  一:我下了JBUILDER的试用版,以前装过一次,很好的,后来我重装了系统后(win2000)     再装时就装不上帮助文件了(那样很痛苦的,虽然时e文的,但总比没有好)提示错     误是:“could not load jvm.dll,请重新...

一:我下了JBUILDER的试用版,以前装过一次,很好的,后来我重装了系统后(win2000)
    再装时就装不上帮助文件了(那样很痛苦的,虽然时e文的,但总比没有好)提示错
    误是:“could not load jvm.dll,请重新安装JAVA VM或更改应用程序使用的JAVA
    VM.”  但是我看了一下,jvm.dll毫无疑问的存在,我想着换了一下路径,还是不行
    这是何故?
二:我在书上见到关于policy文件的文章,说是必须将之放在window 的HOME里,这里的
    HOME是不是就是路径里的path?反正我试了一下是不行,那位能帮忙给解释一下?
三:在使用JNI时有什么方法将*.c文件变成*.dll文件?(VC除外)(我想要比较小的工
    具,如:tc什么的,不过tc里好像是没有。)



   先行谢过


|
一、Java中安全策略的概念
----Java应用程序环境的安全策略,详细说明了对于不同的代码所拥有的不同资源的许可,它由一个Policy对象来表达。为了让applet(或者运行在 SecurityManager下的一个应用程序)能够执行受保护的行为,例如读写文件,applet(或 Java应用程序)必须获得那项操作的许可,安全策略文件就是用来实现这些许可。 
----Policy对象可能有多个实体,虽然任何时候只能有一个起作用。当前安装的Policy对象,在程序中可以通过调用getPolicy方法得到,也可以通过调用setPolicy方法改变。Policy对象评估整个策略,返回一个适当的Permissions对象,详细说明哪些代码可以访问哪些资源。 

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

二、Policy文件的格式
----为了能够更好地理解下面的内容,建议在阅读时参照 jdk1.2jrelibsecurityjava.policy文件和jdk1.2jrelibsecurityjava.security文件的内容。 
----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)“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”。 

---- (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/-  目录下的所有文件,包括子目录
-      当前目录下的所有文件,包括子目录
文件系统中的所有文件

----对于java.io.FilePermission,action可以是:read, write, delete和execute。 

----对于java.net.SocketPermission,action可以是:listen, accept,connect,read,write。 

---- (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文件的内容,使用起来相当简单,而且,安全许可的范围控制较精细。 

|
比如:你的机器是在公司的局域里边,这样你就能用几个用户名登录你的机器,在W2000中当用一个用户名登录时会在Documents and Settings目录下产生一个相应的文件夹,这个文件夹就是所谓的HOME目录。

|
问题一
  因为你的机器里边装了几个JDK,且都在当前目录中可以访问,
在运行java.exe不能定位,建议在运行程序是设定PATH指向某一个
JDK的Home

|
showcode@163.com

    
 
 

您可能感兴趣的文章:

  • 急需精通SUPERSITE的兄弟来帮忙完善X-SPACE以下的三个细节!谢谢啦!
  • 关于unix操作系统的三个试题,谁能帮忙解答?
  • 载完rh7.3的三个iso 文件~ 用winios打开后~ 没有发现setup.exe文件~ 大吓帮忙指点一二~
  • 菜鸟第一次安装红帽子7.2的一箩筐问题。每个问题会开个帖子,各放100分!请有安装经验的老鸟们帮忙解决。第三个问题:请教硬盘分区策略
  • 帮忙解释一下三个术语:binding/late binding/virtual method invocation
  • 帮忙看一下这三个服务器的内存使用情况是否正常,要命啊
  • 三个问题,每个33分,高手帮忙~~~(MM)
  • 谢谢大家的支持,有三个三角了,值得庆贺一下吧!:)
  • 请教三个菜鸟的问题,谢谢
  • 问三个问题(急用,谢谢!)
  • 我下了三个ISO的文件,,,是LINUX我该怎么装,,谢谢
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 学不好编程的三个原因
  • 我想取出所有的数据记录,然后一行三个一行三个的显示出来。。。一行够三个了就换行,怎么换到第二行?
  • Spring AOP中Pointcut,dvice 和 Advisor三个概念介绍
  • LINUX中装了三个网卡,三个网卡都是同个IP段,如何让他们不能互相访问?
  • 我在下载debian的时候发现有三个iso文件,有一个包含了businesscard这个单词,请问这三个iso文件个有什么用处啊?
  • 用信号量机制解决实际的三个进程同步问题
  • 虚拟机里linux系统下输入l,k,m三个字母不能正常显示,求解答
  • cut命令输出前三个字段
  • ??三个表的联合比对??
  • JSP常见的三个编译指令page、include、taglib
  • 三个网卡的网关配置问题? 非常急!!!
  • 【在线等待】JDK的三个版本有什么特点和差别?
  • shell如何取一个字符串中最右边的三个字符?
  • 三个vimrc文件有什么区别?
  • linux中的三个问题!!!
  • 三个容易bash脚本,高分求解
  • ls --color[=when] 参数为never always auto,这三个参数分别什么意思。
  • sa_sigaction 如何用第三个参数
  • 关于write函数的第三个参数的传递
  • ubuntu11.10 顶部面板的左端没有应用程序,位置和系统 这三个菜单。怎么启动终端
  • solaris8 x86哪三个iso文件是需要刻的啊??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3