赞
踩
- package com.test.common;
- import java.io.ByteArrayOutputStream;
- import java.io.IOException;
- import java.io.OutputStream;
-
- public class Base64Util {
- private static final char[] legalChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".toCharArray();
- private static void decode(String s, OutputStream os) throws IOException {
- int i = 0;
-
- int len = s.length();
-
- while (true) {
- while (i < len && s.charAt(i) <= ' ')
- i++;
-
- if (i == len)
- break;
-
- int tri = (decode(s.charAt(i)) << 18)
- + (decode(s.charAt(i + 1)) << 12)
- + (decode(s.charAt(i + 2)) << 6)
- + (decode(s.charAt(i + 3)));
-
- os.write((tri >> 16) & 255);
- if (s.charAt(i + 2) == '=')
- break;
- os.write((tri >> 8) & 255);
- if (s.charAt(i + 3) == '=')
- break;
- os.write(tri & 255);
-
- i += 4;
- }
- }
- /*解密一个字符串*/
- public static String decode(String s) {
-
- ByteArrayOutputStream bos = new ByteArrayOutputStream();
- try {
- decode(s, bos);
- } catch (IOException e) {
- throw new RuntimeException();
- }
- byte[] decodedBytes = bos.toByteArray();
- try {
- bos.close();
- bos = null;
- } catch (IOException ex) {
- System.err.println("Error while decoding BASE64: " + ex.toString());
- }
- return new String(decodedBytes);
- }
-
- private static int decode(char c) {
- if (c >= 'A' && c <= 'Z')
- return ((int) c) - 65;
- else if (c >= 'a' && c <= 'z')
- return ((int) c) - 97 + 26;
- else if (c >= '0' && c <= '9')
- return ((int) c) - 48 + 26 + 26;
- else
- switch (c) {
- case '+':
- return 62;
- case '/':
- return 63;
- case '=':
- return 0;
- default:
- throw new RuntimeException("unexpected code: " + c);
- }
- }
- /*加密一个字符串*/
- public static String encode(String str) {
- byte[] data=str.getBytes();
- int start = 0;
- int len = data.length;
- StringBuffer buf = new StringBuffer(data.length * 3 / 2);
-
- int end = len - 3;
- int i = start;
- int n = 0;
-
- while (i <= end) {
- int d = ((((int) data[i]) & 0x0ff) << 16)
- | ((((int) data[i + 1]) & 0x0ff) << 8)
- | (((int) data[i + 2]) & 0x0ff);
-
- buf.append(legalChars[(d >> 18) & 63]);
- buf.append(legalChars[(d >> 12) & 63]);
- buf.append(legalChars[(d >> 6) & 63]);
- buf.append(legalChars[d & 63]);
-
- i += 3;
-
- if (n++ >= 14) {
- n = 0;
- buf.append(" ");
- }
- }
-
- if (i == start + len - 2) {
- int d = ((((int) data[i]) & 0x0ff) << 16)
- | ((((int) data[i + 1]) & 255) << 8);
-
- buf.append(legalChars[(d >> 18) & 63]);
- buf.append(legalChars[(d >> 12) & 63]);
- buf.append(legalChars[(d >> 6) & 63]);
- buf.append("=");
- } else if (i == start + len - 1) {
- int d = (((int) data[i]) & 0x0ff) << 16;
-
- buf.append(legalChars[(d >> 18) & 63]);
- buf.append(legalChars[(d >> 12) & 63]);
- buf.append("==");
- }
-
- return buf.toString();
- }
- }
/*base64编码加密*/ function base64encode(str) { var base64EncodeChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; var base64DecodeChars = new Array( -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1); 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); } //base64编码后在按自己的算法在进行编码 return out; }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。