CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
英特尔®游戏设计大赛100美元现金周周送 专题改版:Java Web 专题
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  Java >  J2SE / 基础类

在applet在另一台计算机上的浏览器中运行时不能与在本机运行的java应用程序建立socket通信,为什么??

楼主birdlovesky(飞鸟)2003-11-01 20:53:16 在 Java / J2SE / 基础类 提问

当把嵌有applet的HTML   在与java应用程序同机的浏览器   上运行时   ,两个程序间能建立起socket通信。  
  但是,将HTML移到另一台机器上的浏览器中运行,而与它通信的java应用程序仍在本机上运行时,不能建立socket通信。  
  为什么?? 问题点数:0、回复次数:4Top

1 楼kypfos(不在寻梦)回复于 2003-11-01 22:34:38 得分 0

applet出于安全考虑是不允许访问除applet所在主机之外的主机Top

2 楼duoshanx(合作双赢)回复于 2003-11-01 22:55:18 得分 0

签名方可Top

3 楼birdlovesky(飞鸟)回复于 2003-11-02 10:22:50 得分 0

请问高手怎样对applet签名授权?是不是一定要从Versigh或Thawte获得开发人员证书?  
  自己编辑一个策略文件而不申请证书可不可行?多谢赐教!Top

4 楼haoqingshi(飞翔)回复于 2003-11-02 17:05:52 得分 0

