zoukankan      html  css  js  c++  java
  • 服务端调用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
    
  • 相关阅读:
    PhoneGap 3.0 官方 安装 方法
    计算机组成
    软件开发瀑布模型
    国内源码下载地址(转载)
    阿里云ECS 介绍
    云端搭建Linux学习环境 链接https://edu.aliyun.com/article/19 (阿里云ECS服务器 )课堂
    阿里云服务器 ECS 部署lamp:centos+apache+mysql+php安装配置方法 (centos7)
    thinkphp 连接数据库 & 实例化模型操作 (下接thinkphp CURD 操作)/慕课
    PHP实现微信公众平台开发—基础篇
    ThinkPHP3.2.3完整版创建前后台入口文件 http://jingyan.baidu.com/article/7e4409533fc1092fc1e2ef53.html
  • 原文地址:https://www.cnblogs.com/charlexu/p/3424963.html
Copyright © 2011-2022 走看看