js 加密 java解密_JS加密JAVA解密实现两个值相同

首先附上JS代码,文件路径在不同的环境下配置实现过程中修改相应的位置。

//加密

//str 是想加密的字符串

//pwd 是key

function encrypt(str, pwd) {

if (pwd == null || pwd.length <= 0) {

alert("Please enter a password with which to encrypt the message.");

return null;

}

var prand = "";

for (var i = 0; i < pwd.length; i++) {

prand += pwd.charCodeAt(i).toString();

}

var sPos = Math.floor(prand.length / 5);

var mult = parseInt(prand.charAt(sPos) + prand.charAt(sPos * 2) + prand.charAt(sPos * 3) + prand.charAt(sPos * 4) + prand.charAt(sPos * 5));

var incr = Math.ceil(pwd.length / 2);

var modu = Math.pow(2, 31) - 1;

if (mult < 2) {

alert("Algorithm cannot find a suitable hash. Please choose a different password. Possible considerations are to choose a more complex or longer password.");

return null;

}

var salt = Math.round(Math.random() * 1000000000) % 100000000;

prand += salt;

while (prand.length > 10) {

prand = (parseInt(prand.substring(0, 10)) + parseInt(prand.substring(10, prand.length))).toString();

}

prand = (mult * prand + incr) % modu;

var enc_chr = "";

var enc_str = "";

for (var i = 0; i < str.length; i++) {

enc_chr = parseInt(str.charCodeAt(i) ^ Math.floor((prand / modu) * 255));

if (enc_chr < 16) {

enc_str += "0" + enc_chr.toString(16);

} else {

enc_str += enc_chr.toString(16);

}

prand = (mult * prand + incr) % modu;

}

salt = salt.toString(16);

while (salt.length < 8) {

salt = "0" + salt;

}

enc_str += salt;

return enc_str;

}

//解密实现

function decrypt(str, pwd) {

if (str == null || str.length < 8) {

alert("A salt value could not be extracted from the encrypted message because it's length is too short. The message cannot be decrypted.");

return;

}

if (pwd == null || pwd.length <= 0) {

alert("Please enter a password with which to decrypt the message.");

return;

}

var prand = "";

for (var i = 0; i < pwd.length; i++) {

prand += pwd.charCodeAt(i).toString();

}

var sPos = Math.floor(prand.length / 5);

var mult = parseInt(prand.charAt(sPos) + prand.charAt(sPos * 2) + prand.charAt(sPos * 3) + prand.charAt(sPos * 4) + prand.charAt(sPos * 5));

var incr = Math.round(pwd.length / 2);

var modu = Math.pow(2, 31) - 1;

var salt = parseInt(str.substring(str.length - 8, str.length), 16);

str = str.substring(0, str.length - 8);

prand += salt;

while (prand.length > 10) {

prand = (parseInt(prand.substring(0, 10)) + parseInt(prand.substring(10, prand.length))).toString();

}

prand = (mult * prand + incr) % modu;

var enc_chr = "";

var enc_str = "";

for (var i = 0; i < str.length; i += 2) {

enc_chr = parseInt(parseInt(str.substring(i, i + 2), 16) ^ Math.floor((prand / modu) * 255));

enc_str += String.fromCharCode(enc_chr);

prand = (mult * prand + incr) % modu;

}

return enc_str;

}Java调用ScriptEngineManager进行JS角本的解析。对应的JAVA代码如下:

import java.io.BufferedReader;

import java.io.File;

import java.io.FileInputStream;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.net.URL;

import java.net.URLDecoder;

import javax.script.ScriptEngineManager;

import com.sun.script.javascript.RhinoScriptEngine;

/**

* * Copyright (C): http://www.html580.com

*

* Description:

*

*

* @author dengzhifeng 280160522@qq.com

*/

public class DesUtils {

static private DesUtils desUtils;

public static String key = "html580.com";

public static String path = "/WEB-INF/views/js/des.js";

ScriptEngineManager engineManager;

RhinoScriptEngine engine;

public DesUtils() {

URL url = getClass().getResource("/");

try {

String file = (URLDecoder.decode(url.getPath(),"utf-8")+"../views/js/des.js").replaceAll("%20", " ");

String content = readFile(new File(file));

engineManager = new ScriptEngineManager();

engine = (RhinoScriptEngine)engineManager.getEngineByName("javascript");

engine.eval(content);

} catch (Exception e) {

e.printStackTrace();

}

}

static public DesUtils getInstance() {

synchronized (DesUtils.class) {

if (desUtils == null)

desUtils = new DesUtils();

}

return desUtils;

}

public String decrypt(String value) {

try {

Object pwd=engine.invokeFunction("decrypt", value ,key);

return pwd.toString();

} catch (Exception e) {

e.printStackTrace();

}

return "";

}

public String encrypt(String value) {

try {

Object pwd=engine.invokeFunction("encrypt", value ,key);

return pwd.toString();

} catch (Exception e) {

e.printStackTrace();

}

return "";

}

public static void main(String<> args) {

String e = DesUtils.getInstance().encrypt("test") ;

System.out.println("pwd=" + e );

System.out.println("pwd=" + DesUtils.getInstance().decrypt( e ));

}

/**

* 读取文件内容

*/

public static String readFile(File file) {

String content = "";

InputStream is = null;

try {

is = new FileInputStream(file);

BufferedReader reader = new BufferedReader(new InputStreamReader(

is, "UTF-8"));

String line = null;

while ((line = reader.readLine()) != null) {

String str = line.trim() ;

content += str + "\n" ;

}

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

is.close();

} catch (Exception e) {

}

}

return content;

}

}前端JS调用

后端Java调用参加上面JAVA写法。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答关于Java实现MD5加密解密的问题。 Java提供了MessageDigest类来实现MD5加密,可以通过以下代码实现: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class MD5Util { /** * 对字符串进行MD5加密 * @param data 需要加密的字符串 * @return 加密后的字符串 */ public static String encrypt(String data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(data.getBytes()); return Base64.getEncoder().encodeToString(bytes); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } /** * 对MD5加密后的字符串进行解密 * @param data 加密后的字符串 * @return 解密后的字符串 */ public static String decrypt(String data) { throw new UnsupportedOperationException("不支持MD5解密"); } } ``` 上述代码中,`encrypt`方法用于实现MD5加密,参数为需要加密的字符串,返回加密后的字符串。`decrypt`方法用于实现MD5加密后的字符串的解密,但是由于MD5是不可逆的加密算法,所以我们无法进行解密,因此在该方法中直接抛出了`UnsupportedOperationException`异常。 使用示例: ```java public class Main { public static void main(String[] args) { String password = "123456"; String encryptedPassword = MD5Util.encrypt(password); System.out.println("加密后的密码:" + encryptedPassword); } } ``` 输出结果: ``` 加密后的密码:MTIzNDU2Nzg5MDM0NTY3OA== ``` 可以看到,加密后的密码是一串Base64编码的字符串。如果需要将其转换为16进制字符串,可以使用以下代码: ```java import java.math.BigInteger; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Base64; public class MD5Util { /** * 对字符串进行MD5加密 * @param data 需要加密的字符串 * @return 加密后的字符串 */ public static String encrypt(String data) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bytes = md5.digest(data.getBytes()); return new BigInteger(1, bytes).toString(16); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return null; } } /** * 对MD5加密后的字符串进行解密 * @param data 加密后的字符串 * @return 解密后的字符串 */ public static String decrypt(String data) { throw new UnsupportedOperationException("不支持MD5解密"); } } ``` 这样输出的加密后的密码就是16进制的字符串了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值