http://blog.csdn.net/xzyxuanyuan/article/details/8062887

JDK1.6版添加了新的ScriptEngine类,允许用户直接执行js代码。

在Java中直接调用js代码

不能调用浏览器中定义的js函数,会抛出异常提示ReferenceError: “alert” is not defined。

 
package com.sinaapp.manjushri; 
import javax.script.ScriptEngine; 
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;   /**  * 直接调用js代码  */
public class ScriptEngineTest {    
public static void main(String[] args) { 
  ScriptEngineManager manager = new ScriptEngineManager();
  ScriptEngine engine = manager.getEngineByName("javascript");
     try{    

          engine.eval("var a=3; var b=4;print (a+b);");

         // engine.eval("alert(\"js alert\");");    // 不能调用浏览器中定义的js函数 // 错误,会抛出alert引用不存在的异常
 }catch(ScriptException e){

 e.printStackTrace();
}
}  
}

输出结果:7

在Java中绑定js变量

在调用engine.get(key);时,如果key没有定义,则返回null

 
package com.sinaapp.manjushri;   

import javax.script.Bindings; 

import javax.script.ScriptContext; 

import javax.script.ScriptEngine; 

import javax.script.ScriptEngineManager; 

import javax.script.ScriptException;   

public class ScriptEngineTest2 {  

public static void main(String[] args) {
ScriptEngineManager manager = new ScriptEngineManager();
ScriptEngine engine = manager.getEngineByName("javascript");
engine.put("a", 4);
engine.put("b", 3);
Bindings bindings = engine.getBindings(ScriptContext.ENGINE_SCOPE);
try {
// 只能为Double,使用Float和Integer会抛出异常 Double result = (Double) engine.eval("a+b"); System.out.println("result = " + result);
engine.eval("c=a+b"); Double c = (Double)engine.get("c"); System.out.println("c = " + c); } catch (ScriptException e) {
e.printStackTrace(); } } }

输出:
result = 7.0
c = 7.0

在Java中调用js文件中的function,传入调用参数,并获取返回值

js文件中的merge函数将两个参数a,b相加,并返回c。

 
// expression.js 
function merge(a, b) { 
 c = a * b; 
 return c; 
}

在Java代码中读取js文件,并参数两个参数,然后回去返回值。

 
package com.sinaapp.manjushri;   

import java.io.FileReader;
  import javax.script.Invocable; import javax.script.ScriptEngine; import javax.script.ScriptEngineManager;  
/** * Java调用并执行js文件,传递参数,并活动返回值 * * @author manjushri */ public class ScriptEngineTest {   public static void main(String[] args) throws Exception {
ScriptEngineManager manager = new ScriptEngineManager();
ScriptEngine engine = manager.getEngineByName("javascript");   String jsFileName = "expression.js"; // 读取js文件 FileReader reader = new FileReader(jsFileName); // 执行指定脚本
engine.eval(reader); if(engine instanceof Invocable) {
Invocable invoke = (Invocable)engine; // 调用merge方法,并传入两个参数 // c = merge(2, 3); Double c = (Double)invoke.invokeFunction("merge", 2, 3); System.out.println("c = " + c);
} reader.close(); }
}

输出结果:
c = 5.0


java调用脚本语言笔记(jython,jruby,groovy)

有两种方法
1.java se 6以后实现了jsr 223规范
java代码:

  1. ScriptEngineManager factory = new ScriptEngineManager();
  2. ScriptEngineManager scriptEngine = factory.getEngineByName("javascript");//或者"js"
  3. scriptEngine.eval(code);//执行一段脚本,code是js代码

很方便调用脚本

2.可以使用脚本语方本身提供的与java的集成手段

