Java BASE64加密解密

Java BASE64加密解密

 

Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045~RFC2049,上面有MIME的详细规范。Base64编码可用于在HTTP环境下传递较长的标识信息。例如,在Java Persistence系统Hibernate中,就采用了Base64来将一个较长的唯一标识符(一般为128-bit的UUID)编码为一个字符串,用作HTTP表单和HTTP GET URL中的参数。在其他应用程序中,也常常需要把二进制数据编码为适合放在URL(包括隐藏表单域)中的形式。此时,采用Base64编码不仅比较简短,同时也具有不可读性,即所编码的数据不会被人用肉眼所直接看到。

 

RFC2045还规定每行位76个字符,每行末尾需添加一个回车换行符,即便是最后一行不够76个字符,也要加换行符。

 

实现原理

 

Base64实际上是对二进制码做分组转换操作

1.每3个8位二进制码位一组,转换为4个6位二进制码为一组(不足6位时地位补0)。3个8位二进制码和4个6位二进制码长度都是24位。

2.对获得的4个6位二进制码补位,每个6位二进制码添加两位高位0,组成4个8位二进制码。

3.将获得的4个8位二进制码转换为4个十进制码。

4.将获得的十进制码转换为Base64字符表中对应的字符。

 

 

 

字符串“A”,进行Base64编码,如下所示:

 

字符                A

ASCII码           65

二进制码          01000001

 

4个6位二进制码 010000          010000

4个8位二进制码 00010000       00010000

十进制码          16                 16

字符表映射码     Q                  Q                   =                 =

 

 

字符串“A”经过Base64编码后得到字符串“QQ==”。

结果出现了两个等号。很显然,当原文的二进制码长度不足24位,最终转换为十进制时也不足4项,这时就需要用等号补位。

将Base64编码后的字符串最多会有2个等号,这时因为:

余数 = 原文字节数 MOD 3。

 

 

 

 

 

 

 

字符串“密”,对其使用UTF-8编码等到Byte数组{-27,-81,-122},

 

字符                密

UTF-8编码        -27                -81               -122

二进制码          11100101       10101111       10000110

4个6位二进制码 111001          011010           111110          000110

4个8位二进制码 00111001       00011010       00111110       00000110

十进制码          57                 26                  62                6

字符表映射码     5                   a                   +                 G

 

字符串“密”经过Base64编码后得到字符串“5a+G”。

 

 

对照表:

 

 

索引对应字符索引对应字符索引对应字符索引对应字符
0A17R34i51z
1B18S35j520
2C19T36k531
3D20U37l542
4E21V38m553
5F22W39n564
6G23X40o575
7H24Y41p586
8I25Z42q597
9J26a43r608
10K27b44s619
11L28c45t62+
12M29d46u63/
13N30e47v  
14O31f48w  
15P32g49x  
16Q33h50y 

 

 java实现

 

1.JDK实现:

Java代码   收藏代码
  1. import sun.misc.BASE64Decoder;     
  2. import sun.misc.BASE64Encoder;     
  3.     
  4. /**   
  5.  * BASE64加密解密   
  6.  */    
  7. public class BASE64     
  8. {     
  9.     
  10.     /**    
  11.      * BASE64解密   
  12.    * @param key          
  13.      * @return          
  14.      * @throws Exception          
  15.      */              
  16.     public static byte[] decryptBASE64(String key) throws Exception {               
  17.         return (new BASE64Decoder()).decodeBuffer(key);               
  18.     }               
  19.                   
  20.     /**         
  21.      * BASE64加密   
  22.    * @param key          
  23.      * @return          
  24.      * @throws Exception          
  25.      */              
  26.     public static String encryptBASE64(byte[] key) throws Exception {               
  27.         return (new BASE64Encoder()).encodeBuffer(key);               
  28.     }       
  29.          
  30.     public static void main(String[] args) throws Exception     
  31.     {     
  32.         String data = BASE64.encryptBASE64("http://aub.iteye.com/".getBytes());     
  33.         System.out.println("加密前:"+data);     
  34.              
  35.         byte[] byteArray = BASE64.decryptBASE64(data);     
  36.         System.out.println("解密后:"+new String(byteArray));     
  37.     }     
  38. }    
  39.    

   注意,sun.misc包是Sun公司提供给内部使用的专用API,在java API文档中我们看不到任何有关BASE64影子,不建议使用。

 

 

2.Apache的实现:(建议使用这种方式,当然,自己实现也可以)

 参考org.apache.commons.codec.binary.Base64
下载地址:
http://commons.apache.org/codec/download_codec.cgi

 

Apache还提供了,非标准的实现方式:

1.不再添加回车符。

2.Url Base64,也就是将“+”和“\”换成了“-”和“_”符号,且不适用补位。

 

 

 

 

 

本文参考《java 加密与解密的艺术》,和百度百科。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值