java 安全 笔记

java  安全

1.类加载器 Classloader

每个java程序最少有三个类加载器,引导类加载器、扩展类加载器、系统类加载器(应用类加载器)

引导类加载器没有Classloader,String.class.getClassloader()为null,是虚拟机的一部分。负责加载系统类,通常从rt.jar中加载。

扩展类加载器从jre/lib/ext目录中加载标准的的扩展。

系统类加载器 加载classpath环境变量中的类

除了引导类加载器以外,每个类加载器都有一个父类加载器,加载时先用父加载器加载,当父加载器加载失败时,再加载。

通过Classloader.defineClass可以将字节码加载为Class


2.字节码校验

当类加载器将新加载的java平台类的字节码传递给虚拟机时,这写字节码首先要接受校验器(verifier)的校验。校验器负责检查那些无法执行的明显有破坏性的操作。

出系统类外,所有的类都要校验。可以使用非正式的-noverify选项来关闭校验。


3.安全管理器与访问权限

一旦某个类被某个类加载器或者默认的类加载机制加载到虚拟机中,并由校验器检查过之后,java平台的第三种安全机制就会启动。这个机制就是安全管理器。安全管理器是控制某个操作是否允许执行的类,安全管理器负责检查的操作包括

当前线程是否能创建一个新的类加载器

当前线程是否能够中止虚拟机的运行

某个类是否能够访问另一个类的成员

当前线程是否能够访问本地文件

当前线程是否能够打开到达外部主机的socket连接

某个类是否能够启动打印操作

某个类是否能访问系统剪切板

某个类是否能访问AWT事件队列

当前线程是否可被信任以打开一个顶层窗口等


在运行java应用程序时,默认的设置是不安装安全管理器,这样所有的操作都被允许。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值