客户端自动下载thin驱动,且无需配置而实现Applet访问Oracle ?(50分)

  • 主题发起人 主题发起人 郭守平
  • 开始时间 开始时间

郭守平

Unregistered / Unconfirmed
GUEST, unregistred user!
能否实现:
客户端自动下载thin驱动,且无需配置而实现Applet访问Oracle ?
我的服务器端:oracle8.0.5.0+Oracle Application Server 4.0.8.1a(利用其Http监听)
开发模式:Java Applet(仅利用Java核心包java.sql.*;.....)
目前情况:当访问含Applet的 Html页时,可以看到Applet,但当连接Oracle时
提示:
Loading JDBC driver oracle.jdbc.driver.OracleDriver
Connecting to jdbc:oracle:thin:scott/tiger@DB:1521:ora7
No suitable driver <<<<------------------扑捉到错误(没有找到驱动)
已经尝试的方法:
1。archive法:(classes111.jar为内涵驱动和Applet的archive)
<APPLET CODE = "gsp.Client" CODEBASE = "." archive="classes111.jar" WIDTH = 400 HEIGHT = 400 ALIGN = middle NAME = "TestApplet" >
</APPLET>
2。在同一目录下有:
Html,Applet,oracle(我把它解压开了)
。。。。。。。。
 
你试试jbuilder的打包发布功能。
 
我试过,但可能是由于使用不当,还是不成功。
我发现一篇文章:()
我最想知道的地方说的不详细!
就是它的第一步:"前提我已经将监控程序和解开的包都放在同一个目录下了"
那解开的包还有很多不同目录下的包,难道把其中所有.class都考到统一目录下〉〉〉???


:::::::::::::::::::::::::::::::::
体步骤如下:
服务器端:
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中,才可以,:郭守平的方法是对applet的数字签名,
而这个applet又没有访问本地资源,无所谓打包。
 
后退
顶部