在Java中直接調用js代碼(轉載)

來源:互聯網
上載者:User

標籤:

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代碼:

[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)

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


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

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

訪問資料庫
使用jdbc:

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


 結果:
2200
2100
2200

使用zxJDBC :

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


 結果:
name:麥克
name:Olson
name:Philtanker

從資料庫中查出的中文內容正常的。
而在代碼裡面的中文全部是亂碼或拋異常,未解決。

與jruby整合
使用jsr223:Java代碼

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

 訪問資料庫

Ruby代碼

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


 

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

 

從資料庫中查出的中文內容為亂碼的。
而在代碼裡面的中文正常。

 

與groovy整合
使用jsr223:

Java代碼

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


 使用GroovyShell:

Java代碼

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


訪問資料庫

Groovy代碼

 

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

結果:
名字:麥克
名字: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代碼(轉載)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.