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

文章介绍了密码学从古典到现代的发展,包括替换法和移位法等古典密码学,恩尼格码和现代的对称加密如DES,以及非对称加密和散列函数。还讨论了如何设置安全密码,Base64编码的工作原理,并提到了toString()和newString()在加密解密中的区别。
摘要由CSDN通过智能技术生成

密码学

1.1 密码学基本概念

密码: 微信,QQ,支付宝,银行,密码什么时候开始使用 密码学:网络安全,信息安全,区块链这些学科的基础

密码学已经存在好几千年

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 里面的编码进行参照,找对应的字符
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

焱宣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值