jython集成
使用jsr223:
前提下载jython的包,已实现jsr223
(建议在官网上下载,在安装目录下有jython.jar,http://repo2.maven.org/maven2/org/python/jython/2.5.0/ 这里也有,但是这个包里没有jsr223的实现,看包下存不存在org.python.jsr223)

  1. ScriptEngineManager factory = new ScriptEngineManager();
  2. ScriptEngineManager scriptEngine = factory.getEngineByName("python");//或者"jython"
  3. scriptEngine.eval(code);

使用PythonInterpreter,可以调用exec(String code)方法:

  1. PythonInterpreter interpreter = new PythonInterpreter();
  2. interpreter.exec(code);

访问数据库
使用jdbc:

  1. from oracle.jdbc.driver import OracleDriver
  2. from java.sql import DriverManager
  3. username = 'hr'
  4. password = '123456'
  5. url = 'jdbc:oracle:thin:@localhost:1521:XE'
  6. driver = OracleDriver()
  7. DriverManager.registerDriver(driver)
  8. conn = DriverManager.getConnection(url, username, password)
  9. stmt = conn.createStatement()
  10. sql = "select salary from EMPLOYEES t where t.salary<2300"
  11. rs = stmt.executeQuery(sql)
  12. while (rs.next()):
  13. print rs.getInt('salary')
  14. rs.close()
  15. stmt.close()

结果:
2200
2100
2200

使用zxJDBC :

  1. from com.ziclix.python.sql import zxJDBC
  2. url = 'jdbc:oracle:thin:@localhost:1521:XE'
  3. username = 'hr'
  4. password = '123456'
  5. driverName = 'oracle.jdbc.driver.OracleDriver'
  6. mysqlConn = zxJDBC.connect(url,username, password,driverName)
  7. cursor = mysqlConn.cursor()
  8. cursor.execute("select last_name from EMPLOYEES t where t.salary<2300");
  9. #print cursor.fetchone()
  10. list = cursor.fetchall()
  11. for record in list:
  12. print "name:"+record[0]
  13. #print cursor.description[0]
  14. #print cursor.description[1]

结果:
name:麦克
name:Olson
name:Philtanker

从数据库中查出的中文内容正常的。
而在代码里面的中文全部是乱码或抛异常,未解决。

与jruby集成
使用jsr223:Java代码

  1. ScriptEngineManager factory = new ScriptEngineManager();
  2. ScriptEngineManager scriptEngine = factory.getEngineByName("jruby");//或者"ruby"
  3. scriptEngine.eval(code);

访问数据库

Ruby代码

  1. require 'java'
  2. module JavaLang
  3. include_package "java.lang"
  4. end
  5. module JavaSql
  6. include_package 'java.sql'
  7. end
  8. begin
  9. username = 'hr'
  10. password = '123456'
  11. url = 'jdbc:oracle:thin:@localhost:1521:XE'
  12. driverName = 'oracle.jdbc.driver.OracleDriver'
  13. JavaLang::Class.forName(driverName).newInstance
  14. conn = JavaSql::DriverManager.getConnection(url, username, password)
  15. stmt = conn.createStatement
  16. sql = "select last_name from EMPLOYEES t where t.salary<2300"
  17. rs = stmt.executeQuery(sql)
  18. while (rs.next) do
  19. puts "名字:"+rs.getString("last_name")
  20. end
  21. rs.close
  22. stmt.close
  23. conn.close()
  24. rescue JavaLang::ClassNotFoundException
  25. puts "ClassNotFoundException"
  26. rescue JavaSql::SQLException
  27. puts "SQLException"
  28. end

结果:
名字:楹﹀厠
名字:Olson
名字:Philtanker

从数据库中查出的中文内容为乱码的。
而在代码里面的中文正常。

与groovy集成
使用jsr223:

Java代码

  1. ScriptEngineManager factory = new ScriptEngineManager();
  2. ScriptEngineManager scriptEngine = factory.getEngineByName("groovy");//或者"Groovy"
  3. scriptEngine.eval(code);

使用GroovyShell:

Java代码

  1. GroovyShell shell = new GroovyShell();
  2. Script script = shell.parse(code);
  3. Object result = script.run();

访问数据库

  1. import groovy.sql.Sql
  2. def username = 'hr'
  3. def password = '123456'
  4. def url = 'jdbc:oracle:thin:@localhost:1521:XE'
  5. def driverName = 'oracle.jdbc.driver.OracleDriver'
  6. def sql = Sql.newInstance(url, username, password, driverName)
  7. sql.eachRow("select last_name from EMPLOYEES t where t.salary<2300") {
  8. println "名字:${it.last_name}"
  9. }

结果:
名字:麦克
名字:Olson
名字:Philtanker

在使用groovy过程中碰到了一个异常
Exception in thread "main" java.lang.VerifyError: (class: groovy/runtime/metaclass/java/util/ArrayListMetaClass, method: super$2$invokeMethod signature: (Ljava/lang/Class;Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;ZZ)Ljava/lang/Object;) Illegal use of nonvirtual function call
这个异常解决花了很长时间
是因为在原来项目中存在json-lib-2.1.jar(有可能名称为json-lib-2.1-jdk15.jar),这个包是用来处理json的,与groovy1.7.5存在冲突,更新为json-lib-2.3.jar即可
(json-lib里有一些groovy运行时处理的内容)

在Java中直接调用js代码(转载)的更多相关文章

  1. 在Java中直接调用js代码

    JDK1.6版添加了新的ScriptEngine类,允许用户直接执行js代码. 在Java中直接调用js代码 不能调用浏览器中定义的js函数,会抛出异常提示ReferenceError: “alert ...

  2. android 中webview调用js

    1.android中利用webview调用网页上的js代码. Android 中可以通过webview来实现和js的交互,在程序中调用js代码,只需要将webview控件的支持js的属性设置为true ...

  3. iOS中UIWebView执行JS代码(UIWebView)

    iOS中UIWebView执行JS代码(UIWebView) 有时候iOS开发过程中使用 UIWebView 经常需要加载网页,但是网页中有很多明显的标记让人一眼就能看出来是加载的网页,而我们又不想被 ...

  4. Java中常用的设计模式代码与理解

    Java中常用的设计模式代码与理解 一.单例模式 1.饿汉式 (太饿了,类加载的时候就创建实例) /** * 饿汉式单例模式 */ public class HungrySingleInstance ...

  5. Java&Selenium自动化测试调用JS实现单击

    Java&Selenium自动化测试调用JS实现单击 /* * the method of invoking js to do something * * @author davieyang ...

  6. 在wxml中直接写js代码(wxs)

    我们在h5开发中,很多时候要在html中写到js代码,这个很容易实现.但是在微信小程序开发中,是不能直接在wxml中写js代码的,因此就有了wxs.在wxml中用wxs代码,有以下几种方式(在小程序文 ...

  7. Java中如何调用静态方法

    Java中如何调用静态方法: 1.如果想要调用的静态方法在本类中,可直接使用方法名调用 2.调用其他类的静态方法,可使用类名.方法名调用 关于静态方法能被什么调用 1.实例方法 2.静态发放

  8. <a>标签中的href如何调用js代码

    在HTML中,<a>标签的href属性用于指定超链接的目标的URL.在所有浏览器中,链接的默认外观是: 未被访问的链接带有下划线而且是蓝色的 已被访问的链接带有下划线而且是紫色的 活动链接 ...

  9. java调用js代码

    jdk8里使用脚本引擎调用js 1.定义一个js方法: function getRouteInfo(province){ //注意,参数不要带var..在java里执行会报错.. if (provin ...

随机推荐

  1. 安全性之DDOS的防护技巧

    网站的信息安全越来越重要,结合自己1年多的互联网金融方面的安全防护做些总结. 后续希望研究并运用: 1.加密算法 2.DDOS的防护技巧 3.跨站点请求伪造 4.XSS攻击 5.文件上传漏洞 6.信息 ...

  2. 将doc文件批量转为pdf文件

    需要将不少doc文件转为pdf,WPS带有这种功能,但是鼠标点击次数太多以后整个人都变得很烦躁 用了一下午去搜这方面的工具软件,找到若干.有一些免费,有一些试用的,但总归就找到一个真正能用,虽说生成的 ...

  3. centos安装firefox flash插件

    centos下的firefox flash插件默认不是最新版的,安装过程如下: 将安装地址添加到repolist中 sudo yum -y install http://linuxdownload.a ...

  4. atitit.技术选型方法总结为什么java就是比.net有前途

    atitit.技术选型方法总结为什么java就是比.net有前途 #----按照不同的需要有不铜的法... 一般有开发效率,稳定性上的需要.. 作者 老哇的爪子 Attilax 艾龙,  EMAIL: ...

  5. atitit.编程语言 程序语言 的 工具性 和 材料性 双重性 and 语言无关性 本质

    atitit.编程语言 程序语言 的 工具性 和 材料性 双重性 and 语言无关性 本质 #---语言的 工具和材料双重性 有的人说语言是个工具,有的人说语言是个材料..实际上语言同时属于两个属性. ...

  6. Leetcode 205 Isomorphic Strings 字符串处理

    判断两个字符串是否同构 hs,ht就是每个字符出现的顺序 "egg" 与"add"的数字都是122 "foo"是122, 而"ba ...

  7. 建立一个名叫Cat的类

    //属性 成员变量 String name; int age; String color; //方法 函数 成员函数 void name() { System.out.println("名字 ...

  8. hdu 1864 01背包 最大报销额

    http://acm.hdu.edu.cn/showproblem.php?pid=1864 New~ 欢迎“热爱编程”的高考少年——报考杭州电子科技大学计算机学院关于2015年杭电ACM暑期集训队的 ...

  9. hdu 1548 楼梯 bfs或最短路 dijkstra

    http://acm.hdu.edu.cn/showproblem.php?pid=1548 Online Judge Online Exercise Online Teaching Online C ...

  10. Cocos2dx.3x入门三部曲-Hello Game项目解析(三)

    一.前提: 完成Hello Game项目的创建编译. 具体参考:Cocos2dx.3x_Hello Game项目创建篇 二.本篇目标: l  分析proj.win32工程的主要构成 l  分析proj ...