JVM基础篇---02
为什么需要用户自定义类加载器:
扩展类加载器的功能:
Java的默认类加载器主要有三个,分别是引导类加载器、扩展类加载器和应用程序类加载器。其中,引导类加载器和扩展类加载器是由JVM实现的,用户无法修改其行为。而应用程序类加载器是由Java程序开发者编写的,可以满足一般的类加载需求。但是在某些特殊情况下,需要扩展类加载器的功能,比如加载自定义的类文件、从非标准位置加载类等,这时就需要用户自定义类加载器了。
实现类的动态加载:
动态加载类是一种非常有用的功能,可以在程序运行时动态地加载类文件,并且只在需要时才加载。这在一些需要灵活性和扩展性的场景下特别适用,比如插件化开发、热部署等。用户自定义类加载器可以提供这种动态加载类的功能,通过重写findClass()方法,可以根据自定义的加载规则来加载类。
实现类的隔离和保护:
有些情况下,我们希望某些类只能由特定的类加载器来加载,以达到类的隔离和保护的目的。例如,在Java应用程序中,可以使用不同的类加载器加载不同的模块,并设置不同的权限限制,从而实现对类的隔离和保护。用户自定义类加载器可以帮助我们实现这种隔离和保护的需求。
实现自定义的类加载策略:
Java的默认类加载器按照一定的规则来加载类,但有时我们需要实现一些自定义的加载策略。比如,在分布式环境下,可以使用自定义的类加载器来从网络中加载类,或者从数据库中加载类。这样可以更灵活地根据实际需求来加载类,提高系统的可扩展性和灵活性。
加载非Java类:
Java的默认类加载器只能加载Java类文件,而有些场景下需要加载非Java类,例如JNI(Java Native Interface)开发中,需要加载C/C++编写的本地库,这时就需要用户自定义的类加载器来加载非Java类。
ClassLoader常用方法:
- loadClass(String name):加载指定名称的类。该方法使用默认的类加载器加载类,返回一个Class对象。如果类已经被加载过,则直接返回已加载的Class对象。
ClassLoader classLoader = ClassLoader.getSystemClassLoader();
Class<?> clazz = classLoader.loadClass("com.example.MyClass");
- getResource(String name):根据名称获取资源的URL。资源可以是类路径下的文件,也可以是JAR文件中的文件。返回一个URL对象,表示资源的位置。如果资源不存在,则返回null。
ClassLoader classLoader = ClassLoader.getSystemClassLoader();
URL resourceUrl = classLoader.getResource("myresource.txt");
- getResourceAsStream(String name):根据名称获取资源的输入流。返回一个InputStream对象,通过该输入流可以读取资源的内容。如果资源不存在,则返回null。
ClassLoader classLoader = ClassLoader.getSystemClassLoader();
InputStream inputStream = classLoader.getResourceAsStream("myresource.txt");
- getSystemClassLoader():获取系统类加载器。系统类加载器是Java虚拟机默认的类加载器,一般是AppClassLoader的实例。
ClassLoader classLoader = ClassLoader.getSystemClassLoader();
- getParent():获取父类加载器。每个类加载器都有一个父类加载器,用于委派加载任务。如果没有父类加载器,则返回null。
ClassLoader classLoader = ClassLoader.getSystemClassLoader();
ClassLoader parentClassLoader = classLoader.getParent();
- defineClass(String name, byte[] b, int off, int len):定义一个新的类。该方法将字节数组中的字节码转换为Class对象。通常在自定义类加载器中使用。
class MyClassLoader extends ClassLoader {public Class<?> defineClassFromByteCode(String className, byte[] byteCode) {return defineClass(className, byteCode, 0, byteCode.length);}
}
- resolveClass(Class<?> c):链接一个已经加载的类。链接是指将类的二进制数据合并到Java虚拟机中,生成可执行代码的过程。
ClassLoader classLoader = ClassLoader.getSystemClassLoader();
Class<?> clazz = classLoader.loadClass("com.example.MyClass");
classLoader.resolveClass(clazz);
沙箱安全机制
是一种计算机安全措施,用于隔离和限制应用程序或代码的访问和行为,以防止恶意代码对系统造成损害。它通常将应用程序或代码限制在一个受限的执行环境中,以防止其访问敏感资源或对系统进行未经授权的操作。
沙箱安全机制的原理是通过创建一个虚拟的、与主操作系统隔离的执行环境,其中包含了一系列限制和保护措施。这个执行环境通常被称为沙箱。沙箱通过实施访问控制、权限管理、资源限制和行为监控等措施,确保应用程序或代码只能在受限的范围内运行,并防止其对系统造成任何损害。
沙箱安全机制的作用主要有以下几个方面:
-
防止恶意代码的扩散:沙箱可以限制应用程序或代码的访问权限,防止其对系统中的重要文件、目录或其他资源进行修改、删除或读取。这样可以防止恶意代码通过系统漏洞或探针来扩散或窃取敏感信息。
-
隔离应用程序:沙箱可以将应用程序隔离在一个独立的执行环境中,防止其对其他应用程序或系统造成干扰。这可以有效地防止应用程序之间的冲突或意外的干扰,提高系统的稳定性和安全性。
-
检测和阻止恶意行为:沙箱可以对应用程序的行为进行监控和审计,以便及时发现和阻止恶意行为。它可以检测应用程序对系统资源的异常访问、未经授权的操作或其他恶意行为,并采取相应的措施进行拦截和防御。
-
提供可信环境:沙箱可以为应用程序提供一个可信的执行环境,避免被未知或不受信任的代码影响。这对于运行第三方应用程序或代码非常重要,可以提供额外的安全保障,防止恶意代码的滥用或攻击。
相关文章:
JVM基础篇---02
为什么需要用户自定义类加载器: 扩展类加载器的功能: Java的默认类加载器主要有三个,分别是引导类加载器、扩展类加载器和应用程序类加载器。其中,引导类加载器和扩展类加载器是由JVM实现的,用户无法修改其行为。而应用…...
HTML网站基础
一、前端开发基础 前端一共三门语言——HTML、CSS、JS(Java Script) HTML用于静态网页框架,CSS用于修饰,JS构成动态网页 1、HTML 对于中文网页需要使用 <meta charset"utf-8"> 声明编码,否则会出现…...
最优化考试之惩罚函数外点法
最优化考试之惩罚函数外点法 一、外点法1.问题条件2.解题过程 一、外点法 1.问题条件 目标函数 f ( x ) f(x) f(x)约束函数 g ( x ) g(x) g(x) 2.解题过程 定义罚函数 F ( x ) f ( x ) t ∗ m i n ( 0 , g ( x ) 2 ) F(x)f(x)t*min(0,g(x)^2) F(x)f(x)t∗min(0,g(x)2)对罚…...
JavaScript 数组【详解】
Hi i,m JinXiang ⭐ 前言 ⭐ 本篇文章主要介绍JavaScript中数组详解 数组声明/基础操作以及部分理论知识 🍉欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁 🍉博主收将持续更新学习记录获,友友们有任何问题可…...
Node.js版本对比
目录 1. node版本与Npm版本对照表 2. node版本与node-sass版本对照表 3. node-sass与sass-loader版本对照表 1. node版本与Npm版本对照表 以往的版本 | Node.js 下面显示最新的对应内容,如果需要查找历史版本,可以进入上面的页面查询 VersionLTSDateV8np…...
人工智能:网络犯罪分子的驱动力
随着 2024 年的临近,是时候展望今年的网络安全状况了。由于网络犯罪日益复杂,预计到 2025 年,全球网络安全成本将增至 10.5 万亿美元。 人工智能的使用不断发展,网络犯罪分子变得越来越有创造力 我们注意到,联邦调查…...
ASP.NET Core认证原理和实现
ASP.NET Core认证原理和实现 AuthenticationHttpContextExtensions AuthenticationHttpContextExtensions 类是对 HttpContext 认证相关的扩展,它提供了如下扩展方法: public static class AuthenticationHttpContextExtensions {public static Task&l…...
基于OpenCV的图像颜色与形状识别的原理2
基于OpenCV的图像颜色与形状识别通常涉及以下几个步骤: 图像读取:使用OpenCV的cv2.imread()函数读取图像。预处理:可能包括图像的灰度转换、二值化、滤波等,以减少噪声和无关信息。颜色识别:颜色空间转换:…...
无法获取前置摄像头的预览图像?【Bug已解决-鸿蒙开发】
文章目录 项目场景:问题描述原因分析:解决方案:此Bug解决方案总结HarmonyOS和OpenHarmony区别和联系项目场景: 最近也是遇到了这个问题,看到网上也有人在询问这个问题,本文总结了自己和其他人的解决经验,解决了无法获取前置摄像头的预览图像的问题。 问题:前置摄像头…...
微信小程序的bindtap和catchtap的区别
一. 事件 1.事件是视图层到逻辑层的通讯方式。 2. 事件可以将用户的行为反馈到逻辑层进行处理。 3. 事件可以绑定在组件上,当达到触发事件,就会执行逻辑层中对应的事件处理函数。 二. 如何使用事件 1. 简单来说就是将事件绑定到组件上面,bi…...
python哈希算法实现
以下是用Python实现SHA-256算法的示例代码: import hashlibdef sha256(message):# 创建SHA-256哈希对象sha256_hash hashlib.sha256()# 更新哈希对象的输入消息sha256_hash.update(message.encode(utf-8))# 计算哈希值并返回十六进制表示return sha256_hash.hexdi…...
SpringBoot实用开发(三)-- Redis提供API接口 -- StringRedisTemplate
引言: 由于redis内部不提供java对象的存储格式,因此当操作的数据以对象的形式存在时,会进行转码,转换成字符串格式后进行操作。为了方便开发者使用基于字符串为数据的操作,springboot整合redis时提供了专用的API接口StringRedisTemplate,你可以理解为这是RedisTe…...
【Qt-编码】
Qt编程指南 ■ 编码■ ASCII■ ANSI■ GB2312■ GBK■ GB18030 编码■ Unicode■ UTF-8: ■ Qt接收注射泵GBK编码后显示乱码■■ ■ 编码 ■ ASCII (American Standard Code for Information Interchange,美国信息交换标准代码)…...
使用Python实现Linux惠尔顿上网认证客户端
在本文中,我们将展示如何使用Python编写一个简单的脚本来实现Linux下的惠尔顿上网认证。以下是我们需要的参数和值: wholeton_host: 惠尔顿服务器地址,例如 192.168.10.10wholeton_user: 用户名,例如 AABBCCwholeton_pass: 密码&…...
【漏洞复现】某检测系统(admintool)接口任意文件上传漏洞
文章目录 前言声明一、漏洞详情二、影响版本三、漏洞复现四、修复建议 前言 湖南建研检测系统 admintool接口任意文件上传漏洞,攻击者可通过该漏洞获取服务器敏感信息。 声明 请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息或者…...
检测如下MHA运行条件【踩坑记录】
【masterha_check_ssh --conf/etc/mha/app1.cnf:SSH免密登录】 【错误信息1】 [error][/usr/share/perl5/vendor_perl/MHA/SSHCheck.pm, ln111] SSH connection from root10.0.0.53(10.0.0.53:22) to root10.0.0.51(10.0.0.51:22) failed! 【错误反馈】就是服务器…...
使用js编写一个函数判断所有数据类型的通用方法
一、typeof 在 JavaScript 里使用 typeof 来判断数据类型,只能区分基本类型,即 “number”,”string”,”undefined”,”boolean”,”object” 五种。 对于数组、对象来说,其关系错综复杂&…...
AutoSAR(基础入门篇)2.1Autosar架构中的AppL
目录 一、Autosar中APPL概述 1、AppL的内容 2、汽车顶灯示例 3、SWC的通信...
怎么使用jupter notebook并配置环境变量
有的时候需要使用Jupyter Notebook运行代码,Jupyter Notebook的主要特点: ① 编程时具有语法高亮、缩进、tab补全的功能。 ② 可直接通过浏览器运行代码,同时在代码块下方展示运行结果。 ③ 以富媒体格式展示计算结果。富媒体格式包括&…...
深信服技术认证“SCSA-S”划重点:文件上传与解析漏洞
为帮助大家更加系统化地学习网络安全知识,以及更高效地通过深信服安全服务认证工程师考核,深信服特别推出“SCSA-S认证备考秘笈”共十期内容,“考试重点”内容框架,帮助大家快速get重点知识~ 划重点来啦 *点击图片放大展示 深信服…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...
[特殊字符] 智能合约中的数据是如何在区块链中保持一致的?
🧠 智能合约中的数据是如何在区块链中保持一致的? 为什么所有区块链节点都能得出相同结果?合约调用这么复杂,状态真能保持一致吗?本篇带你从底层视角理解“状态一致性”的真相。 一、智能合约的数据存储在哪里…...
Cursor实现用excel数据填充word模版的方法
cursor主页:https://www.cursor.com/ 任务目标:把excel格式的数据里的单元格,按照某一个固定模版填充到word中 文章目录 注意事项逐步生成程序1. 确定格式2. 调试程序 注意事项 直接给一个excel文件和最终呈现的word文件的示例,…...
应用升级/灾备测试时使用guarantee 闪回点迅速回退
1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间, 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点,不需要开启数据库闪回。…...
阿里云ACP云计算备考笔记 (5)——弹性伸缩
目录 第一章 概述 第二章 弹性伸缩简介 1、弹性伸缩 2、垂直伸缩 3、优势 4、应用场景 ① 无规律的业务量波动 ② 有规律的业务量波动 ③ 无明显业务量波动 ④ 混合型业务 ⑤ 消息通知 ⑥ 生命周期挂钩 ⑦ 自定义方式 ⑧ 滚的升级 5、使用限制 第三章 主要定义 …...
CMake 从 GitHub 下载第三方库并使用
有时我们希望直接使用 GitHub 上的开源库,而不想手动下载、编译和安装。 可以利用 CMake 提供的 FetchContent 模块来实现自动下载、构建和链接第三方库。 FetchContent 命令官方文档✅ 示例代码 我们将以 fmt 这个流行的格式化库为例,演示如何: 使用 FetchContent 从 GitH…...
云原生周刊:k0s 成为 CNCF 沙箱项目
开源项目推荐 HAMi HAMi(原名 k8s‑vGPU‑scheduler)是一款 CNCF Sandbox 级别的开源 K8s 中间件,通过虚拟化 GPU/NPU 等异构设备并支持内存、计算核心时间片隔离及共享调度,为容器提供统一接口,实现细粒度资源配额…...
沙箱虚拟化技术虚拟机容器之间的关系详解
问题 沙箱、虚拟化、容器三者分开一一介绍的话我知道他们各自都是什么东西,但是如果把三者放在一起,它们之间到底什么关系?又有什么联系呢?我不是很明白!!! 就比如说: 沙箱&#…...
Axure 下拉框联动
实现选省、选完省之后选对应省份下的市区...
热门Chrome扩展程序存在明文传输风险,用户隐私安全受威胁
赛门铁克威胁猎手团队最新报告披露,数款拥有数百万活跃用户的Chrome扩展程序正在通过未加密的HTTP连接静默泄露用户敏感数据,严重威胁用户隐私安全。 知名扩展程序存在明文传输风险 尽管宣称提供安全浏览、数据分析或便捷界面等功能,但SEMR…...
