Introduction to java virtual machine(2)

  Java's security model

The fundamental components responsible for Java's sandbox are:

  • the class loader architecture
  • the class file verifier
  • safety features built into the Java virtual machine (and the language)
  • the security manager and the Java API 

    sandbox,沙盒,是Java开发环境中的一种安全措施。当applet作为网页的一部分进行传输的时候,沙盒就是一组创建applet时需要遵循的规则,它可以预防某些意外的发生。当浏览器请求一个含有applet的网页时,applet会自动的发送给浏览器,并在到达后立即执行。如何applet被允许可以无限制的访问内存和操作系统的资源,计算机会收到恶意的伤害。沙盒可以创建一个环境,严格规定了什么样的系统资源applet可以访问。当可执行的代码来源未知或者不可信任是,沙盒允许用户安全的运行这些代码。

    Java沙盒通过三层防御达到安全的目的,任何一层的失败都会导致安全功能的丧失,并存在被攻击的威胁:

  • 1.字节码校验--在运行之前,Java自动的检查不信任的外部码。当对java源码进行编译的时候,它会生成平台独立的通过校验 的java位码。这些为程序的安全打下了基础。[主要执行下面的检查:类符合JVM规范的类文件格式,没有违反访问限制,代码没有造成堆栈的上溢或者下溢,所有操作代码的参数类型都是正确的,没有非法的数据类型转换(例如将整型数转换成对象类型)发生;校验通过的字节码被解释器(interpreter)执行,解释器在必要时通过运行时系统执行对底层硬件的合适调用。]
  • 2.applet类载入程序--所有的Java对象属于classes,applet类载入程序决定何时和如何把applet载入并运行。applet载入程序确保Java运行环境的主要组件没有被applet安装代码替换。
  • 3.安全管理器--当危险的代码将执行的时候,安全管理器会查询Java代码库。安全管理器有权阻止某项操作,并产生一个安全例外。
虚拟机(Virtual Machine)指通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统 定义   虚拟机指通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统。 编辑本段用途   通过虚拟机软件,你可以在一台物理计算机上模拟出一台或多台虚拟的计算机,这些虚拟机完全就像真正的计算机那样进行工作,例如你可以安装操作系统、安装应用程序、访问网络资源等等。对于你而言,它只是运行在你物理计算机上的一个应用程序,但是对于在虚拟机中运行的应用程序而言,它就是一台真正的计算机。因此,当我在虚拟机中进行软件评测时,可能系统一样会崩溃,但是,崩溃的只是虚拟机上的操作系统,而不是物理计算机上的操作系统,并且,使用虚拟机的“Undo”(恢复)功能,我可以马上恢复虚拟机到安装软件之前的状态。 编辑本段虚拟系统与虚拟机区别   虚拟系统其实以Prayaya迅影V3虚拟系统为代表的,通过生成现有操作系统的全新虚拟镜像,它具有真实windows系统完全一样的功能,进入虚拟系统后,所有操作都是在这个全新的独立的虚拟系统里面进行,可以独立安装运行软件,保存数据,拥有自己的独立桌面,不会对真正的系统产生任何影响 ,而且具有能够在现有系统与虚拟镜像之间灵活切换的一类操作系统。虚拟系统和传统的虚拟机(Vmware,VirtualBox,Virtual pc)不同,虚拟系统不会降低电脑的性能,启动虚拟系统不需要像启动windows系统那样耗费时间,运行程序更加方便快捷。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值