import java.io.ByteArrayOutputStream;

import java.io.IOException;

import java.io.UnsupportedEncodingException;

import java.util.zip.Deflater;

import java.util.zip.Inflater;

public class Base64 {

/**

* Byte value that maps to 'a' in Base64 encoding

*/

private final static int LOWER_CASE_A_VALUE = 26;

/**

* Byte value that maps to '0' in Base64 encoding

*/

private final static int ZERO_VALUE = 52;

/**

* Byte value that maps to '+' in Base64 encoding

*/

private final static int PLUS_VALUE = 62;

/**

* Byte value that maps to '/' in Base64 encoding

*/

private final static int SLASH_VALUE = 63;

/**

* Bit mask for one character worth of bits in Base64 encoding. Equivalent

* to binary value 111111b.

*/

private final static int SIX_BIT_MASK = 63;

/**

* Bit mask for one byte worth of bits in Base64 encoding. Equivalent to

* binary value 11111111b.

*/

private static final int EIGHT_BIT_MASK = 0xFF;

/**

* The input String to be decoded

*/

private String mString;

/**

* Current position in the String(to be decoded)

*/

private int mIndex = 0;

/**

* Encode an array of bytes using Base64

*

* @param data[]

*            The bytes to be encoded

* @return A valid Base64 representation of the input

*/

public static String encode(byte data[])

{

return new Base64().internalEncode(data);

}

/**

* Encode an array of bytes using Base64

*

* @param data[]

*            The bytes to be encoded

* @return A valid Base64 representation of the input

*/

public String internalEncode(byte data[])

{

// Base64 encoding yields a String that is 33% longer than the byte

// array

int charCount = ((data.length * 4) / 3) + 4;

// New lines will also be needed for every 76 charactesr, so allocate a

// StringBuffer that is long enough to hold the full result without

// having to expand later

StringBuffer result = new StringBuffer((charCount * 77) / 76);

int byteArrayLength = data.length;

int byteArrayIndex = 0;

int byteTriplet = 0;

while (byteArrayIndex < byteArrayLength - 2)

{

// Build the 24 bit byte triplet from the input data

byteTriplet = convertUnsignedByteToInt(data[byteArrayIndex++]);

// Each input byte contributes 8 bits to the triplet

byteTriplet <<= 8;

byteTriplet |= convertUnsignedByteToInt(data[byteArrayIndex++]);

byteTriplet <<= 8;

byteTriplet |= convertUnsignedByteToInt(data[byteArrayIndex++]);

// Look at the lowest order six bits and remember them

byte b4 = (byte) (SIX_BIT_MASK & byteTriplet);

// Move the byte triplet to get the next 6 bit value

byteTriplet >>= 6;

byte b3 = (byte) (SIX_BIT_MASK & byteTriplet);

byteTriplet >>= 6;

byte b2 = (byte) (SIX_BIT_MASK & byteTriplet);

byteTriplet >>= 6;

byte b1 = (byte) (SIX_BIT_MASK & byteTriplet);

// Add the Base64 encoded character to the result String

result.append(mapByteToChar(b1));

result.append(mapByteToChar(b2));

result.append(mapByteToChar(b3));

result.append(mapByteToChar(b4));

// There are 57 bytes for every 76 characters, so wrap the line when

// needed

// if ( byteArrayIndex % 57 == 0 ) {

// result.append( "\n" );

// }

}

// Check if we have one byte left over

if (byteArrayIndex == byteArrayLength - 1)

{

// Convert our one byte to an int

byteTriplet = convertUnsignedByteToInt(data[byteArrayIndex++]);

// Right pad the second 6 bit value with zeros

byteTriplet <<= 4;

byte b2 = (byte) (SIX_BIT_MASK & byteTriplet);

byteTriplet >>= 6;

byte b1 = (byte) (SIX_BIT_MASK & byteTriplet);

result.append(mapByteToChar(b1));

result.append(mapByteToChar(b2));

// Add "==" to the output to make it a multiple of 4 Base64

// characters

result.append("==");

}

// Check if we have two byte left over

if (byteArrayIndex == byteArrayLength - 2)

{

// Convert our two bytes to an int

byteTriplet = convertUnsignedByteToInt(data[byteArrayIndex++]);

byteTriplet <<= 8;

byteTriplet |= convertUnsignedByteToInt(data[byteArrayIndex++]);

// Right pad the third 6 bit value with zeros

byteTriplet <<= 2;

byte b3 = (byte) (SIX_BIT_MASK & byteTriplet);

byteTriplet >>= 6;

byte b2 = (byte) (SIX_BIT_MASK & byteTriplet);

byteTriplet >>= 6;

byte b1 = (byte) (SIX_BIT_MASK & byteTriplet);

result.append(mapByteToChar(b1));

result.append(mapByteToChar(b2));

result.append(mapByteToChar(b3));

// Add "==" to the output to make it a multiple of 4 Base64

// characters

result.append("=");

}

return result.toString();

}

/**

* Decode an input String using Base64

*

* @param data

*            The String to be decoded

* @return The appropriate byte array

*/

public static byte[] decode(String data)

{

return new Base64().internalDecode(data);

}

/**

* Decode an input String using Base64

*

* @param data

*            The String to be decoded

* @return The appropriate byte array

*/

public byte[] internalDecode(String data)

{

mString = data;

mIndex = 0;

/**

* Total number of Base64 characters in the input

*/

int mUsefulLength = 0;

int length = mString.length();

for (int i = 0; i < length; i++)

{

if (isUsefulChar(mString.charAt(i)))

{

mUsefulLength++;

}

}

// mString = data;

// A Base64 byte array is 75% the size of its String representation

int byteArrayLength = mUsefulLength * 3 / 4;

byte result[] = new byte[byteArrayLength];

int byteTriplet = 0;

int byteIndex = 0;

// Continue until we have less than 4 full characters left to

// decode in the input.

while (byteIndex + 2 < byteArrayLength)

{

// Package a set of four characters into a byte triplet

// Each character contributes 6 bits of useful information

byteTriplet = mapCharToInt(getNextUsefulChar());

byteTriplet <<= 6;

byteTriplet |= mapCharToInt(getNextUsefulChar());

byteTriplet <<= 6;

byteTriplet |= mapCharToInt(getNextUsefulChar());

byteTriplet <<= 6;

byteTriplet |= mapCharToInt(getNextUsefulChar());

// Grab a normal byte (eight bits) out of the byte triplet

// and put it in the byte array

result[byteIndex + 2] = (byte) (byteTriplet & EIGHT_BIT_MASK);

byteTriplet >>= 8;

result[byteIndex + 1] = (byte) (byteTriplet & EIGHT_BIT_MASK);

byteTriplet >>= 8;

result[byteIndex] = (byte) (byteTriplet & EIGHT_BIT_MASK);

byteIndex += 3;

}

// Check if we have one byte left to decode

if (byteIndex == byteArrayLength - 1)

{

// Take out the last two characters from the String

byteTriplet = mapCharToInt(getNextUsefulChar());

byteTriplet <<= 6;

byteTriplet |= mapCharToInt(getNextUsefulChar());

// Remove the padded zeros

byteTriplet >>= 4;

result[byteIndex] = (byte) (byteTriplet & EIGHT_BIT_MASK);

}

// Check if we have two bytes left to decode

if (byteIndex == byteArrayLength - 2)

{

// Take out the last three characters from the String

byteTriplet = mapCharToInt(getNextUsefulChar());

byteTriplet <<= 6;

byteTriplet |= mapCharToInt(getNextUsefulChar());

byteTriplet <<= 6;

byteTriplet |= mapCharToInt(getNextUsefulChar());

// Remove the padded zeros

byteTriplet >>= 2;

result[byteIndex + 1] = (byte) (byteTriplet & EIGHT_BIT_MASK);

byteTriplet >>= 8;

result[byteIndex] = (byte) (byteTriplet & EIGHT_BIT_MASK);

}

return result;

}

/**

* Convert a Base64 character to its 6 bit value as defined by the mapping.

*

* @param c

*            Base64 character to decode

* @return int representation of 6 bit value

*/

private int mapCharToInt(char c)

{

if (c >= 'A' && c <= 'Z')

{

return c - 'A';

}

if (c >= 'a' && c <= 'z')

{

return (c - 'a') + LOWER_CASE_A_VALUE;

}

if (c >= '0' && c <= '9')

{

return (c - '0') + ZERO_VALUE;

}

if (c == '+')

{

return PLUS_VALUE;

}

if (c == '/')

{

return SLASH_VALUE;

}

throw new IllegalArgumentException(c + " is not a valid Base64 character.");

}

/**

* Convert a byte between 0 and 63 to its Base64 character equivalent

*

* @param b

*            Byte value to be converted

* @return Base64 char value

*/

private char mapByteToChar(byte b)

{

if (b < LOWER_CASE_A_VALUE)

{

return (char) ('A' + b);

}

if (b < ZERO_VALUE)

{

return (char) ('a' + (b - LOWER_CASE_A_VALUE));

}

if (b < PLUS_VALUE)

{

return (char) ('0' + (b - ZERO_VALUE));

}

if (b == PLUS_VALUE)

{

return '+';

}

if (b == SLASH_VALUE)

{

return '/';

}

throw new IllegalArgumentException("Byte " + new Integer(b) + " is not a valid Base64 value");

}

/**

* @param c

*            Character to be examined

* @return Whether or not the character is a Base64 character

*/

private boolean isUsefulChar(char c)

{

return (c >= 'A' && c <= 'Z') || (c >= 'a' && c <= 'z') || (c >= '0' && c <= '9') || (c == '+') || (c == '/');

}

/**

* Traverse the String until hitting the next Base64 character. Assumes that

* there is still another valid Base64 character left in the String.

*/

private char getNextUsefulChar()

{

char result = '_'; // Start with a non-Base64 character

while (!isUsefulChar(result))

{

result = mString.charAt(mIndex++);

}

return result;

}

/**

* Convert a byte to an integer. Needed because in Java bytes are signed,

* and for Base64 purposes they are not. If not done this way, when

* converted to an int, 0xFF will become -127

*

* @param b

*            Byte value to be converted

* @return Value as an integer, as if byte was unsigned

*/

private int convertUnsignedByteToInt(byte b)

{

if (b >= 0)

{

return (int) b;

}

return 256 + b;

}

public static String getEncodeMsg(String tMessage)

{

String returnStr = "";

try

{

ByteArrayOutputStream byteStream = getCompressedStr(tMessage);

if(byteStream!=null)

returnStr = Base64.encode(byteStream.toByteArray());

//returnStr = Base64.encode(tMessage.getBytes("UTF-8"));

}

catch (Exception ex)

{

ex.printStackTrace();

}

return returnStr;

}

private static ByteArrayOutputStream getCompressedStr(String tMessage)

{

ByteArrayOutputStream compressedStream = null;

try

{

if (tMessage != null && !"".equals(tMessage))

{

byte[] input = tMessage.getBytes("UTF-8");

Deflater compresser = new Deflater();

compresser.setInput(input);

compresser.finish();

compressedStream = new ByteArrayOutputStream();

byte[] buf = new byte[2048];

while (!compresser.finished())

{

int got = compresser.deflate(buf);

compressedStream.write(buf, 0, got);

}

}

}

catch (Exception ex)

{

ex.printStackTrace();

}

finally

{

if (compressedStream != null)

{

try

{

compressedStream.close();

}

catch (IOException ioex)

{

ioex.printStackTrace();

}

}

}

return compressedStream;

}

public static String getDecodeMsg(String tMessage)

{

String outputString = "";

byte[] inputStr  = null;

try

{

String newStr = tMessage;

newStr = newStr.replaceAll(" ", "+");

inputStr = Base64.decode(newStr);

outputString = getDeCompressedStr(inputStr);

}

catch (Exception ex)

{

ex.printStackTrace();

}

return outputString;

//      return new String(inputStr);

}

private static String getDeCompressedStr(byte[] tMessage)

{

String returnStr = "";

ByteArrayOutputStream aDeCompressedStream = null;

try

{

// Decompress the bytes

Inflater decompresser = new Inflater();

decompresser.setInput(tMessage);

aDeCompressedStream = new ByteArrayOutputStream();

byte[] buf = new byte[2048];

while (!decompresser.finished())

{

int got = decompresser.inflate(buf);

aDeCompressedStream.write(buf, 0, got);

}

}

catch (Exception ex)

{

ex.printStackTrace();

} finally

{

try

{

if(aDeCompressedStream!=null)

aDeCompressedStream.close();

}

catch (IOException ioex)

{

ioex.printStackTrace();

}

}

try

{

returnStr = aDeCompressedStream.toString("UTF-8");

}

catch (UnsupportedEncodingException encodeEx)

{

encodeEx.printStackTrace();

}

return returnStr;

}

}

