Java中如何使用js代码

Java8新JavaScript引擎nashorn

    伴随 Java 8 的发布,Oracle 也一同发布了 Nashorn,它是在 Java 虚拟机上运行 Javascript 语言的一个引擎。Nashorn 的设计是为了替换最初的运行在 JVM 上的项目——被称之为 Rhino(Nashorn 是 rhino 的德语中的词语)。
Nashorn 完全重写和实现,谋求和 Java 的高效的交互性,精准地保证与 JavaScript ECMA 规范的一致性。Nashorn 是第一个达到 100% 遵从 JavaScript 的规范,并且在绝大部分工作量上运行速度是 Rhino 的20倍之多。

  接下来就来介绍一下如何使用吧

 encrypt.js脚本内容:

/*
*功能:对url加密算法(只针对window.location.href跳转,不针对post表单提交及ajax方式)
*算法:对于暴露在浏览器地址栏中的属性值进行加密,如一个属性为agentID=1,
*     若对1加密后为k230101io934jksd32r4,说明如下:
*     前三位为随机数;
*     第四到第五位为要加密字符转换成16进制的位数,
*       如:要加密字符为15转换成16进制为f,位数为1,则第四、五位为01;
*     第六位标识要加密字符为何种字符,0:纯数字,1:字符
*       若是字符和数字的混合,则不加密;
*     从第七位开始为16进制转换后的字符(字母和非数字先转换成asc码);
*     若加密后的字符总位数不足20位,则用随机数补齐到20位,若超出20位,则不加随机数。
*     即加密后总位数至少为20位。
*/
function encode16(str){
    str=str.toLowerCase();
    if (str.match(/^[-+]?\d*$/) == null){//非整数字符,对每一个字符都转换成16进制,然后拼接
        var s=str.split("");
        var temp="";
        for(var i=0;i<s.length;i++){
            s[i]=s[i].charCodeAt();//先转换成Unicode编码
            s[i]=s[i].toString(16);
            temp=temp+s[i];
        }
        return temp+"{"+1;//1代表字符
    }else{//数字直接转换成16进制
        str=parseInt(str).toString(16);
    }
    return str+"{"+0;//0代表纯数字
}
  
  
function produceRandom(n){
    var num=""; 
    for(var i=0;i<n;i++) 
    { 
        num+=Math.floor(Math.random()*10);
    } 
    return num;
}
  
//主加密函数
function encrypt(str){
    var encryptStr="";//最终返回的加密后的字符串
    encryptStr+=produceRandom(3);//产生3位随机数
      
    var temp=encode16(str).split("{");//对要加密的字符转换成16进制
    var numLength=temp[0].length;//转换后的字符长度
    numLength=numLength.toString(16);//字符长度换算成16进制
    if(numLength.length==1){//如果是1,补一个0
        numLength="0"+numLength;
    }else if(numLength.length>2){//转换后的16进制字符长度如果大于2位数,则返回,不支持
        return "";
    }
    encryptStr+=numLength;
      
    if(temp[1]=="0"){
        encryptStr+=0;
    }else if(temp[1]=="1"){
        encryptStr+=1;
    }
      
    encryptStr+=temp[0];
      
    if(encryptStr.length<20){//如果小于20位,补上随机数
        var ran=produceRandom(20-encryptStr.length);
        encryptStr+=ran;
    }
    return encryptStr;
}

 

Java调用encrypt.js脚本的代码:

package com.group.util;
 
import java.io.FileReader;
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
 
public class myTest {
    public static void main(String[] args) {
 
        // 获取脚本引擎
        ScriptEngineManager scriptEngineManager = new ScriptEngineManager();
        ScriptEngine nashorn = scriptEngineManager.getEngineByName("nashorn");
 
        try {
			
            // 读取js文件内容
            nashorn.eval(new FileReader("src/main/webapp/js/encrypt.js"));
			
            //调用js代码,进行参数加密
            Object eval = nashorn.eval("encrypt('" + 1 + "')");
            System.out.println(eval);
        } catch (Exception e) {
            e.printStackTrace();
        }
 
    }
 
}

  

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值