談起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
