网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.JGraph开发经验谈.
.课程介绍(9):SL-310 超越CGI开发.
.Tomcat 配置技巧精华详解分析.
.针对hibernate,jdbc,sql的思考.
.上海某全球五百强面试题(嵌入式.
.Java路径问题最终解决方案.
.使用Java Web Services Develope.
.利用JBuilder2005开发Web应用程序.
.J2ME中使用Socket开发联网程序.
.DeleteFolder 方法.
.Hibernate3发布beta版本 支持EJB.
.“浅薄”绝不该是中国程序员的性.
.把JBoss缓存用作POJO缓存的实战演.
.ActionForm的生命周期浅探.
.使用SQLMaps 进行对象关系映射.
.浅谈将子类对象赋值给父类对象.
.Spring框架快速入门之简介.
.Javascript实例教程(20) OLE Aut.
.在Java中轻松实现界面跳转.
.剖析.Net下的数据访问层技术(1).

技术进修:JDBC从入门到精通专题讲座三

发表日期:2008-1-5



  5. 安全性考虑
  
  作为网络上的语言Java必须十分注安全性的考虑。基于上面的讨论,JDBC的两种主要使用场合里面,我们必须考虑安全性问题:
  
  * 在Java applications的场合里面Java代码是本地的,所以也是"trusted"
  
  * 没有验证的Java applet代码不可以存取本地的以及其他网络的数据。
  
  5. 1. JDBC 和未验证的applet
  
  JDBC首先必须符合JAVA的一般安全规则。另外:
  
  * JDBC 必须认为没有验证的applets是不可靠的。
  
  * JDBC 不可以让不可靠的applets存取本地数据库。
  
  * 一个已经向JDBC DriverManager注册的是JDBC Driver只能存取它所来的数据源。
  
  * 一个applet也只能向它所Download来的服务器来存取数据。
  
  假如JDBC驱动层假如完全确信对一个数据库服务器打开连接不会引起认证或者权限问题(可能由网上随机主机上运行的程序引起),那么它就答应applet打开这样的连接。
  
  数据库服务器不通过IP地址来限制存取是相当少的,主要是为了举例。(当心,这一段话我可能翻译反了!!!大家看看原文。)这些限制是相当烦琐的。不过他们与对一般applet的限制是一致的我们没有必要放开这些限制。
  
  5. 2. JDBC 和Java应用程序
  
  对于一个普通的Java应用程序(例如全部用Java代码而不是不可靠的applet )JDBC将从本地的类路径里面获得驱动,并且答应应用程序自由存取文件,远程服务器等等。
  
  但是和applet一样,假如由于某些原因一个没有验证的sun.sql.Driver类从远程的来源里面获得,那么这个驱动只能和相同地方来的代码配合。
  
  5. 3. Driver的安全责任
  
  JDBC driver可能在各种情况下使用,所以驱动的编制者遵循一定的简单的安全规则,从而避免applet做非法的数据库连接。
  
  假如所有的驱动都象applet一样从网上下载,那么这些原则将是不必要的,因为普通的安全规则已经对它做了限制。
  
  但是驱动的编写者必须记住一旦他们的驱动获得成功,用户将在本地磁盘安装这些驱动,那么驱动将成为Java环境中一个被信任的部分,所以必须确信它不会被来访的applet所滥用。所以我们鼓励所有的驱动编写者必须遵循一定安全原则。
  
  所有这些原则都是在连接打开的时候使用。这正式驱动和虚拟机器检查当前调用者是否真的可以与指定的数据库连接的时刻。一旦连接建立就不必做更多的检查了。
  
  5. 3. 1. 分享TCP/IP连接的时候必须谨慎
  
  假如一个JDBC驱动试图打开一个 TCP 连接,那么这个打开会被Java 安全治理机制自动检查。这个机构会检查当前调用栈里面有没有applet,假如有那么就限定它可以访问的机器集合。所以一般地JDBC驱动可以把TCP建立检查留给Java虚拟机。
  
  但是假如一个JDBC驱动试图在多个数据库连接之间共享一个TCP连接,那么驱动就必须自己负责检查每个调用者是否真的被答应与目标数据库联系。
  
  例如假如我们为applet A打开了一个通往机器foobah 的TCP连接,这并不意味着applet B被自动答应来共享这个连接。
  
  applet B可能没有任何访问机器foobah的权力。所以在答应某个程序重用一个现成的TCP连接之前,JDBC 驱动必须通过安全机构来检查当前的的调用者是否可以访问这个连接。通过下面的代码可是实现这个功能。
  
  SecurityManager security = System.getSecurityManager();
  
  if (security != null)
  
  {
  
  security.checkConnect(hostName, portNumber);
  
  }
  
  假如连接是不答应的,那么Security.checkConnect方法将产生一个java.lang.SecurityException。
  
  5. 3. 2. 检查所有的本地文件访问。
  
  假如一个JDBC取得需要访问本地机器上的数据,那么他必须确信调用者是被答应打开这个文件的。例如:
  
  SecurityManager security = System.getSecurityManager();
  
  if (security != null)
  
  {
  
  security.checkRead(fileName);
  
  }
  
  假如对特定文件的访问是不答应的,那么Security.checkRead方法将产生一个java.lang.SecurityException。
  
  5. 3. 3. 作好最坏的预备
  
  一些驱动可能使用本地的方法来桥接底层数据库程序。则这些情况里面判定那些本地文件将被底层函数所访问是困难的。
  
  在这些环境里面用户必须作好最坏的打算,并且否决所有下载applet所发出的数据库存取,除非驱动可能完全确信将要做存取是没有问题的。
  
  例如一个JDBC-ODBC桥接器必须检查ODBC数据源的的名称,确保applet只可以访问它的"生源地"。假如对有的名字中不能判定出数据源的主机名,那么只能否决这个访问。
  
  为了决定一个当前的调用者是可以信赖的应用还是一个applet,JDBC驱动必须能够检查这个调用者是否可以写一个随机的文件:
  
  SecurityManager security = System.getSecurityManager();
  
  if (security != null)
  
  {
  
  security.checkWrite("foobaz");
  
  I. }
上一篇:灵活使用EJB的本地和远程接口(二) 人气:630
下一篇:EJB的编程限制 人气:513
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