• BASE64 编码和解码


    依赖jar: import org.apache.commons.codec.binary.Base64;

    BASE64和其他相似的编码算法通常用于转换二进制数据为文本数据,其目的是为了简化存储或传输。更具体地说,BASE64算法主要用于转换二进 制数据为ASCII字符串格式。Java语言提供了一个非常好的BASE64算法的实现,即Apache Commons Codec工具包。本文将简要地讲述怎样使用BASE64以及它是怎样工作的。

    下面我们用BASE64对字符串进行编码:

     

    复制代码
    import java.io.UnsupportedEncodingException; 
    import org.apache.commons.codec.binary.Base64; 
       
    public class Base64Test { 
        public static void main(String[] args){ 
            String str = "Hello World"; 
            try{ 
                System.out.println("RESULT: " + encodeStr(str)); 
            } catch(UnsupportedEncodingException e){ 
                e.printStackTrace(); 
            } 
        } 
    }
    复制代码

     

    复制代码
        /** 
         * 解密 
         *  
         * @param pwd 
         * @return 
         * @see [类、类#方法、类#成员] 
         */  
        public static String decodeStr(String pwd)  
        {  
            Base64 base64 = new Base64();  
            byte[] debytes = base64.decodeBase64(new String(pwd).getBytes());  
            return new String(debytes);  
        }  
    
        /** 
         * 加密 
         *  
         * @param pwd 
         * @return 
         * @see [类、类#方法、类#成员] 
         */  
        public static String encodeStr(String pwd)  
        {  
            Base64 base64 = new Base64();  
            byte[] enbytes = base64.encodeBase64Chunked(pwd.getBytes());  
            return new String(enbytes);  
    复制代码

    输出结果为:

    1. RESULT: SGVsbG8gV29ybGQ=  

    上面输出的字符串是“Hello world”字符串的8位二进制值被连接在一起,然后以6位分组。随后每个组都被转换成一个单独的数字并映射到Base64的索引。

    复制代码
    binary  dec Base64 
    010010  18  S 
    000110  6   G 
    010101  21  V 
    101100  44  s 
    011011  27  b 
    000110  6   G 
    111100  60  8 
    100000  32  g 
    010101  29  d 
    110110  54  2 
    111101  61  9 
    110010  50  y 
    011011  27  b 
    000110  6   G 
    010000  16  Q
  • 相关阅读:
    高斯消元
    逻辑运算符之优先级&&and、or
    康托展开
    关于bootstrap的双层遮罩问题
    写好页面在内网内访问
    swiper插件的一些坑
    第一篇博客
    poj 3415 Common Substrings
    poj 1509 Glass Beads
    poj 3260 The Fewest Coins
  • 原文地址:https://www.cnblogs.com/zhengxingpeng/p/6674828.html
Copyright © 2020-2023  润新知