参考使用
演示的是一个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