談起js在服務端的應用,大部分人的第一反應都是node.js。node.js作為一套服務器端的 JavaScript 運行環境,有自己的獨到之處,但不是所有的地方都需要使用它。
例如在已有的服務端代碼上增加一個業務,而這個業務使用的卻是js編寫。如果用node.js處理的話,會很麻煩。而且另一方面對於很多服務端程序員來說,覺得js的對象模型很奇怪,不太喜歡用js處理問題。
對於上面這種情況,有一種簡單的處理方法:javax.script API
javax.script加入了對部分腳本語言的支持,它的原意是為了針對關於業務在客戶端和服務端中,邏輯相同而語言不同導致實現不同的問題。但是這種處理方法由於前后端的分工和一些缺陷,很少在實際應用中用到。
javax.script
實現起來很簡單。
一:得到一個ScriptEngine對象
ScriptEngineManager maneger = new ScriptEngineManager(); ScriptEngine engine = maneger.getEngineByName("JavaScript");
二:讀js文件
Reader scriptReader = new InputStreamReader( JsInServer.class.getResourceAsStream("js文件"));
三:解析文件
engine.eval(scriptReader);
四:調用js方法,得到的結果以Object對象返回
Object result = invocable.invokeFunction("js方法", js方法參數1, js方法參數2...);
測試例子:
java
import java.io.IOException; import java.io.InputStreamReader; import java.io.Reader; import javax.script.Invocable; import javax.script.ScriptEngine; import javax.script.ScriptEngineManager; import javax.script.ScriptException; public class JsInServer { public static void main(String[] arg) throws IOException { ScriptEngineManager maneger = new ScriptEngineManager(); ScriptEngine engine = maneger.getEngineByName("JavaScript"); Reader scriptReader = new InputStreamReader( JsInServer.class.getResourceAsStream("TestAdd.js")); if (engine != null) { try { // JS引擎解析文件 engine.eval(scriptReader); if (engine instanceof Invocable) { Invocable invocable = (Invocable) engine; // JS引擎調用方法 Object result = invocable.invokeFunction("add", 1, 2); System.out.println("The result is: " + result); } } catch (ScriptException e) { e.printStackTrace(); } catch (NoSuchMethodException e) { e.printStackTrace(); } finally { scriptReader.close(); } } else { System.out.println("ScriptEngine create error!"); } } }
js:
function add(a,b){ println("The first parameter is: " + a); println("The second parameter is: " + b); return a+b; } println("js perform success");
執行結果:
js perform success The first parameter is: 1 The second parameter is: 2 The result is: 3.0