密码学
1.1 密码学基本概念
密码: 微信,QQ,支付宝,银行,密码什么时候开始使用 密码学:网络安全,信息安全,区块链这些学科的基础
密码学已经存在好几千年
1.2 密码学的历史
1.2.1 古典密码学
古代就开始使用密码,目的:就是希望保护信息
- 替换法
- 位移法
- 古典密码学的破解方式:
- 频率分析法: 概率论
1.2.2 近代密码学
- 出现了恩尼格码密码机: 核心使用的也是移位法和替换法;可以采用图灵破解 (人工智能破解)
1.2.3 现代密码学
-
散列函数,也叫哈希函数 如: md5,sha-1,sha-256
-
对称加密
- 对称加密,使用的加密方式和解密方式,使用的是一把秘钥
- 非对称加密
- 非对称加密,有两把秘钥,使用公钥加密,使用私钥解密
1.2.4 如何设置密码才安全
- 密码不要太常见,不要使用 123456 作为密码
- 各个应用软件里密码不要设置一样,撞库
- 在设置密码的时候,可以加一些特殊的标记,注册京东,jd,zfb,szsgg
1.2.5 byte 和 bit 的区别:
1.3 ASCII编码
现代加密方式
1.1 对称加密: 加密和解密使用的是同一把钥匙 对称加密 分为流加密和块加密
例如:
- DES 加密:
- 秘钥 key 必须是8个字节
- Base 64 介绍
- base64 不是加密算法,可读性算法
- base64 目的不是保护我们的数据,目的是为了可读性
- base64 是有64 个字符组成,大写A-Z,小写a-z,数字0-9,两个符号,+ 和/
- base58 一般用在比特币里面的一种编码方式
- base64 和 base58 区别:在base58 里面,没有数字0 也没有字母 o 没有大小写字母 i 也没有 + 和 /
- Base 64 原理:
- base64, 是3个字节为一组,一个字节是8位,一共就是24位,base64 把三个字节,转换成4组,每组6位
- 一个字节,应该是8位,缺少2位,在高位进行补齐,在高位进行补 0 ,这样做的好处,base 取后面6位,前面的2位,会把他去掉,可以把 base64 控制在0-63 之间;
- toString() 和 new String() 的区别:
- 注意:如果在使用编码,进行加密和解密的时候,需要使用new String() 这种方式
- str.toString 方式,实际是调用的Object 里面的toString() 方法,返回的实际上是hash 值
- new String 方法: 是根据参数,参数是一个字节数组,使用java 虚拟机的默认编码格式,会把这个字节数组进行decode,找到对应的字符,如果虚拟机的编码格式,如果是ISO-8859-1,会去找ascii 里面的编码进行参照,找对应的字符