服務端調用js:javax.script


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

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM