`
junli0411
  • 浏览: 141940 次
  • 来自: ...
社区版块
存档分类
最新评论

jsp页面如何调用本机的应用程序?例如c:/netterm.exe?

阅读更多

对不起,我的本意是这样:客户机执行客户机上的程序。Runtime.getRuntime().exec("c:/netterm.exe");写在jsp中在客户端执行,只能启动服务器上的netterm.exe 。
而我只想执行客户端上的netterm.exe.

如果是控制面板程序中有的程序,可用
<input type=button onclick="exec('程序.EXE')" value="调用程序">
如果不是,把路径写清楚就可以啦
例如exec('%JAVA_HOME%\\bin\\javac.bat’)


我把你的Runtime。。代码做成applet.在服务器端数字签名,客户端什么都没做。
这样可以在客户端调用扫雷、笔记本程序。但是调用media player,就完全没有反应了。
我用appletviewer在服务器端跳时这个applet,发现有个异常:java.security.AccessControlException: access denied (java.io.FilePermission <<AL
L FILES>> execute)。
可能是因为我没有修改客户端的策略文件吧,我不太清楚如何搞定。
解决这个问题各位有什么高见?

 

使用Policy来设置Java的安全策略 

--------------------------------------------------------------------------------

源作者:杨绍方 人气:1723 
 


众所周知,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是一个私有密钥(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}\lib\security\java.policy (Windows)
用户Policy文件的缺省位置为:
{user.home}/.java.policy (Solaris)
{user.home}\.java.policy (Windows)
  其实,在实际使用中,我们可能不会象上面介绍的那么复杂,特别是在不使用数字签名时。这时,我们完全可以借鉴JDK 1.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文件拷贝到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文件的内容,使用起来相当简单,而且,安全许可的范围控制较精细。

 

分享到:
评论

相关推荐

    netterm.exe

    好用的cisco模拟器,比Packet trace的命令要全

    netterm_ssh_linux连接工具

    netterm 连接工具 NetTerm is a general purpose communications program designed to work with bulletin boards, local area networks, and the Internet network. Terminal emulation includes VT-52, VT-100, ...

    netterm安装程序.rar

    1. 下载:首先,你需要下载NetTerm的安装程序,这通常是一个RAR格式的压缩包,如"NetTerm安装程序.rar"。RAR是一种常见的压缩文件格式,用于减小文件大小以便于传输和存储。 2. 解压:使用解压缩软件(如WinRAR或7-...

    NetTerm.rar

    标题“NetTerm.rar”指的是一个压缩包文件,其中包含了一个名为“NetTerm”的终端仿真程序。这个程序是绿色版的,意味着它无需安装即可使用,且压缩包经过检测,确认无病毒,用户可以安全地下载和运行。 终端仿真...

    NetTerm v5.4.0.2

    包含有一个FTP服务器,有对IP地址进行分辨且能监控网址的功能,它支持从Unix主机的全透明打印,还含一个Unix页面文件,你可以通过透射功能将该页面上传加载至主机,然后送到你的计算机中,假如你是程序员,你可在 本 ...

    NetTerm-v5.4.0.5

    1. **netterm325405.exe**:这是一个可执行文件,很可能是NetTerm-v5.4.0.5的安装程序。用户可以通过运行这个文件来安装NetTerm软件,通常安装过程中会提示用户选择安装路径、组件以及是否创建桌面快捷方式等。 2. ...

    netterm

    6. **打印功能**:`nt3242ei-终端打印版.exe`可能是NetTerm的一个特定版本,强调了终端打印功能,这在需要将远程会话内容物理输出的情况下非常有用,例如,进行审计记录或者提供纸质备份。 在实际应用中,NetTerm...

    netterm3.4.2

    在提供的压缩包文件中,有两个关键文件:nt3242c.exe是netterm3.4.2的安装程序,用户可以通过运行这个文件在Windows系统上安装软件;而license_netterm.txt则可能包含软件的授权信息或使用条款,用户在安装和使用前...

    NetTerm5.4.rar

    "Progress"标签可能指的是两个方面:一方面,NetTerm可能使用了Progress公司的技术,如Progress 4GL编程语言,这是一种用于开发数据库应用程序的语言,以其高效和跨平台特性著称。另一方面,"Progress"也可能是指QAD...

    netterm 4.3.0

    7. **nt32430.exe**:这个文件名表明它是`netterm 4.3.0`的32位Windows版本安装程序。用户下载后,可以通过运行此文件来安装或升级`netterm`软件。32位版本适用于那些仍运行32位操作系统的用户。 综上所述,`...

    NetTerm_5.2.0.2

    在实际应用中,NetTerm广泛用于系统管理员的日常运维工作,例如远程诊断和修复问题、监控系统状态、更新和配置软件等。此外,对于开发人员来说,它也是调试代码和测试环境的理想工具。无论是在企业数据中心还是个人...

    NetTerm工具

    NetTerm是一款专为Linux系统设计的远程连接工具,它提供了用户友好的图形界面,使得非技术背景的用户也能轻松操作Linux服务器。这款工具的核心功能是通过终端模拟器提供SSH(Secure Shell)连接,确保数据传输的安全...

    netterm v4.2.e.4.rar

    这个软件的核心是"Netterm",一个针对Unix系统的客户端应用程序。 Netterm是一款历史悠久的终端仿真器,最初在1980年代末由Michael Elkins开发,用于在个人电脑上模拟多种类型的终端,如DEC VT系列、IBM 3270等。它...

    常用的工具NetTerm

    NetTerm是一款广泛应用于IT行业的远程终端模拟软件,它允许用户通过图形化界面连接到不同的远程服务器,进行命令行操作。这个软件尤其适用于网络管理员、系统管理员以及开发人员,他们需要频繁地在不同操作系统环境...

    NetTerm 4.2.e.4 (无需注册!)

    NetTerm 4.2.e.4 (已破解,无需注册!)

    NetTerm 4.2.7 纯绿色版

    NetTerm 4.2.7 纯绿色版是一款经典的网络终端模拟软件,适用于Windows操作系统。这个版本是经过特别优化的,确保用户可以无需安装、不写入系统目录即可使用,减轻了对系统资源的影响,同时也方便用户随身携带和在多...

    netterm5.4.2.0

    由InterSoft, International这家公司所开发的共享软件

    Solaris10的补丁安装

    3.输入命令 `# ./setup-standard.sh`,开始安装补丁。 4.在安装过程中,系统将询问一些问题,例如: * Sun keyboard Power button to be disabled? [y/n]: y * Are the buttons & dials to be disabled? [y/n]: y *...

    NetTerm远程工具

    NetTerm便是这一技术的具体应用,它支持多种协议,如Telnet、SSH(Secure Shell)、RDP(Remote Desktop Protocol)等,这些协议在确保数据安全传输的同时,提供了稳定可靠的远程连接。 **NetTerm的主要功能:** 1...

Global site tag (gtag.js) - Google Analytics