Base64(2)的更多相关文章

  1. linux shell 不同进制数据转换(二进制,八进制,十六进制,base64) (转)

    shell可以在不调用第3方命令,表示不同进制数据.这里总结以下表示方法.shell 脚本默认数值是由10 进制数处理,除非这个数字某种特殊的标记法或前缀开头. 才可以表示其它进制类型数值.如:以 0 ...

  2. 将上传图片转成base64(转)

    效果如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"><titl ...

  3. js转base64(数字)

    var name='测试文字'; var t_name=encodeURIComponent(name); t_name=window.btoa(t_name); console.log(t_name ...

  4. hdu 5237 Base64(模拟)

    Base64 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Subm ...

  5. Base64(3)

    public final class Base64 { static private final int     BASELENGTH           = 128; static private ...

  6. WebSocket协议探究(一)

    一 复习和目标 1 复习 上一节使用wireshark抓包分析了WebSocket流量 包含连接的建立:HTTP协议升级WebSocket协议 使用建立完成的WebSocket协议发送数据 2 目标 ...

  7. cookie规范(RFC6265)翻译

    来源:https://github.com/renaesop/blog/issues/4 RFC 6265 要点翻译 1.简介 本文档定义了HTTP Cookie以及HTTP头的Set-Cookie字 ...

  8. (iOS)Base64加密和DES加密、以及JAVA和iOS中DES加密统一性问题

    我们在项目中为了安全方面的考虑,通常情况下会选择一种加密方式对需要安全性的文本进行加密,而Base64加密和DES64加密是常用的加密算法.我记得我在前一个项目中使用的就是这两种加密算法的结合:Bas ...

  9. Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC

    Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC 博客分类: Java/Security Javabase64macmd5sha     加密解密,曾经是我一 ...

随机推荐

  1. Windows/Linux/Mac下安装mvn

    Step1: 去官网地址下载 http://maven.apache.org/download.cgi Step2: 解压并且移动到指定到目录下 Step3: 配置环境变量并使之生效 .bash_pr ...

  2. CentOS7安装Supervisor3.1.4

    supervisord 负责管理进程的server端,配置文件是/etc/supervisor/supervisord.conf supervisorctl client端的命令行工具,管理子进程,配 ...

  3. windows下面,PHP如何启动一些扩展功能

    我今天在试这个时,发现php有些默认设置,是需要人为介入修改的. 比如,当我们在安装一个软件,而这个软件需要启用php一些扩展功能. 那么,按一般套路,将php.ini文件里的相关行的注释去掉即可. ...

  4. poj3522Slim Span(暴力+Kruskal)

    思路: 最小生成树是瓶颈生成树,瓶颈生成树满足最大边最小. 数据量较小,所以只需要通过Kruskal,将边按权值从小到大排序,枚举最小边求最小生成树,时间复杂度为O( nm(logm) ) #incl ...

  5. 通过iptables限制docker容器端口

    如何限制docker暴露的对外访问端口 docker 会在iptables上加上自己的转发规则,如果直接在input链上限制端口是没有效果的.这就需要限制docker的转发链上的DOCKER表. # ...

  6. [NOIp 2018]all

    Description 题库链接: Day1 T1 铺设道路 Day1 T2 货币系统 Day1 T3 赛道修建 Day2 T1 旅行 Day2 T2 填数游戏 Day2 T3 保卫王国 Soluti ...

  7. LeetCode 988. Smallest String Starting From Leaf

    原题链接在这里:https://leetcode.com/problems/smallest-string-starting-from-leaf/ 题目: Given the root of a bi ...

  8. Clickhouse 性能瓶颈排查 IO过高

    前几天公司clickhouse 有个查询很慢.经理一直追问为什么慢 是cpu 不够 还是IO 占用太高,还是其他的原因.于是有了以下的排查 执行该条,在不考虑优化sql 的情况下 进行性能排查 1.首 ...

  9. 关于System.ArgumentNullException异常

    什么是ArgumentNullException 当将 null 引用(Visual Basic 中为 Nothing)传递到不接受其作为有效参数的方法时引发的异常. 继承 Object Except ...

  10. ES6 数组方法 forEach map filter find every some reduce

    1. forEach const colors = ['red', 'blue', 'green'] colors.forEach(function (params) { console.log(pa ...