网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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,移动开发
本月文章推荐
.Java技巧:按屏幕比例重新设定一.
.常用JDBC连接方法.
.一篇不错的介绍Java Socket编程的.
.JML起步--使用JML改进你的Java程.
.Jakarta Struts应用的七个经验(.
.Java中的Vector.
.课程介绍(1):SL-110 初级Java语言.
.Apache与Tomcat整合问题的新方法.
.理解JavaHelp结构的好处.
.使用iterator节省代码.
.Java图像处理.
.经验分享:如何迅速成为Java高手.
.JBUILDER 5新增功能.
.用SQLJ开发数据库(3).
.Jar文件高级应用指南.
.深入浅出基于Java的建造设计模式.
.sun Technical Training NOTE.
.3. Building View Components.
.OJB简介--翻至ojb docs.
.实现Hibernate分页查询原理解读.

详细介绍并掌握J2ME的安全结构

发表日期:2008-1-5



  基于CLDC+MIDP的无线应用程序具有与生俱来的安全特性,这得益于Java语言和JAVA平台的安全机制。即使是有破坏性的程序也只能伤害到虚拟机层,不会伤害到手机操作系统。本文并不是要专门针对MIDP2.0的安全体系结构进行介绍,而是力图结合Java语言、虚拟机等方面的安全设计谈谈无线应用的安全结构。
  
  Java语言具有安全的特性,这得益于下面三个方面的支持。
  
  java语言是健壮的、安全的
  在java中规定了所有原始数据类型的精确尺寸,并且这不依靠于底层的操作系统。java具有非常出色的异常处理机制,对数组越界操作和公指针操作提供检查,一经发现会抛出异常。要知道假如在c语言中由于程序的不健全导致数组越界操作是非常危险的事情。java中采用的是引用机制,没有提供指针运算的操作。以上几点确保了java语言本身的安全性。
  
  java编译器和运行环境
  Java的编译器和运行环境通过提供的一些特性来确保安全的实现,这些特性包括:类装载、Class文件验证。总之,这将确保Java程序必须要在一个JVM规范答应的范围内运行。假如读者有爱好可以参考一下《深入Java虚拟机2》
  
  SecurityMananger
  以上两个方面可以确保怀有恶意的代码不被执行,这样虚拟机就不会被破坏。但是针对applet或者非信任的网络程序则无能为力,java中定义了SecurityManager类答应用户订制安全政策,什么代码可以被执行,什么不可以被执行。
  用过Applet的程序员都知道沙箱这个词,它同样是为了确保安全。Applet的运行需要从网络上下载到本地上来,在你确认它是否安全之前让它访问你的本地资源的话那将是非常危险的事情。因此java采用了沙箱的机制,让applet运行在一个受限的环境内。
  
 具体介绍并把握J2ME的安全结构(图一)

  由于J2SE中的安全机制需要很大内存的支持,因此在J2ME(CLDC+MIDP)中并没有采取。在J2ME中采用的是两层安全结构,包括底层的KVM安全机制和上层的应用程序安全机制。
  
  在KVM的安全机制中,主要是通过class文件验证来确保安全的,一旦这个class文件是非安全的,比如它含有对危险内存空间的引用,那么KVM将不会运行它的。但是由于class文件在验证上比较消耗时间,因此KVM的设计人员把这部分工作移植到开发阶段了,我们看到源文件在编译后会被验证,你可以仔细看看ktoolbar的控制台输出。而在KVM里面做的验证都是简单的。
  
具体介绍并把握J2ME的安全结构(图二)

  在应用程序层进行的限制主要是为了防止应用程序恶意破坏文件系统等设备。由于考虑到性能的问题,他没有采取SecurityManager类的策略。因此与传统的沙箱不同的是,基于CLDC/MIDP的沙箱模型作了如下的限制。
  
  class文件必须是经过验证并有效的
  系统只提供了一部分预定义的API给开发人员,为了安全的因素JNI、用户定义的类装载器都不被支持
  下载和治理应用程序由KVM完成,用户不能自己实现
  开发者不能下载并使用任何包含访问本机方法的类库,只限于CLDC/MIDP和可选包。
上一篇:请关注J2ME WTK2.2 的新特性 人气:545
下一篇:J2ME(CLDC/MIDP)简介 人气:867
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