加入收藏 | 设为首页 | 会员中心 | 我要投稿 汽车网 (https://www.0577qiche.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 安全 > 正文

网络传输加密的方式有哪些,优缺点是哪些

发布时间:2023-06-02 08:55:00 所属栏目:安全 来源:
导读: 下面是网络传输中常用的几种加密方式:

提示:这些加密是涉及一些明文信息的传输的,因此需要在传统的https超文本协议上加密传输。

1、密钥散列

采用MD5或者SHA1等散列算法,对明文进行加密
    下面是网络传输中常用的几种加密方式:

    提示:这些加密是涉及一些明文信息的传输的,因此需要在传统的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();

(编辑:汽车网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章