什么是Java中的JVMTI(JVM Tool Interface)?

Java中的JNI(Java Native Interface)和JVMTI(JVM Tool Interface)都是与Java运行时环境(JVM)交互的工具,但它们有不同的目的和使用场景。下面我从新手的角度来幽默地解释一下它们的区别和用途。

JNI:Java Native Interface,就是Java Native库。当你需要在本地代码(C、C++等)中调用Java代码时,就需要用到JNI。这就好像你想吃米饭,但是米太贵,于是你买了一堆糯米,然后用糯米包饺子吃。虽然糯米饺子也很好吃,但是饺子皮是糯米做的,吃完之后太撑了。所以,你需要用到JNI来“吃”糯米。

代码示例:

public class JniExample {
    public native void printHello();
    static {
        System.loadLibrary("jni");
    }
    public static void main(String[] args) {
        JniExample example = new JniExample();
        example.printHello();
    }
}

JVMTI:JVM Tool Interface,就是JVM工具接口。当你需要监控、调试或修改Java程序时,就需要用到JVMTI。这就好像你想吃米饭,但是你不想自己包饺子,于是你找到了一个卖饺子的店,想要知道这家店的饺子好吃不好吃。这时你就可以用JVMTI来“吃”这家店的饺子。

代码示例:

public class JvmtiExample {
    public static void main(String[] args) {
        System.out.println("JVMTI Example");
    }
}

以上就是一个简单的例子,你可以在命令行中运行这个程序,然后使用JVMTI来查看程序的输出结果。这样你就可以知道这家店的饺子好吃不好吃了。

我们再来举个例子。

想象一下,如果你在海滩上散步,突然发现了一个宝藏,但是你不知道怎么找到它。这时,你可以使用GPS(全球定位系统)来找到宝藏的位置。同样地,JVMTI就像是你在Java应用程序中的GPS,可以帮助你找到宝藏(即优化应用程序性能)的位置。

下面是一个简单的代码示例,演示如何使用JVMTI来监控Java应用程序的执行过程:

public class MonitorApp {
    public static void main(String[] args) {
        // 启动JVMTI
        JVMTICaller jvmtiCaller = new JVMTICaller();
        jvmtiCaller.start();

        // 运行应用程序
        System.out.println("开始运行应用程序...");
        // 模拟一些耗时的操作
        for (int i = 0; i < 1000000; i++) {
            if (i == 50000) {
                System.out.println("应用程序执行了50,000次循环!");
            }
        }
        System.out.println("应用程序执行完毕!");
    }
}

class JVMTICaller {
    public static void start() {
        // 启用JVMTI事件回调
        jvmtiEnv env = JVMTICallback.startJVMTICallback();
        // 设置要监控的变量和方法
        // ...
        // 关闭JVMTI事件回调
        env.Env = null;
    }
}

在上面的示例中,我们创建了一个名为MonitorApp的类,它运行一个简单的循环。然后,我们创建了一个名为JVMTICaller的类,它使用JVMTI API启动了JVMTI事件回调。在调用start方法时,我们调用了JVMTICallback的静态方法startJVMTICallback,该方法返回一个jvmtiEnv对象,用于监控应用程序的执行过程。在这个例子中,我们没有设置任何要监控的变量和方法,但是在实际应用中,我们可以使用JVMTI API来监视Java代码中的各种事件,例如方法调用、堆栈跟踪、内存分配等。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
众所周知,Java编译后的Jar包和Class文件,可以轻而易举的使用反编译工具(如JD-GUI)进行反编译,拿到源码。为了保护自己发布的Jar包和Class文件,采用的方式大多是混淆方式,这种方式对于Class文件的加密是不彻底的,还是能够通过分析得出核心算法。本工具是采用jvmti方式对Class文件进行加密,使用C++生成加密和解密库,先用加密库对Jar包进行加密,将加密后的Jar包及解密库文件发布出去,执行时候需要JVM引入解密库文件,解密后执行。c++的.dll文件和.so文件的破解难度是很大的,这就能有效的保护软件和代码的知识产权. 使用方法: 1.打开windows命令行(运行=>cmd=>回车),在命令行 进入 EncryptJar目录 2.执行 java -jar encrypt.jar 3.输入h,然后回车,可以看到帮助菜单 4.输入3,然后按回车键,进入加入jar文件功能 5.输入要加密的jar文件的路径 6.提示输入秘钥(key)的时候,直接回车,不要输入任何字符(否则后面classhook将不可解密加密后的jar包) 7.输入目标路径(加密后的jar文件路径,此处要注意:jar文件名要保持相同,将加密后的文件保存到不同的目录) 8.将加密后的jar包,替换原来的没有加密的jar包,与要发布的程序一起进行发布.(一般替换lib目录下对应的jar包即可) 9.加密后的jar包运行方法: windows下: 拷贝libClassHook.dll文件到程序的根目录(通常为要执行的jar程序的根目录) 使用以下命令启动程序: java -agentlib:libClassHook -jar xxxxxxxxxxx.jar 则在运行过程会自动进行解密操作(解密过程是运行过程用c++的dll进行解密的,可以有效防止破解class文件) 如果执行过程报错,可将程序根目录添加到环境变量path去 Linux下: 拷贝libClassHook.so到程序的根目录(通常为要执行的jar程序的根目录) 使用以下命令启动程序: java -agentlib:ClassHook -jar xxxxxxxxxxx.jar (这里要删除掉lib,linux系统下会自动补全) 则在运行过程会自动进行解密操作(解密过程是运行过程用c++的dll进行解密的,可以有效防止破解class文件) 如果执行过程报错,可以在程序根目录下执行以下语句:export LD_LIBRARY_PATH=`pwd`:$LD_LIBRARY_PATH 或将libClassHook.so 拷贝到/usr/lib目录去。 支持操作系统:加密请在windows64位系统并安装了64位jdk环境下进行。 需要解密运行的程序支持LINUX(64位)和windows(64位)安装了JDK1.8以上的系统。 测试程序: (t_lib目录下的jar包为经过加密的jar包) java -agentlib:libClassHook -jar test.jar
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值