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代码(转载)

    http://blog.csdn.net/xzyxuanyuan/article/details/8062887 JDK1.6版添加了新的ScriptEngine类,允许用户直接执行js代码. 在Ja ...

  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. 获取iframe中的元素

    父窗口中获取iframe中的元素 var ifr = document.getElementById('suggustion').contentWindow.document.body; 在ifram ...

  2. jquery ajax/post/get 传参数给 mvc的action

    jquery ajax/post/get 传参数给 mvc的action1.ActionResult Test1    2.View  Test1.aspx3.ajax page4.MetaObjec ...

  3. windows_phone指定时间后执行函数

    开发windows phone 应用程序时需要在一段指定的时间后执行某些函数,于是乎想到了通过DispatcherTimer类来实现,再在.Tick后面添加自己想要的事件 DispatcherTime ...

  4. 企业级账号更新app

    企业级账号 版本更新总结       参考:http://jingyan.baidu.com/article/a3aad71aa5fbfbb1fb0096b1.html 1.打包ipa,plist工具 ...

  5. 浅谈ASP.NET报表控件

    OWC似乎使用者居多,但看见有网友在帖中抱怨OWC在使用时需要许可证书,于是将其排除,我可不想BOSS在看报表时弹出一个“没有许可证书”的窗口. 接着找到了ComponentOne的Web chart ...

  6. Javacript中(function(){})() 与 (function(){}()) 区别 {转}

    这个问题可以从不同的角度来看,但从结果上来说 :他们是一样的.首先,如果从AST(抽象语法树)的角度来看,两者的AST是一模一样的,最终结果都是一次函数调用.因此,就解析器产生的结果论而言,两者是没有 ...

  7. 如何使用CSS3创建一个漂亮的图标

    演示 下载 今天,我想展示给你一个巧妙的花招.我们将创建一个纯CSS3文本图标.更让人震惊的是,这效果将只需要一个HTML元素. 游戏的计划 创建一个矩形盒子 设置圆角 使用伪类元素创建一个卷角效果 ...

  8. iOS终端查看.a文件是否能在模拟器上运行

    复制文件路径进去: 红色框框里面没有x86所以模拟器运行会报错

  9. sparksql链接mysql

    1.在IDEA上建立一个sparksql_mysql的scala对象. 2.连接mysql的代码如下 import java.sql.{DriverManager, PreparedStatement ...

  10. iOS多线程的初步研究(七)-- dispatch对象

    谈起iOS的dispatch(正式称谓是Grand Central Dispatch或GCD),不得不说这又是iOS(包括MacOSX)平台的创新,优缺点这里不讨论,只有当你使用时才能真正体会到.我们 ...