网络安全常用的几种加密方式是什么意思
下面是网络传输中常用的几种加密方式:
提示:这些加密涉及明文传输的,需要在https协议上加密传输。
1、密钥散列
采用MD5或者SHA1等散列算法,对明文进行加密(这里的加密仅对人,不对机器,因为这些算法机器可以用对应算法算出来)
优点:防篡改
适用场景:普通文件下载
缺点:不具备安全性,可认证性
2、对称加密
优点:安全、可认证
适用场景:收发方数量固定,密钥使用对象少
缺点:BS网络传输关系,密钥过多难维护,除非对密钥进行加密传输
3、非对称加密
3.1、接收方发送公钥(保证数据完整性)
前提:首次通信时发送方接收了接收方的公钥,并保存在本地
3.2、发送方发送公钥(保证发送方认证)
前提:首次通信时接收方接收了发送方的公钥,并保存在本地
4、数字签名
适用场景:登录认证
缺点:不具备足保密性
速记
对称算法
对称算法(SymmestricAlgorithm).Create()=>
Provider.CreateEncryptor()
Provider.CreateDecryptor()
CryptoStream(Stream stream,ICrytoTransform transform,CryptoStreamMode mode):
CryptoStream(encryptedSteam,encryptor,CryptoStreamMode.Write)//加密 准备读取 空encryptedSteam准备被写入
CryptoStream(encryptedSteam,decryptor,CryptoStreamMode.Read)//解密 准备写入 密文流encryptedSteam准备被读取
非对称加密
非对称加密(ASymmistricAlgorithm):
Provider provider
provider.ToXmlString(true);//获得公私钥对
provider.ToXmlString(false);//获得公钥
provier.FromXmlString(publicKeyXml);
provier.FromXmlString(privateKeyXml);
provider.Encrypt();
provider.Decrypt();
实例:
对称加密:
string key = "abc";
string sendContent="你好!";
var byteKey = Encoding.UTF8.GetBytes(key);
var byteIV = Encoding.UTF8.GetBytes(key);//加密算法初始化向量
DESCryptoServiceProvider des = new DESCryptoServiceProvider();//使用des加密
byte[] bytesContent = Encoding.UTF8.GetBytes(sendContent);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(byteKey, byteIV), CryptoStreamMode.Write);
cs.Write(bytesContent, 0, bytesContent.Length);
cs.FlushFinalBlock();
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanfejca
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
怎样阻止微信小程序自动打开
PHP中文网 06-13 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01