使用graalvm 进行node 与java 代码的调用

参考使用

演示的是一个jdbc的连接

var url = "jdbc:mysql://localhost:2881?useSSL=false";
var username = "root";
var password = "";
Java.addToClasspath("hashids-1.0.3.jar")  // 添加jar 
var conn =null;
var rs =null;
var st = null;
try{
     conn = java.sql.DriverManager.getConnection(url, username, password)
     st = conn.createStatement();
     var hashids = new org.hashids.Hashids("this is my salt");
     var id = hashids.encode(1, 2, 3);
     var numbers = hashids.decode(id);
     console.log(numbers,id)
     var sql = "select  * from test.appdemo";
     rs = st.executeQuery(sql);
     while (rs.next()) {
        var name = rs.getString(1);
        console.log(name)
     }
}
finally{
    if(conn!=null){
        conn.close();
    }
    if(rs!=null){
        rs.close();
    }
}
 
 
const Properties = java.util.Properties;
const properties = new Properties();
 
properties.setProperty("name","dlaong")
 
console.log(properties.getProperty("name"))

运行

node --jvm  --vm.classpath=$PWD/mysql-connector-java-5.1.47.jar  app.js

注意对于spi 依赖的jar 需要通过启动时指定,不然jar 加载会有问题的。。。。,其他可以运行时获取的就没有问题
同时对于java 类型,我们可以基于Java.type 导入,也可以类似java 包的模式

说明

使用graalvm 的node 与java 进行互调用的好处很明显代码是同步的,我们不要处理一堆复杂的callback(而且简单高效。。。)
比如我们基于此就可以灵活的扩展cube.js 的jdbc driver

参考资料

https://www.graalvm.org/reference-manual/js/JavaInteroperability/
https://github.com/joeferner/node-java
https://www.npmjs.com/package/java

原文地址:https://www.cnblogs.com/rongfengliang/p/15580970.html