我的项目是使用APPLET制作一个实时消息队列监控程序,由于涉及到了本地资源,对APPLET一定要进行数字签名和认证。我使用的环境是WINDOWS2000,应用服务器是WEBLOGIC6.0,开发环境是JBUILDER4.0。之前我提醒大家一定要注意服务器端和客户端的概念。那些文件应该在服务器端,那些文件应该在客户端。    
  首先在客户端使用JRE1.3.0_01(JAVA运行环境1.3.0.1版本)以取代IE的JVM(JAVA虚拟机),可以到WWW.JAVA.SUN.COM网站上去下载,下载好了先在客户端安装好,安装过程非常简单。    
  在服务器端的调用APPLET的HTML文件中也需要将它包含进来,以便没有事先安装JRE的客户端下载,具体的写法,请接着往下看;    
   
  具体步骤如下:    
   
  服务器端:    
  1.将程序需要用到的各种包文件全部解压(我这儿要用到WEBLOGIC的JMS包使用命令jar   xf   weblogicc.jar),然后使用JDK的打包命令将编译好的监控程序.class和刚才解压的包一起打包到一个包中。(前提我已经将监控程序和解开的包都放在同一个目录下了),都是dos状态下的命令,具体命令见jdk1.3(1.2)的bin目录下,    
  命令如下:    
  jar   cvf   monitor.jar   *.class    
  此命令生成一个名为monitor.jar的包    
  2.为刚才创建的包文件(monitor.jar)创建keystore和keys。其中    
  keystore将用来存放密匙(private   keys)和公共钥匙的认证,alias别名这儿取为monitor。    
  命令如下:    
  keytool   -genkey   -keystore   monitor.keystore   –alias   monitor    
  此命令生成了一个名为monitor.keystore的keystore文件,    
  接着这条命令,系统会问你好多问题,比如你的公司名称,你    
  的地址,你要设定的密码等等,都由自己的随便写。    
  3.使用刚才生成的钥匙来对jar文件进行签名    
  命令如下:    
  jarsigner   -keystore   monitor.keystore   monitor.jar   monitor    
  这个命令将对monitor.jar文件进行签名,不会生成新文件。    
  4.将公共钥匙导入到一个cer文件中,这个cer文件就是要拷贝到客户端的唯一文件   。    
  命令如下:    
  keytool   -export   -keystore   monitor.keystore   -alias   monitor   -file   monitor.cer    
  此条命令将生成monitor.cer认证文件,当然这几步都有可能问你刚    
  才设置的密码。    
  这样就完成了服务器端的设置。这时你就可以将jar文件和keystore文件以及cer文件(我这儿是monitor.jar,monitor.keystore,monitor.cer)拷贝到服务器的目录下了,我用的是weblogic6.0,所以就拷贝到C:\bea\wlserver6.0\config\mydomain\applications\DefaultWebApp_myserver下的自己建的一个目录下了。    
   
  客户端:    
  1.   首先应该安装jre1.3.0_01,然后将服务器端生成的monitor.cer    
  文件拷贝到jre的特定目录下,我这儿是:    
  c:\program   files\javasoft\jre\1.3.0_01\lib\security目录下。    
  2.   将公共钥匙倒入到jre的cacerts(这是jre的默认keystore)    
  命令如下:    
  keytool   -import   -alias   monitor   -file   monitor.cer    
  -keystore   cacerts    
  注意这儿要你输入的是cacerts的密码,应该是changeit,而不    
  是你自己设定的keystore的密码。    
  3.   修改policy策略文件,在dos状态下使用命令   policytool    
  系统会自动弹出一个policytool的对话框,如图4所示,在这里面首先选择file菜单的open项,    
  打开c:\program   files\javasoft\jre\1.3.0_01\lib\security目录下的java.poliy文件,然后在edit菜单中选择Change   keystore   ,在对话框中new   keystore   url:中输入    
  file:/c:/program   files   /javasoft/jre/1.3.0_01/lib/security/cacerts,    
  这儿要注意反斜杠,在new   keystore   type   中输入JKS,这是cacerts的固定格式,然后单击Add   Policy   Entry,在出现的对话框中CodeBase中输入:    
  http://URL:7001/*    
  其中的URL是服务器的IP地址,7001是我的weblogic的端口,如果你是在别的应用服务器上比如说是apache,那端口号就可以省略掉。    
  在SignedBy中输入(别名alias):这儿是Monitor    
  然后单击add   peimission按钮,在出现的对话框中permission中选择你想给这个applet的权限,这儿具体有许多权限,读者可以自己找资料看看。我这儿就选用allpeimission,右边的signedBy中输入别名:monitor    
  最后保存,在file菜单的save项。    
  当然你可以看见我已经对多个包实现了签名认证。    
   
   
   
  这样客户端的设置就完成了。在客户端用ie运行该applet程序时,会询问你是不是对该签名授权,选择授权后,包会自动从服务器下载到本地计算机,而且ie会自动启动jre,在右下栏中可以看见,相当于ie的java控制台。    
   
  4.调用applet的html文件    
  大家都知道由于java2的安全性,对applet的正常调用的html文件已经不能再使用了,而改为ActiveX类型的调用。具体的又分ie和nescape的不同写法,这一些在sun网上都能找到现成的教程。我就不多说了,只是将我的这个小程序为ie写的的html给大家看看。    
   
   
   
   
   
  消息中心实时监控平台  
   
   
  --------------------------------------------------------------------------------  
   
   
   
   
   
   
  其中我要强调一点,因为applet每一次的改动都需要重新打包签名,手续非常繁琐,所以在具体的实现中要将一些会变化参数放到html文件中来,传到applet中去,这一点网上文章好多,自己去看吧。    
  另外一个就是有朋友问我,那这样不是太麻烦了,每一个客户端都要进行复杂的dos命令操作,我只能说一目前我的水平只能将一个已经做好的客户端文件cer文件和java.policy以及cacerts文件直接拷贝到客户端,当然这也有缺陷,如果别人的计算机已经有了认证,就会丢失。就这些问题我们可以一起探讨。    
  另外还有一点优化,就是在打包的时候,我这儿只讲了把所有要用的涉及到安全性的包和源程序到要打到一个包中。这样如果包非常大的话,会非常影响下载的速度,如果可以使用本地计算机的包就好了,这一点jre也做到了,具体的要到控制面板的jre控制台上去设置。这个就留着读者自己去摸索吧。    
  Top

相关问题

  • java applet本机能执行,上传以后不能运行,为什么?
  • 在applet端写文件的程序,可以在本机器上运行成功,却不能在别的机器上运行,为什么??
  • 怎么运行applet ??
  • 本机是否真的不适合ulead cool 3D的运行?
  • 没办法在本机上运行cgi!!!(小肯兄救命!!!)
  • 怎样用运行方式查本机的IP地址??
  • 如何在VB中获取本机正在运行的程序
  • 网络运行的程序,怎样得到本机名?
  • 本机运行的ASP做的BBS出现以下错误
  • 本机运行的ASP做的BBS出现错误!

关键词

  • 文件
  • java
  • 服务器
  • 客户
  • 应用程序
  • html
  • 通信
  • 计算机
  • 浏览器
  • 认证

得分解答快速导航

  • 帖主:birdlovesky

相关链接

  • CSDN Java频道
  • Java类图书
  • Java类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
世纪乐知(北京)网络技术有限公司 版权所有, 京 ICP 证 020026 号
北京创新乐知广告有限公司 提供技术支持
Copyright © 2000-2007, CSDN.NET, All Rights Reserved
GongshangLogo