首页 > 编程语言 >java 脚本使用不同版本jdk说明

java 脚本使用不同版本jdk说明

时间:2024-10-23 16:21:22浏览次数:3  
标签:Object java String jdk script JavaScript JDK result 版本

目录

1. 使用ScriptEngine执行JavaScript

2. Nashorn(JDK 8及以上)和工具类

3.GraalVM(JDK 11及以上)

总结


在Java中,运行或执行JavaScript脚本有几种方式,其中最常用的是通过Java内置的JavaScript引擎(Nashorn或者Rhino)来执行JavaScript代码。下面介绍几种实现方式。

1. 使用ScriptEngine执行JavaScript

Java 在 JDK 6 中引入了javax.script包,这个包允许你在 Java 中使用脚本语言,包括 JavaScript。到 JDK 8 时,Nashorn JavaScript 引擎取代了早期的 Rhino 引擎(jdk6以下版本)。

示例代码:

import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;

public class JavaScriptExample {
    public static void main(String[] args) {
        // 创建ScriptEngineManager
        ScriptEngineManager manager = new ScriptEngineManager();
        
        // 获取JavaScript引擎
        ScriptEngine engine = manager.getEngineByName("JavaScript");
        
        // 要执行的JavaScript代码
        String script = "var x = 10; var y = 20; x + y;";
        
        // 执行JavaScript代码
        try {
            Object result = engine.eval(script);
            System.out.println("JavaScript结果: " + result);
        } catch (ScriptException e) {
            e.printStackTrace();
        }
    }
}


输出:

JavaScript结果: 30


2. Nashorn(JDK 8及以上)和工具类

在Java 8中,Nashorn引擎是默认的JavaScript引擎。Nashorn的性能比Rhino引擎更好,并且提供了更好的ES5标准的支持。
JDK 8 默认使用 Nashorn。如果你在 JDK 11 或更高版本,Nashorn 可能被删除,推荐使用其他方式(如 GraalVM)。

基于目前大多项目使用jdk8,给出如下详细工具类可供使用。

import javax.script.Invocable;
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;

public class ScriptUtil {

    private final ScriptEngine engine;

    public ScriptUtil() {
        ScriptEngineManager manager = new ScriptEngineManager();
        // 获取Nashorn引擎实例
        engine = manager.getEngineByName("nashorn");

    }

    // 执行任意JavaScript代码
    public Object executeScript(String script) throws ScriptException {
        return engine.eval(script);
    }

    // 执行带参数的JavaScript代码
    public Object executeScriptWithBindings(String script, Object... args) throws ScriptException {
        // 设置脚本中的参数
        for (int i = 0; i < args.length; i++) {
            engine.put("arg" + i, args[i]);
        }
        return engine.eval(script);
    }

    // 调用JavaScript中的函数
    public Object callFunction(String script, String functionName, Object... args) throws ScriptException, NoSuchMethodException {
        // 先执行包含函数定义的脚本
        engine.eval(script);
        // 获取Invocable实例
        Invocable invocable = (Invocable) engine;
        // 调用指定的JavaScript函数
        return invocable.invokeFunction(functionName, args);
    }

    public static void main(String[] args) {
        try {
            //JavaScriptExecutor executor = new JavaScriptExecutor();
            ScriptUtil xbScriptUtil = new ScriptUtil();
            // 执行简单的JavaScript代码
            String script = "print('Hello, World!');";
            Object object = xbScriptUtil.executeScript(script);
            System.out.println(object);
            // 执行带参数的JavaScript代码
            String scriptWithParams = "var result = arg0 + arg1; result;";
            Object result = xbScriptUtil.executeScriptWithBindings(scriptWithParams, 5, 3);
            System.out.println("Result with bindings: " + result);

            // 调用JavaScript中的函数
            String functionScript = "function add(a, b) { return a + b; }";
            Object functionResult = xbScriptUtil.callFunction(functionScript, "add", 5, 3);
            System.out.println("Function result: " + functionResult.toString());

            String functionScript1 = "function calcData(val) { var val2='455'; return val+val2; }";
            //传入字符串
            Object functionResult1 = xbScriptUtil.callFunction(functionScript1, "calcData", "222");
            System.out.println("Function1 result: " + functionResult1.toString());

            String functionScript2 = "function calcData(obj) { var val2=obj.getData('11','22'); return val2; }";
            // 传入对象参数,调用函数
            Object functionResult2 = xbScriptUtil.callFunction(functionScript2, "calcData", xbScriptUtil);
            System.out.println("Function2 result: " + functionResult2.toString());
            // System.out.println(xbScriptUtil.getData("1","2"));

        } catch (ScriptException | NoSuchMethodException e) {
            e.printStackTrace();
        }
    }

    public String getData(String channelId, String pointId) {
        return channelId + "#" + pointId;
    }
}

输出:

Hello, World!
null
Result with bindings: 8.0
Function result: 8.0
Function1 result: 222455
Function2 result: 11#22

3.GraalVM(JDK 11及以上)

