快捷搜索: 王者荣耀 脱发

Java 加密方式学习(持续更新)

密码学

1.1 密码学基本概念

密码学已经存在好几千年

1.2 密码学的历史

1.2.1 古典密码学

古代就开始使用密码,目的:就是希望保护信息

  1. 替换法
  2. 位移法
  3. 古典密码学的破解方式:
    频率分析法: 概率论

1.2.2 近代密码学

    出现了恩尼格码密码机: 核心使用的也是移位法和替换法;可以采用图灵破解 (人工智能破解)

1.2.3 现代密码学

  1. 散列函数,也叫哈希函数 如: md5,sha-1,sha-256
  2. 对称加密
    对称加密,使用的加密方式和解密方式,使用的是一把秘钥
  1. 非对称加密
    非对称加密,有两把秘钥,使用公钥加密,使用私钥解密

1.2.4 如何设置密码才安全

  1. 密码不要太常见,不要使用 123456 作为密码
  2. 各个应用软件里密码不要设置一样,撞库
  3. 在设置密码的时候,可以加一些特殊的标记,注册京东,jd,zfb,szsgg

1.2.5 byte 和 bit 的区别:

1.3 ASCII编码

现代加密方式

1.1 对称加密: 加密和解密使用的是同一把钥匙 对称加密 分为流加密和块加密

例如:

  1. DES 加密:
    秘钥 key 必须是8个字节
  1. Base 64 介绍
    base64 不是加密算法,可读性算法 base64 目的不是保护我们的数据,目的是为了可读性 base64 是有64 个字符组成,大写A-Z,小写a-z,数字0-9,两个符号,+ 和/ base58 一般用在比特币里面的一种编码方式 base64 和 base58 区别:在base58 里面,没有数字0 也没有字母 o 没有大小写字母 i 也没有 + 和 /
  1. Base 64 原理:
    base64, 是3个字节为一组,一个字节是8位,一共就是24位,base64 把三个字节,转换成4组,每组6位 一个字节,应该是8位,缺少2位,在高位进行补齐,在高位进行补 0 ,这样做的好处,base 取后面6位,前面的2位,会把他去掉,可以把 base64 控制在0-63 之间;
  1. toString() 和 new String() 的区别:
    注意:如果在使用编码,进行加密和解密的时候,需要使用new String() 这种方式 str.toString 方式,实际是调用的Object 里面的toString() 方法,返回的实际上是hash 值 new String 方法: 是根据参数,参数是一个字节数组,使用java 虚拟机的默认编码格式,会把这个字节数组进行decode,找到对应的字符,如果虚拟机的编码格式,如果是ISO-8859-1,会去找ascii 里面的编码进行参照,找对应的字符
经验分享 程序员 微信小程序 职场和发展