开发了一个
百度网盘热门资源站,因为用了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对数据进行加解密的实例。这个示例可能包含一段代码,展示了如何在编程环境中实现Base64的加密和解密功能。常见的编程语言如Python、Java、JavaScript都有内置的库函数...
它首先去除Base64字符串中的任何非Base64字符,然后按照Base64编码规则将每4个字符分解成3个字节,最后将这些字节转回原始字符串。 _utf8_encode方法是将普通字符串转为UTF-8编码的字符串,而_utf8_decode方法则...
### VBScript 版本的 Base64 解密脚本详解 #### 一、Base64 简介 Base64 是一种常见的编码方式,它主要用于将二进制数据转换为文本格式的数据(具体来说是ASCII字符)。这种转换通常是为了方便在网络上传输二进制...
了解了Base64编码的基本原理和应用场景后,我们可以使用各种编程语言(如Python、Java、JavaScript等)的库函数轻松实现Base64的编码和解码。在实际开发中,正确理解和使用Base64编码对于数据传输和存储至关重要。
注意,解密后的片段可能包含填充位,所以在合并之前,可能需要去除这些填充位。 **Java解密** 在后端,如Java环境中,你可以使用`Java Cryptography Extension (JCE)`来解密这些数据。Java代码会类似这样: ```java...
这些文件可能包括Python、Java、JavaScript或其他编程语言的示例,展示了如何使用Base64进行编码和解码操作。 对于Base64编码,其基本原理是将每个字节视为8位二进制数,然后每3个字节(24位)分为4组,每组6位。6...
解密过程与加密类似,但顺序相反:Base64解码、状态到字节转换、执行解密轮(逆向的SubBytes、ShiftRows、MixColumns和AddRoundKey)、去除填充,最后得到原始明文。 在实际应用中,你可能需要根据`aes.js`中的实现...
- **Base64编码**:将JavaScript代码转换为Base64字符串,使得代码在原始文本形式下难以理解。 - **ASCII/Unicode混淆**:通过使用特殊字符或Unicode编码来隐藏代码含义。 - **加密算法**:利用AES、RSA等加密...
3. **去除填充**:由于加密前进行了数据填充,解密后需要去除这些填充,还原原始数据。 在提供的压缩包文件“AES加密ECB模式”中,很可能包含了一个实现了上述功能的JavaScript文件。这个文件可以方便微信小程序...
5. **解密**: 要解密,使用`CryptoJS.AES.decrypt()`方法,传入密文(Base64解码后)和相同的密钥。解密后,会自动去除零填充部分,恢复原始明文。 在实际应用中,由于ECB模式的弱点,通常建议使用更安全的模式,如...
多功能版在线WEB工具箱PHP源码带后台安装版,一个多功能的Web工具PHP脚本,适用于日常任务和开发人员。 DNS 查找工具。IP 查找工具。SSL 查找工具。Whois 查询工具。Ping工具。MD5 生成器工具。Base64 转换工具。...
在网络安全和网页开发领域,CSS(层叠样式表)和JS(JavaScript)是不可或缺的组成部分。CSS用于控制网页的布局和样式,而JS则负责页面的动态交互和功能实现。然而,随着网络技术的发展,代码的安全性变得越来越重要...
3. 注意解密后可能需要去除额外的填充字符,因此在处理字符串时,可能需要调用`.trim()`方法。 在提供的代码片段中,`AesEncode`类展示了如何使用Java的`javax.crypto`包进行AES解密。这个类中的`desEncrypt`方法...
这里使用了`preg_match()`函数来匹配特定格式的字符串,然后通过`str_replace()`函数去除多余的字符,并调用`base64_decode()`完成解码过程。 ### 二、解密键提取 #### 2.1 解析解密键 解密键对于整个解密过程至...
5. 03.rar、asp加密网页.txt、js压缩解压工具.txt、js加解密.txt:这些可能是更深入的关于ASP网页加密和JS加解密的技术文档或工具说明。 6. 巧用ASP技术保护DHTML源代码_files:这是一个目录,可能包含与上述HTML...
- **编码(Encoding)**:将JS代码转换为另一种形式,如Base64编码,使其在源代码中看起来像是乱码。 - **加密(Encryption)**:使用加密算法,如AES,RSA等,将JS代码转化为密文,只有拥有解密密钥才能还原。 - **...
后者用于解密,接受加密文本、私钥文件名和一个布尔值指示是否从JavaScript传来(如果是,则使用无填充模式解密)。解密后,根据情况处理字符串(去除可能的尾部标记,反转字符串等)。 需要注意的是,RSA加密不...
这里的`base64encode()`和`base64decode()`函数实现了Base64的编码和解码过程。它们通过对输入字符串的每个字节进行处理,然后将其转换为Base64字符序列。 JavaScript中的这些常见函数对于日常编程工作至关重要,...
如果密钥以`base64:`开头,会先去除并解码。 6. **分析`Encrypter`类** - **构造方法**:在实例化`Encrypter`时,会检查提供的密钥和所选的加密算法是否兼容。`supported`静态方法确保了密钥长度与加密算法匹配。 ...
对称加密算法的核心特点是加密和解密使用相同的密钥,这使得AES在性能上表现出色,尤其适合于大量数据的快速加解密。 首先,让我们了解一下AES的基本概念。AES支持三种密钥长度:128位、192位和256位。其中,128位...