从JDK 11开始,Oracle现代允许删除了Nashorn,引入了GraalVM多语言支持的更完整的方案。GraalVM作为在Java中高效执行JavaScript、Python、R等多种语言。

使用GraalVM执行JavaScript
需要使用GraalVM的polyglotAPI,下面是如何通过GraalVM执行JavaScript代码的示例。

示例代码:

<dependency>
    <groupId>org.graalvm.js</groupId>
    <artifactId>js</artifactId>
    <version>23.0.4</version> <!-- 请使用最新版本 -->
</dependency>
import org.graalvm.polyglot.Context;
import org.graalvm.polyglot.Value;

public class GraalVMExample {
    public static void main(String[] args) {
        // 创建GraalVM上下文
        try (Context context = Context.create()) {
            // 执行JavaScript代码
            Value result = context.eval("js", "var x = 10; var y = 20; x + y;");
            System.out.println("JavaScript结果: " + result.asInt());
        }
    }
}

输出:
JavaScript结果: 30

总结

ScriptEngine (Nashorn/Rhino):适用于JDK 8及以下版本,适合简单的JavaScript脚本执行。
GraalVM:推荐在JDK 11及以上使用,支持更多语言,并且性能更优。
如果你在Java项目中需要集成或执行大量复杂的JavaScript代码,推荐使用GraalVM。如果只需要运行少量简单的JavaScript代码,可以继续使用ScriptEngine。

标签:Object,java,String,jdk,script,JavaScript,JDK,result,版本
From: https://blog.csdn.net/h4241778/article/details/143186993

相关文章

  • java基于springboot的中药材进存销管理系统(源码+vue+部署文档+前后端分离等)
    收藏关注不迷路!!......
  • Javascript数据类型及转换
    Javascript代码引入方式同HTML相似分为行内式、内嵌式、外链式    1.行内式:行内式是将JavaScript代码作为HTML标签的属性值使用。<ahref="javascript:alert('Hello');">test</a>代码杂乱容易混淆不推荐    2.嵌入式:也称为内嵌式,使用<script>标签包......
  • 大厂面试Java工程师为什么总爱问Spring相关问题?
    因为Spring框架自从诞生以来就一直备受开发者青睐,很多Java程序员实质上就是Spring程序员,它涵盖了Spring、Springboot、SpringCloud等诸多解决方案,一般我们都会统称为Spring全家桶!出于Spring框架在Java开发者心中中的统治地位,所以不管是面试还是工作,Spring都是绕不开的重点也是......
  • Java程序员换工作有必要刻意在金三银四或者金九银十吗?
    Java面试谈到Java面试,相信大家第一时间脑子里想到的词肯定是金三银四,金九银十。好像大家的潜意识里做Java开发的都得在这个时候才能出去面试,跳槽成功率才高!但LZ不这么认为,LZ觉得我们做技术的一生中会遇到很多大大小小的面试,金三银四(金九银十)只是机会比平时多一些,但也未必每个......
  • 小结---安装nvm解决node版本不兼容的问题(node版本切换)
    1、卸载node(如果电脑上没有安装node略过即可)在控制面板找到node.js卸载并将c盘的node文件等全部删除最后打开高级设置,找到高级系统设置将配置的node字段全部删除 2、nvm安装官网下载nvm包https://github.com/coreybutler/nvm-windows/releases2.安装n......
  • Java异常的处理:
    Java异常分成两个部分:“抛出异常”和"捕获异常"    Java异常处理机制是:将可能发生异常的语句写入try{}中,当try语句中发生异常时,系统会生成一个异常对象,该异常对象会提交给Java运行时环境,这个过程称为“抛出异常”。    当出现异常时,会去匹配可以处理异常的c......
  • 对接Java所谓的DES加解密
       众所周知,Java的一些封装方法中默认编码方式和实现略有不同与c#, 以及基础类型整型默认范围是有符号的,可以是负数,但是c#中默认是有符号的,不能为负数.    两者在对接的时候,涉及到一些编码方式,以及加解密时问题就来了,网上铺天盖地的各种兼容写法实际上手之后很难凑......
  • Java综合测试题精选
    一,填空题Javaapplication中的主类需要包含main方法,main方法的返回类型是void。Java正则表达式中,通配符\w等同于大小写字母,数字和下划线。System.out.println(true?false:true==true?false:true);输出结果为false。在Java中对于基本类型变量,Java是传值的副本;对于......
  • java8 stream详细理解
    stream简介Java8中的Stream是对集合(Collection)对象功能的增强,它专注于对集合对象进行各种非常便利、高效的聚合操作(aggregateoperation),或者大批量数据操作(bulkdataoperation)。StreamAPI借助于Lambda表达式,极大的提高编程效率和程序可读性。stream接口方法......
  • (分享源码)计算机毕业设计必看必学 上万套实战教程手把手教学JAVA、PHP,node.js,C++、pyth
    摘 要大数据时代下,数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求,利用互联网服务于其他行业,促进生产,已经是成为一种势不可挡的趋势。在网络小说的要求下,开发一款整体式结构的小说网站,将复杂的系统进行拆分,能够实现对需求的变化快速响应、系统稳定性的保......