常用加密一、BASE64加密

常用加密一、BASE64加密

2019年04月16日 13:40:38 chun_hua_xue_yue 阅读数:1183

BASE64编码的原理是源文件以标准字节byte(8个bit)为单位转化成二进制。

加密步骤:
1、将待转换的字符串每三个字节分为一组,每个字节占8bit,那么共有24个二进制位。
2、将上面的24个二进制位每6个一组,共分为4组。(最后一组不足6位补0)
3、在每组前面添加两个0,每组由6个变为8个二进制位,总共32个二进制位,即四个字节。
4、根据Base64编码对照表获得对应的值。(不足四组补 = )

解密与之相反。

代码:


import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;

import java.io.IOException;

/**
 BASE64的加密解密是双向的,可以求反解.
 BASE64Encoder和BASE64Decoder是非官方JDK实现类。虽然可以在JDK里能找到并使用,但是在API里查不到。
 JRE 中 sun 和 com.sun 开头包的类都是未被文档化的,他们属于 java, javax 类库的基础,其中的实现大多数与底层平台有关,
 一般来说是不推荐使用的。
 BASE64 严格地说,属于编码格式,而非加密算法
 主要就是BASE64Encoder、BASE64Decoder两个类,我们只需要知道使用对应的方法即可。
 另,BASE加密后产生的字节位数是8的倍数,如果不够位数以=符号填充。
 BASE64
 按照RFC2045的定义,Base64被定义为:Base64内容传送编码被设计用来把任意序列的8位字节描述为一种不易被人直接识别的形式。
 (The Base64 Content-Transfer-Encoding is designed to represent arbitrary sequences of octets in a form that need not be humanly readable.)
 常见于邮件、http加密,截取http信息,你就会发现登录操作的用户名、密码字段通过BASE64加密的。
 */
public class BASE64Utils {

    /**
     * BASE64解密
     * @param key
     * @return
     */
    public static byte[] decryptBASE64(String key) {
        try {
            return new BASE64Decoder().decodeBuffer(key);
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }

    /**
     * BASE64加密
     * @param key
     * @return
     */
    public static String encryptBASE64(byte[] key){
        return new BASE64Encoder().encodeBuffer(key);
    }

    public static void main(String[] args) {

        String  str="12345678";
        String  result1= BASE64Utils.encryptBASE64(str.getBytes());
        System.out.println("result1=====加密数据=========="+result1);

        byte  result2[]= BASE64Utils.decryptBASE64(result1);
        String  str2=new String(result2);
        System.out.println("str2========解密数据========"+str2);

    }

}

加密算法目录

常用加密二、MD5加密

猜你喜欢

转载自blog.csdn.net/f45056231p/article/details/89888196
今日推荐