c利用js解密(js解密方法)

本文目录一览:

js怎么解密,js解密工具js怎么查看这些代码麻烦给解决一下

首先你的加密后的代码有误,无法执行,应将return(c35?String.fromCharCode(c+29):

修改为return(ca?””:e(parseInt(c/a)))+((c=c%a)35?String.fromCharCode(c+29):

c和35之间的部分你没复制出来

这种加密的算法的解密方法很简单

html

body

div id=”test”/div

script type=”text/javascript”

document.getElementById(‘test’).innerHTML = 将需要破解的代码全部复制过来,注意你原来的代码不对,请通过替换先将上面说的那个错误改正

/script

/body

/html

将上面的代码保存成html文件,打开此文件即可看到加密前的内容,由于你的问题解密后是广告语,所以不在此处给出,自己试一下

JS解密eval(function(p,a,c,k,e,d)

把开头的eval替换为alert,然后执行,可以在弹出的对话框里得到解密结果。。。

如何实现用javascript实现rsa加解密

服务端生成公钥与私钥,保存。

客户端在请求到登录页面后,随机生成一字符串。

后此随机字符串作为密钥加密密码,再用从服务端获取到的公钥加密生成的随机字符串

将此两段密文传入服务端,服务端用私钥解出随机字符串,再用此私钥解出加密的密文。这其中有一个关键是解决服务端的公钥,传入客户端,客户端用此公钥加密字符串后,后又能在服务端用私钥解出。

步骤:

服务端的RSA  Java实现:

/** 

 *  

 */  

package com.sunsoft.struts.util;  

  

import java.io.ByteArrayOutputStream;  

import java.io.FileInputStream;  

import java.io.FileOutputStream;  

import java.io.ObjectInputStream;  

import java.io.ObjectOutputStream;  

import java.math.BigInteger;  

import java.security.KeyFactory;  

import java.security.KeyPair;  

import java.security.KeyPairGenerator;  

import java.security.NoSuchAlgorithmException;  

import java.security.PrivateKey;  

import java.security.PublicKey;  

import java.security.SecureRandom;  

import java.security.interfaces.RSAPrivateKey;  

import java.security.interfaces.RSAPublicKey;  

import java.security.spec.InvalidKeySpecException;  

import java.security.spec.RSAPrivateKeySpec;  

import java.security.spec.RSAPublicKeySpec;  

  

import javax.crypto.Cipher;  

  

  

  

/** 

 * RSA 工具类。提供加密,解密,生成密钥对等方法。 

 * 需要到

下载bcprov-jdk14-123.jar。 

 *  

 */  

public class RSAUtil {  

    /** 

     * * 生成密钥对 * 

     *  

     * @return KeyPair * 

     * @throws EncryptException 

     */  

    public static KeyPair generateKeyPair() throws Exception {  

        try {  

            KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance(“RSA”,  

                    new org.bouncycastle.jce.provider.BouncyCastleProvider());  

            final int KEY_SIZE = 1024;// 没什么好说的了,这个值关系到块加密的大小,可以更改,但是不要太大,否则效率会低  

            keyPairGen.initialize(KEY_SIZE, new SecureRandom());  

            KeyPair keyPair = keyPairGen.generateKeyPair();  

            saveKeyPair(keyPair);  

            return keyPair;  

        } catch (Exception e) {  

            throw new Exception(e.getMessage());  

        }  

    }  

      

    public static KeyPair getKeyPair()throws Exception{  

        FileInputStream fis = new FileInputStream(“C:/RSAKey.txt”);  

         ObjectInputStream oos = new ObjectInputStream(fis);  

         KeyPair kp= (KeyPair) oos.readObject();  

         oos.close();  

         fis.close();  

         return kp;  

    }  

      

    public static void saveKeyPair(KeyPair kp)throws Exception{  

          

         FileOutputStream fos = new FileOutputStream(“C:/RSAKey.txt”);  

         ObjectOutputStream oos = new ObjectOutputStream(fos);  

         //生成密钥  

         oos.writeObject(kp);  

         oos.close();  

         fos.close();  

    }  

  

    /** 

     * * 生成公钥 * 

     *  

     * @param modulus * 

     * @param publicExponent * 

     * @return RSAPublicKey * 

     * @throws Exception 

     */  

    public static RSAPublicKey generateRSAPublicKey(byte[] modulus,  

            byte[] publicExponent) throws Exception {  

        KeyFactory keyFac = null;  

        try {  

            keyFac = KeyFactory.getInstance(“RSA”,  

                    new org.bouncycastle.jce.provider.BouncyCastleProvider());  

        } catch (NoSuchAlgorithmException ex) {  

            throw new Exception(ex.getMessage());  

        }  

  

        RSAPublicKeySpec pubKeySpec = new RSAPublicKeySpec(new BigInteger(  

                modulus), new BigInteger(publicExponent));  

        try {  

            return (RSAPublicKey) keyFac.generatePublic(pubKeySpec);  

        } catch (InvalidKeySpecException ex) {  

            throw new Exception(ex.getMessage());  

        }  

    }  

  

    /** 

     * * 生成私钥 * 

     *  

     * @param modulus * 

     * @param privateExponent * 

     * @return RSAPrivateKey * 

     * @throws Exception 

     */  

    public static RSAPrivateKey generateRSAPrivateKey(byte[] modulus,  

            byte[] privateExponent) throws Exception {  

        KeyFactory keyFac = null;  

        try {  

            keyFac = KeyFactory.getInstance(“RSA”,  

                    new org.bouncycastle.jce.provider.BouncyCastleProvider());  

        } catch (NoSuchAlgorithmException ex) {  

            throw new Exception(ex.getMessage());  

        }  

  

        RSAPrivateKeySpec priKeySpec = new RSAPrivateKeySpec(new BigInteger(  

                modulus), new BigInteger(privateExponent));  

        try {  

            return (RSAPrivateKey) keyFac.generatePrivate(priKeySpec);  

        } catch (InvalidKeySpecException ex) {  

            throw new Exception(ex.getMessage());  

        }  

    }  

  

    /** 

     * * 加密 * 

     *  

     * @param key 

     *            加密的密钥 * 

     * @param data 

     *            待加密的明文数据 * 

     * @return 加密后的数据 * 

     * @throws Exception 

     */  

    public static byte[] encrypt(PublicKey pk, byte[] data) throws Exception {  

        try {  

            Cipher cipher = Cipher.getInstance(“RSA”,  

                    new org.bouncycastle.jce.provider.BouncyCastleProvider());  

            cipher.init(Cipher.ENCRYPT_MODE, pk);  

            int blockSize = cipher.getBlockSize();// 获得加密块大小,如:加密前数据为128个byte,而key_size=1024  

            // 加密块大小为127  

            // byte,加密后为128个byte;因此共有2个加密块,第一个127  

            // byte第二个为1个byte  

            int outputSize = cipher.getOutputSize(data.length);// 获得加密块加密后块大小  

            int leavedSize = data.length % blockSize;  

            int blocksSize = leavedSize != 0 ? data.length / blockSize + 1  

                    : data.length / blockSize;  

            byte[] raw = new byte[outputSize * blocksSize];  

            int i = 0;  

            while (data.length – i * blockSize  0) {  

                if (data.length – i * blockSize  blockSize)  

                    cipher.doFinal(data, i * blockSize, blockSize, raw, i  

                            * outputSize);  

                else  

                    cipher.doFinal(data, i * blockSize, data.length – i  

                            * blockSize, raw, i * outputSize);  

                // 这里面doUpdate方法不可用,查看源代码后发现每次doUpdate后并没有什么实际动作除了把byte[]放到  

                // ByteArrayOutputStream中,而最后doFinal的时候才将所有的byte[]进行加密,可是到了此时加密块大小很可能已经超出了  

                // OutputSize所以只好用dofinal方法。  

  

                i++;  

            }  

            return raw;  

        } catch (Exception e) {  

            throw new Exception(e.getMessage());  

        }  

    }  

  

    /** 

     * * 解密 * 

     *  

     * @param key 

     *            解密的密钥 * 

     * @param raw 

     *            已经加密的数据 * 

     * @return 解密后的明文 * 

     * @throws Exception 

     */  

    public static byte[] decrypt(PrivateKey pk, byte[] raw) throws Exception {  

        try {  

            Cipher cipher = Cipher.getInstance(“RSA”,  

                    new org.bouncycastle.jce.provider.BouncyCastleProvider());  

            cipher.init(cipher.DECRYPT_MODE, pk);  

            int blockSize = cipher.getBlockSize();  

            ByteArrayOutputStream bout = new ByteArrayOutputStream(64);  

            int j = 0;  

  

            while (raw.length – j * blockSize  0) {  

                bout.write(cipher.doFinal(raw, j * blockSize, blockSize));  

                j++;  

            }  

            return bout.toByteArray();  

        } catch (Exception e) {  

            throw new Exception(e.getMessage());  

        }  

    }  

  

    /** 

     * * * 

     *  

     * @param args * 

     * @throws Exception 

     */  

    public static void main(String[] args) throws Exception {  

        RSAPublicKey rsap = (RSAPublicKey) RSAUtil.generateKeyPair().getPublic();  

        String test = “hello world”;  

        byte[] en_test = encrypt(getKeyPair().getPublic(),test.getBytes());  

        byte[] de_test = decrypt(getKeyPair().getPrivate(),en_test);  

        System.out.println(new String(de_test));  

    }  

}

测试页面IndexAction.java:

/* 

 * Generated by MyEclipse Struts 

 * Template path: templates/java/JavaClass.vtl 

 */  

package com.sunsoft.struts.action;  

  

import java.security.interfaces.RSAPrivateKey;  

import java.security.interfaces.RSAPublicKey;  

  

import javax.servlet.http.HttpServletRequest;  

import javax.servlet.http.HttpServletResponse;  

  

import org.apache.struts.action.Action;  

import org.apache.struts.action.ActionForm;  

import org.apache.struts.action.ActionForward;  

import org.apache.struts.action.ActionMapping;  

  

import com.sunsoft.struts.util.RSAUtil;  

  

/**  

 * MyEclipse Struts 

 * Creation date: 06-28-2008 

 *  

 * XDoclet definition: 

 * @struts.action validate=”true” 

 */  

public class IndexAction extends Action {  

    /* 

     * Generated Methods 

     */  

  

    /**  

     * Method execute 

     * @param mapping 

     * @param form 

     * @param request 

     * @param response 

     * @return ActionForward 

     */  

    public ActionForward execute(ActionMapping mapping, ActionForm form,  

            HttpServletRequest request, HttpServletResponse response)throws Exception {  

          

        RSAPublicKey rsap = (RSAPublicKey) RSAUtil.getKeyPair().getPublic();  

        String module = rsap.getModulus().toString(16);  

        String empoent = rsap.getPublicExponent().toString(16);  

        System.out.println(“module”);  

        System.out.println(module);  

        System.out.println(“empoent”);  

        System.out.println(empoent);  

        request.setAttribute(“m”, module);  

        request.setAttribute(“e”, empoent);  

        return mapping.findForward(“login”);  

    }  

}

通过此action进入登录页面,并传入公钥的 Modulus 与PublicExponent的hex编码形式。

JS解密window[“\x65\x76\x61\x6c”](function

[“\x65\x76\x61\x6c”]这个是正则表达式,代表的是十六进制的ASCII 编码 转换的结果是eval

eval在js中的用法如下

eval 方法

检查 JScript 代码并执行.

eval(codeString)

必选项 codestring 参数是包含有效 JScript 代码的字符串值。这个字符串将由 JScript 分析器进行分析和执行。

说明

eval 函数允许 JScript 源代码的动态执行。例如,下面的代码创建了一个包含 Date 对象的新变量 mydate :

eval(“var mydate = new Date();”);

传递给 eval 方法的代码执行时的上下文和调用 eval 方法的一样.

原创文章,作者:PGCPG,如若转载,请注明出处:https://www.506064.com/n/315920.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
PGCPGPGCPG
上一篇 2025-01-09 12:13
下一篇 2025-01-09 12:13

相关推荐

  • JS Proxy(array)用法介绍

    JS Proxy(array)可以说是ES6中非常重要的一个特性,它可以代理一个数组,监听数据变化并进行拦截、处理。在实际开发中,使用Proxy(array)可以方便地实现数据的监…

    编程 2025-04-29
  • 解决.net 6.0运行闪退的方法

    如果你正在使用.net 6.0开发应用程序,可能会遇到程序闪退的情况。这篇文章将从多个方面为你解决这个问题。 一、代码问题 代码问题是导致.net 6.0程序闪退的主要原因之一。首…

    编程 2025-04-29
  • ArcGIS更改标注位置为中心的方法

    本篇文章将从多个方面详细阐述如何在ArcGIS中更改标注位置为中心。让我们一步步来看。 一、禁止标注智能调整 在ArcMap中设置标注智能调整可以自动将标注位置调整到最佳显示位置。…

    编程 2025-04-29
  • Python中init方法的作用及使用方法

    Python中的init方法是一个类的构造函数,在创建对象时被调用。在本篇文章中,我们将从多个方面详细讨论init方法的作用,使用方法以及注意点。 一、定义init方法 在Pyth…

    编程 2025-04-29
  • Python创建分配内存的方法

    在python中,我们常常需要创建并分配内存来存储数据。不同的类型和数据结构可能需要不同的方法来分配内存。本文将从多个方面介绍Python创建分配内存的方法,包括列表、元组、字典、…

    编程 2025-04-29
  • 用不同的方法求素数

    素数是指只能被1和自身整除的正整数,如2、3、5、7、11、13等。素数在密码学、计算机科学、数学、物理等领域都有着广泛的应用。本文将介绍几种常见的求素数的方法,包括暴力枚举法、埃…

    编程 2025-04-29
  • 使用Vue实现前端AES加密并输出为十六进制的方法

    在前端开发中,数据传输的安全性问题十分重要,其中一种保护数据安全的方式是加密。本文将会介绍如何使用Vue框架实现前端AES加密并将加密结果输出为十六进制。 一、AES加密介绍 AE…

    编程 2025-04-29
  • Python中读入csv文件数据的方法用法介绍

    csv是一种常见的数据格式,通常用于存储小型数据集。Python作为一种广泛流行的编程语言,内置了许多操作csv文件的库。本文将从多个方面详细介绍Python读入csv文件的方法。…

    编程 2025-04-29
  • Python学习笔记:去除字符串最后一个字符的方法

    本文将从多个方面详细阐述如何通过Python去除字符串最后一个字符,包括使用切片、pop()、删除、替换等方法来实现。 一、字符串切片 在Python中,可以通过字符串切片的方式来…

    编程 2025-04-29
  • 用法介绍Python集合update方法

    Python集合(set)update()方法是Python的一种集合操作方法,用于将多个集合合并为一个集合。本篇文章将从以下几个方面进行详细阐述: 一、参数的含义和用法 Pyth…

    编程 2025-04-29

发表回复

登录后才能评论