网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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!
当前位置 > 网站建设学院 > 网络编程 > J2EE/J2ME
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,移动开发
本月文章推荐
.精通Hibernate映射继承关系之四.
.关注J2ME WTK2.2新特性.
.实战程序管理器和多语言程序.
.使用J2ME实现移动支付.
.J2me性能优化,避免内存溢出小结.
.测试MySQL驱动的安装.
.J2ME中RMS的使用解析.
.EnterpriseJavaBeans导论六.
.新手入门:初学者搭建J2ME移动开.
.无线标记语言(WML)基础之基本知识.
.手机开发教您使用JSR172解析XML.
.步入J2EE架构和过程(2).
.M3G游戏中性能提升技巧.
.JBoss-3.0.1RC1_Tomcat-4.0.4中的.
.WebService开发的层次.
.在索尼爱立信JP7平台上自动启动M.
.J2EE常见问题.
.快速开发web程序:用WebWork、JSP.
.简析J2EE应用程序中数据库类的设.
.使用蓝牙技术开发交互五子棋.

介绍J2ME的安全结构

发表日期:2007-12-23


    基于CLDC+MIDP的无线应用程序具有与生俱来的安全特性,这得益于Java语言和JAVA平台的安全机制。即使是有破坏性的程序也只能伤害到虚拟机层,不会伤害到手机操作系统。本文并不是要专门针对MIDP2.0的安全体系结构进行介绍,而是力图结合Java语言、虚拟机等方面的安全设计谈谈无线应用的安全结构。

    Java语言具有安全的特性,这得益于下面三个方面的支持。

  1. java语言是健壮的、安全的。
    在java中规定了所有原始数据类型的精确尺寸,并且这不依赖于底层的操作系统。java具有非常出色的异常处理机制,对数组越界操作和空指针操作提供检查,一经发现会抛出异常。要知道如果在c语言中由于程序的不健全导致数组越界操作是非常危险的事情。java中采用的是引用机制,没有提供指针运算的操作。以上几点确保了java语言本身的安全性。
  2. java编译器和运行环境
    Java的编译器和运行环境通过提供的一些特性来确保安全的实现,这些特性包括:类装载、Class文件验证。总之,这将确保Java程序必须要在一个JVM规范允许的范围内运行。如果读者有兴趣可以参考一下《深入Java虚拟机2》
  3. 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的沙箱模型作了如下的限制。

  1. class文件必须是经过验证并有效的
  2. 系统只提供了一部分预定义的API给开发人员,为了安全的因素JNI、用户定义的类装载器都不被支持
  3. 下载和管理应用程序由KVM完成,用户不能自己实现
  4. 开发者不能下载并使用任何包含访问本机方法的类库,只限于CLDC/MIDP和可选包。

    希望您读完这篇文章能对J2ME的安全体系有一定的认识。

(出处:)


上一篇:熟练使用J2ME可选包MMAPI 人气:657
下一篇:WML开发详细指南 人气:795
浏览全部J2EE/J2ME的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