语言小结
  • program-language-note
  • contact
  • common
    • 代码风格
    • 概念语法
      • 类型
      • 注释
      • 字符
      • 语句
      • 操作符
      • 函数
        • 递归
    • 格式化参数
    • 源码结构
    • 数据结构
    • 名词
  • 电路
    • 内存地址
    • Untitled
    • Code
  • C
    • note
    • overview
      • helloworld.c
      • c标准
      • 关键字
      • tips
      • util.c
    • 语法
      • 函数
        • main
      • const
      • static
      • 作用域
    • 编译和运行
      • c代码内存模型
      • 预处理
        • include
        • define
    • 头文件
    • 基本数据类型
      • 整型
      • 枚举
      • 浮点型
      • 指针
      • 数组
      • 结构和联合
    • 指针&数组、指针&函数
    • API
    • 存储结构
    • 操作符
      • sizeof
    • typedef
    • 输入输出
    • 格式化参数
    • 左値右値
    • 性能思考
    • volatile
    • 字符串
      • find_char.c
    • 动态分配
      • alloc.h
      • alloc.c
      • alloc_usage.c
    • note
  • cpp
    • 资源
    • note
    • 数据结构
    • 智能指针
    • 编译过程
  • shell
    • usage
    • Untitled
  • Rust
    • overview
  • Lisp
    • Untitled
  • web
    • overview
      • index
      • 软件工具
      • ARIA规范
      • SEO
    • style
    • html
      • 标签、元素
        • 标签快记
        • 联系信息
        • 引用
        • 列表
        • 语言设置
        • meta
      • 页面结构
        • 图片
        • 视频
        • 引用css、js文件
      • 等价字符
      • 链接
        • 邮件
      • 表单
        • note
      • 表格
    • css
      • 字体
      • 布局
        • position
        • float
        • display
        • flexbox
    • js
    • note
  • java
    • note
    • java语言程序设计
    • 设计模式
      • 大话设计模式-吴强-2010
      • 大话设计模式-程杰
      • 设计模式-gof
      • 设计模式解析
      • 原则
      • 单例
    • java程序设计第10版-基础
    • java程序设计第10版-进阶
    • java核心技术第9版-I
    • jar包
    • 安全
    • 反射
  • python
    • note
    • index
    • 个人记忆点
    • 疑惑
    • simple
    • 精通Python爬虫框架scrapy
    • 语法
    • scrapy
      • notice
      • index
  • 汇编
    • Untitled
  • kotlin
    • index
    • note
    • by android
      • note
      • index
  • groovy
    • gradle
Powered by GitBook
On this page
  • Java技术自身安全机制
  • 类加载器

Was this helpful?

  1. java

安全

Previousjar包Next反射

Last updated 5 years ago

Was this helpful?

主要来源:[JavaCore卷Ⅱ中文第9版--章9] 深入拓展:

Java技术自身安全机制

1、语言特性 -- 数组边界检查、强类型、无指针算法等 2、访问控制 -- 文件访问、网络访问等 3、代码签名

类加载器

保证了类被加载到虚拟机时的完整性。 无论是默认类加载器还是自定义的,都需要与负责控制代码运行的安全管理类协同工作。

介绍

Java编译器会把代码源文件(.java)转换成存储虚拟机指令的类文件(.class),好让虚拟机执行。 而虚拟机执行的时候,需要进一步转换成目标机器的机器语言。

虚拟机解读的步骤如下: 1.虚拟机通过加载类文件的机制 --磁盘读取文件或者请求web文件-- 加载一个MyProgram.class 2.然后解析类,如果拥有另一个类的域,或者具有超类,会逐个加载 3.然后执行MyProgram的main方法(静态方法,无需创建实例) 4.然后加载执行方法过程中所需的类

每个Java程序至少拥有三个类加载器:

  • 引导类加载器

  • 扩展类加载器

  • 系统类加载器(或者叫 应用类加载器)

引导类加载器负责加载系统类(通常从rt.jar文件中加载)。它是虚拟机不可分割的一部分,而且通常是用C语言来实现的,且没有对应的ClassLoader对象,例如String.class.getClassLoader()返回null 扩展类加载器负责加载“标准的扩展”(从jre/lib/ext目录中加载)。可以把需要的JAR文件放入该目录,这样扩展类加载器可以不通过类路径而直接找到类。 系统类加载器用于加载应用类。在由CLASSPATH环境变量,或者-classpath命令行选项设置的类路径中的目录或者是JAR/ZIP文件里查找类。 在Oracle的java实现中,后两者都是URLClassLoader的实例。

《Inside Java 2 Platform Security : Architecture, API Design, and Implementation》