`
xwater
  • 浏览: 4180 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

去掉"/"后的base64加解密,js和java版

阅读更多
开发了一个百度网盘热门资源站,因为用了spring mvc的resturl和有静态化需要,即把url生成对应的物理文件。所以想到用base64对用户的搜索关键词进行转码。但是因为原base64中,有字符“/”影响resturl的解析,所以对base64进行了稍加改造,去掉了“/”,改为“!”

js端转码代码:

function searchJump(key){
	key = base64encode(utf16to8(key));
	window.location.href = "/search/" + key+".html";
}

var base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+!";
function base64encode(str) {
	var out, i, len;
	var c1, c2, c3;
	len = str.length;
	i = 0;
	out = "";
	while (i < len) {
		c1 = str.charCodeAt(i++) & 0xff;
		if (i == len) {
			out += base64EncodeChars.charAt(c1 >> 2);
			out += base64EncodeChars.charAt((c1 & 0x3) << 4);
			out += "==";
			break;
		}
		c2 = str.charCodeAt(i++);
		if (i == len) {
			out += base64EncodeChars.charAt(c1 >> 2);
			out += base64EncodeChars.charAt(((c1 & 0x3) << 4)
					| ((c2 & 0xF0) >> 4));
			out += base64EncodeChars.charAt((c2 & 0xF) << 2);
			out += "=";
			break;
		}
		c3 = str.charCodeAt(i++);
		out += base64EncodeChars.charAt(c1 >> 2);
		out += base64EncodeChars.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));
		out += base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >> 6));
		out += base64EncodeChars.charAt(c3 & 0x3F);
	}
	return out;
}

function utf16to8(str) {
	var out, i, len, c;
	out = "";
	len = str.length;
	for (i = 0; i < len; i++) {
		c = str.charCodeAt(i);
		if ((c >= 0x0001) && (c <= 0x007F)) {
			out += str.charAt(i);
		} else if (c > 0x07FF) {
			out += String.fromCharCode(0xE0 | ((c >> 12) & 0x0F));
			out += String.fromCharCode(0x80 | ((c >> 6) & 0x3F));
			out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
		} else {
			out += String.fromCharCode(0xC0 | ((c >> 6) & 0x1F));
			out += String.fromCharCode(0x80 | ((c >> 0) & 0x3F));
		}
	}
	return out;
}


java的转码代码:

package com.savetao.util;

public class Base64 {
    private static final char[] S_BASE64CHAR = {
        'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
        'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T',
        'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd',
        'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
        'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x',
        'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7',
        '8','9','+','!'
    };
    private static final char S_BASE64PAD = '=';
    private static final byte[] S_DECODETABLE = new byte[128];
    static {
        for (int i = 0;   i < S_DECODETABLE.length;   i ++)
            S_DECODETABLE[i] = Byte.MAX_VALUE;  // 127
        for (int i = 0;   i < S_BASE64CHAR.length;   i ++) // 0 to 63
            S_DECODETABLE[S_BASE64CHAR[i]] = (byte)i;
    }
    
    private static int decode0(char[] ibuf, byte[] obuf, int wp) {
        int outlen = 3;
        if (ibuf[3] == S_BASE64PAD)   outlen = 2;
        if (ibuf[2] == S_BASE64PAD)   outlen = 1;
        int b0 = S_DECODETABLE[ibuf[0]];
        int b1 = S_DECODETABLE[ibuf[1]];
        int b2 = S_DECODETABLE[ibuf[2]];
        int b3 = S_DECODETABLE[ibuf[3]];
        switch (outlen) {
        case 1:
            obuf[wp] = (byte)(b0 << 2 & 0xfc | b1 >> 4 & 0x3);
            return 1;
        case 2:
            obuf[wp++] = (byte)(b0 << 2 & 0xfc | b1 >> 4 & 0x3);
            obuf[wp] = (byte)(b1 << 4 & 0xf0 | b2 >> 2 & 0xf);
            return 2;
        case 3:
            obuf[wp++] = (byte)(b0 << 2 & 0xfc | b1 >> 4 & 0x3);
            obuf[wp++] = (byte)(b1 << 4 & 0xf0 | b2 >> 2 & 0xf);
            obuf[wp] = (byte)(b2 << 6 & 0xc0 | b3 & 0x3f);
            return 3;
        default:
            throw new RuntimeException("Couldn't decode.");
        }
    }


    public static byte[] decode(String data) {
        char[] ibuf = new char[4];
        int ibufcount = 0;
        byte[] obuf = new byte[data.length()/4*3+3];
        int obufcount = 0;
        for (int i = 0;   i < data.length();   i ++) {
            char ch = data.charAt(i);
            if (ch == S_BASE64PAD
                || ch < S_DECODETABLE.length && S_DECODETABLE[ch] != Byte.MAX_VALUE) {
                ibuf[ibufcount++] = ch;
                if (ibufcount == ibuf.length) {
                    ibufcount = 0;
                    obufcount += decode0(ibuf, obuf, obufcount);
                }
            }
        }
        if (obufcount == obuf.length)
            return obuf;
        byte[] ret = new byte[obufcount];
        System.arraycopy(obuf, 0, ret, 0, obufcount);
        return ret;
    }
    public static String encode(byte[] data) {
        return encode(data, 0, data.length);
    }
    
    public static String encode(byte[] data, int off, int len) {
        if (len <= 0)   return "";
        char[] out = new char[len/3*4+4];
        int rindex = off;
        int windex = 0;
        int rest = len-off;
        while (rest >= 3) {
            int i = ((data[rindex]&0xff)<<16)
                    +((data[rindex+1]&0xff)<<8)
                    +(data[rindex+2]&0xff);
            out[windex++] = S_BASE64CHAR[i>>18];
            out[windex++] = S_BASE64CHAR[(i>>12)&0x3f];
            out[windex++] = S_BASE64CHAR[(i>>6)&0x3f];
            out[windex++] = S_BASE64CHAR[i&0x3f];
            rindex += 3;
            rest -= 3;
        }
        if (rest == 1) {
            int i = data[rindex]&0xff;
            out[windex++] = S_BASE64CHAR[i>>2];
            out[windex++] = S_BASE64CHAR[(i<<4)&0x3f];
            out[windex++] = S_BASE64PAD;
            out[windex++] = S_BASE64PAD;
        } else if (rest == 2) {
            int i = ((data[rindex]&0xff)<<8)+(data[rindex+1]&0xff);
            out[windex++] = S_BASE64CHAR[i>>10];
            out[windex++] = S_BASE64CHAR[(i>>4)&0x3f];
            out[windex++] = S_BASE64CHAR[(i<<2)&0x3f];
            out[windex++] = S_BASE64PAD;
        }
        return new String(out, 0, windex);
    }    
    public static void main(String []args){
    	String s="美国队长";
    	System.out.println(Base64.encode(s.getBytes()));
    	System.out.println(new String(Base64.decode("576O5Zu96Zif6ZW!")));
    }    
}
分享到:
评论

相关推荐

    base64加密解密demo

    在"加密测试"中,我们可以看到如何运用Base64对数据进行加解密的实例。这个示例可能包含一段代码,展示了如何在编程环境中实现Base64的加密和解密功能。常见的编程语言如Python、Java、JavaScript都有内置的库函数...

    JS实现的base64加密解密操作示例

    它首先去除Base64字符串中的任何非Base64字符,然后按照Base64编码规则将每4个字符分解成3个字节,最后将这些字节转回原始字符串。 _utf8_encode方法是将普通字符串转为UTF-8编码的字符串,而_utf8_decode方法则...

    vbs版的解密base64加密的脚本

    ### VBScript 版本的 Base64 解密脚本详解 #### 一、Base64 简介 Base64 是一种常见的编码方式,它主要用于将二进制数据转换为文本格式的数据(具体来说是ASCII字符)。这种转换通常是为了方便在网络上传输二进制...

    Base64 加密算法

    了解了Base64编码的基本原理和应用场景后,我们可以使用各种编程语言(如Python、Java、JavaScript等)的库函数轻松实现Base64的编码和解码。在实际开发中,正确理解和使用Base64编码对于数据传输和存储至关重要。

    jsencrypt.min.js通过JSEncrypt分段加密解密

    注意,解密后的片段可能包含填充位,所以在合并之前,可能需要去除这些填充位。 **Java解密** 在后端,如Java环境中,你可以使用`Java Cryptography Extension (JCE)`来解密这些数据。Java代码会类似这样: ```java...

    文件字符串的加密和解密

    这些文件可能包括Python、Java、JavaScript或其他编程语言的示例,展示了如何使用Base64进行编码和解码操作。 对于Base64编码,其基本原理是将每个字节视为8位二进制数,然后每3个字节(24位)分为4组,每组6位。6...

    不用cryptoJs的aes加密解密

    解密过程与加密类似,但顺序相反:Base64解码、状态到字节转换、执行解密轮(逆向的SubBytes、ShiftRows、MixColumns和AddRoundKey)、去除填充,最后得到原始明文。 在实际应用中,你可能需要根据`aes.js`中的实现...

    JS.rar_php js解密

    - **Base64编码**:将JavaScript代码转换为Base64字符串,使得代码在原始文本形式下难以理解。 - **ASCII/Unicode混淆**:通过使用特殊字符或Unicode编码来隐藏代码含义。 - **加密算法**:利用AES、RSA等加密...

    微信小程序 AES加密 ECB模式js文件

    3. **去除填充**:由于加密前进行了数据填充,解密后需要去除这些填充,还原原始数据。 在提供的压缩包文件“AES加密ECB模式”中,很可能包含了一个实现了上述功能的JavaScript文件。这个文件可以方便微信小程序...

    AES+ECB+pad-zeropadding+crypto-js加密

    5. **解密**: 要解密,使用`CryptoJS.AES.decrypt()`方法,传入密文(Base64解码后)和相同的密钥。解密后,会自动去除零填充部分,恢复原始明文。 在实际应用中,由于ECB模式的弱点,通常建议使用更安全的模式,如...

    多功能版在线WEB工具箱PHP源码带后台安装版

    多功能版在线WEB工具箱PHP源码带后台安装版,一个多功能的Web工具PHP脚本,适用于日常任务和开发人员。 DNS 查找工具。IP 查找工具。SSL 查找工具。Whois 查询工具。Ping工具。MD5 生成器工具。Base64 转换工具。...

    css与js加密法

    在网络安全和网页开发领域,CSS(层叠样式表)和JS(JavaScript)是不可或缺的组成部分。CSS用于控制网页的布局和样式,而JS则负责页面的动态交互和功能实现。然而,随着网络技术的发展,代码的安全性变得越来越重要...

    md5.js下载,支持AES加密

    3. 注意解密后可能需要去除额外的填充字符,因此在处理字符串时,可能需要调用`.trim()`方法。 在提供的代码片段中,`AesEncode`类展示了如何使用Java的`javax.crypto`包进行AES解密。这个类中的`desEncrypt`方法...

    微盾PHP脚本加密专家解密算法.txt

    这里使用了`preg_match()`函数来匹配特定格式的字符串,然后通过`str_replace()`函数去除多余的字符,并调用`base64_decode()`完成解码过程。 ### 二、解密键提取 #### 2.1 解析解密键 解密键对于整个解密过程至...

    js文件加密工具合集

    5. 03.rar、asp加密网页.txt、js压缩解压工具.txt、js加解密.txt:这些可能是更深入的关于ASP网页加密和JS加解密的技术文档或工具说明。 6. 巧用ASP技术保护DHTML源代码_files:这是一个目录,可能包含与上述HTML...

    百度,新浪,58同城js加密代码打包下载

    - **编码(Encoding)**:将JS代码转换为另一种形式,如Base64编码,使其在源代码中看起来像是乱码。 - **加密(Encryption)**:使用加密算法,如AES,RSA等,将JS代码转化为密文,只有拥有解密密钥才能还原。 - **...

    JS关于提交的RSA加密算法.doc

    后者用于解密,接受加密文本、私钥文件名和一个布尔值指示是否从JavaScript传来(如果是,则使用无填充模式解密)。解密后,根据情况处理字符串(去除可能的尾部标记,反转字符串等)。 需要注意的是,RSA加密不...

    javascript常用函数归纳整理

    这里的`base64encode()`和`base64decode()`函数实现了Base64的编码和解码过程。它们通过对输入字符串的每个字节进行处理,然后将其转换为Base64字符序列。 JavaScript中的这些常见函数对于日常编程工作至关重要,...

    Laravel中encrypt和decrypt的实现方法

    如果密钥以`base64:`开头,会先去除并解码。 6. **分析`Encrypter`类** - **构造方法**:在实例化`Encrypter`时,会检查提供的密钥和所选的加密算法是否兼容。`supported`静态方法确保了密钥长度与加密算法匹配。 ...

    如何基于python3和Vue实现AES数据加密

    对称加密算法的核心特点是加密和解密使用相同的密钥,这使得AES在性能上表现出色,尤其适合于大量数据的快速加解密。 首先,让我们了解一下AES的基本概念。AES支持三种密钥长度:128位、192位和256位。其中,128位...

Global site tag (gtag.js) - Google Analytics