做网站选择哪家运营商wordpress doc插件

当前位置: 首页 > news >正文

做网站选择哪家运营商,wordpress doc插件,王野天津音乐广播,做网站为什么一定要留住用户文章目录 Pre机密性完整性1. 哈希函数#xff08;Hash Function#xff09;定义特征常见算法应用散列函数常用场景散列函数无法解决的问题 2. 消息认证码#xff08;MAC#xff09;概述定义常见算法工作原理如何使用 MACMAC 的问题 不可否认性数字签名#xff08;Digital … 文章目录 Pre机密性完整性1. 哈希函数Hash Function定义特征常见算法应用散列函数常用场景散列函数无法解决的问题 2. 消息认证码MAC概述定义常见算法工作原理如何使用 MACMAC 的问题 不可否认性数字签名Digital Signature 总结 Pre 加密与安全常见的分组密码 ECB、CBC、CFB、OFB模式介绍 加密与安全 解读非对称密钥解决密钥配送问题的四个方案 密钥体系的三个主要目标 机密性确保第三者无法通过密文猜测出明文。 完整性确保第三者无法篡改原文内容。 不可否认性确保第三者不能冒充其他人发送消息。
接下来我们将围绕以下几点展开 重述密钥体系的三个主要目标机密性、完整性和不可否认性。介绍确保机密性的对称密码和非对称密码的作用。详细讲解如何通过技术手段确保消息的完整性。介绍确保不可否认性的技术方法。总结加密与消息完整性及不可否认性的方法及其应用场景。 机密性 对称密码使用相同的密钥进行加密和解密。主要的实现方式包括AES、DES等。 优点加密速度快适合大数据量的加密。缺点密钥管理困难需确保密钥的安全传递。 非对称密码使用一对密钥进行加密和解密公钥加密私钥解密。主要的实现方式包括RSA、ECC等。 优点无需安全通道传递公钥私钥无需共享。缺点加密速度较慢不适合大数据量的加密。 对称密码和非对称密码解决的是机密性也就是确保 Eve 即便截获到密文也无法猜测出 Alice 和 Bob 传递的是啥内容。 完整性 有的时候Eve 并非需要破解消息。 比如 Alice 辛辛苦苦写了一个程序Eve 晚上偷偷在程序后面追加了一些代码。 第二天 Alice 将被替换的程序发给了 Bob。 虽然 Eve 没有截获任何密钥但事实上也破坏了 Alice 和 Bob 之间的信任关系。 所以密钥体系仍然需要解决完整性即第三者无法篡改原文内容. 为了确保消息的完整性即防止消息在传输过程中被篡改我们可以使用以下技术手段

  1. 哈希函数Hash Function 定义 哈希函数将任意长度的数据映射为固定长度的散列值哈希值。 散列函数是一个单向计算函数只有一个输入和对应的输出。f(x)y . 其中x称为消息, 而y则称为散列值。 f(x)y可以跟进消息内容计算出对应的散列值而我们就可以通过散列值来检查信息的完整性 特征 一个合格工业级散列函数必须具备以下特征 固定长度的散列值 无论x是多长的消息单向散列函数必须能够生成固定长度的y(散列值)。比如SHA-256它所计算出来的散列值永远是 256 比特 计算速度非常快 当然快是相对的尽管随着x的变大计算时间势必会加长。但如果不能在现实的时间内计算出来那么就丧失实际应用的价值了 散列值的唯一性 散列值的唯一性称之为抗碰撞性。也就是只要x不同那么计算出来的y一定不能相同。抗碰撞性分为两类: 强抗碰撞性和弱抗碰撞性 弱抗碰撞性指的是x确定那么y也就确定。 此时找到一个散列值等于y的x是非常困难的. 和弱抗碰撞性对应的是强抗碰撞性。强抗碰撞性指的是在茫茫数据集中指定任意一个y找到 x 和 x’ 是非常困难的 一个合格的散列函数必须同时具备强抗碰撞性和弱抗碰撞性。 单向性: 根据x可以计算出y,但无法根据y反推出x。
    哈希函数具有不可逆性和抗碰撞性即难以通过哈希值反推出原始数据也难以找到两个不同的输入具有相同的哈希值。 在一些场合中单向散列函数也称之为消息摘要函数、“哈希函数和杂凑函数”. 计算出的散列值也称之为消息摘要或者指纹 常见算法 MD4/5 : MD 是消息摘要(Message Digest)的缩写。 常用的是 MD5目前 MD5 已经被证实强抗碰撞性是不安全的即根据 md5 的算法现在已经可以产生具有相同y的两个不同x了。所以在安全性高的场合中不建议使用 md5SHA-1/256/384/512: 这是一个系列。后面的数字表示y的长度(SHA-1 除外)。 SHA-1 已经被证实强抗碰撞性是不安全的而 SHA-256/384/512 仍未被攻破所以后面这三个仍可以使用。后面这三类统称SHA-2SHA-3: 算法和 SHA-2 已经完全不一样了。 SHA-3 使用的是Keccak算法。Keccak算法理论上可以生成任意长度的散列值目前在 SHA-3 规范中规定了SHA3-224\256\384\512这四种版本。Keccak使用的是一种称之为海绵结构的分组算法大意是将x进行分组然后每个分组计算生成y’再将y’作为输入和下一个明文分组一起计算RIPEMD-160: 这个算法系列有两个版本: RIPEMD 和 RIPEMD-160。 其中 RIPEMD 已经被证实强抗碰撞性是不安全的。但 RIPEMD-160 仍然是安全的 应用 Alice发送消息前计算消息的哈希值并将消息和哈希值一起发送给Bob。Bob收到消息后计算消息的哈希值并与Alice发送的哈希值比较确保消息未被篡改。 散列函数常用场景 口令加密消息认证码数字签名伪随机数生成器一次性口令 散列函数无法解决的问题 散列函数只能确保信息内容不被篡改而无法保证消息一定是从合法渠道发来的。 例如 Eve 可以伪装成 Alice 向 Bob 发送消息和对应的散列值。 Bob 接受到消息和散列值后如果校验一致那么也只能证明消息没有经过篡改而无法证明消息是 Alice 发来的。 而为了解决这个问题就需要同时使用散列值和数字签名了 2. 消息认证码MAC 概述 散列函数中我们提到过通过散列函数我们确保消息原文并没有被篡改过。但无法保证消息是双方真实意思的表现。 比如说 Bob 收到一条借款消息上面写着请 Bob 给 Alice 的银行账户 xxxxx 转 1000. Bob 通过计算消息内容的散列函数证实消息没有被篡改过。 那么此时此刻Bob 应该给这个账户转账吗 不能 因为 Bob 并不能证实这条消息是来自于 Alice 的。 有可能这条消息来自于 Eve。 所有仅通过散列函数只能解决是否篡改而不能解决是否真实。 这是 Bob 以为的 而实际上却是这样的:
    而消息认证码则可以解决这个问题. 定义 消息认证码是基于哈希函数或对称加密算法生成的一段固定长度的代码用于验证消息的完整性和真实性。消息认证码是一种确认信息完整性并可以进行认证的技术简称 MAC(Message Authentication Code)。 MAC 由两部分组成: 消息 共享密钥
    和散列函数类似 MAC 可以将任意长度的消息计算出固定长度的输出值。但和散列函数不同的是如果没有共享密钥则无法计算出最终的 MAC 值。 所以通过这一个性质来确保安全性. MAC 单向散列 共享密钥 常见算法 HMAC (基于哈希函数的消息认证码), CMAC (基于块密码的消息认证码)等。 HMAC 的 H 指的是 Hash 的意思是一种利用 Hash 来构造消息认证码的算法。 我们说过MAC 散列函数 共享密钥 。 HMAC 使用的散列函数有:SHA-1、SHA-224、SHA-256、SHA-384、SHA-512 几种函数。 因此相对应的 HMAC 也称为:HMAC-SHA-1、HMAC-SHA-224、HMAC-SHA-256、HMAC-SHA-384、HMAC-SHA-512. HMAC 用数学公式来表示是: hash(opadKey || hash(ipadKey || message ))其中: ipadKey 是 key(密钥) ⊕ ipad(内部 16 进制的 36 比特流) opadKey 是 key(密钥) ⊕ opad(外部 16 进制的 5C 比特流)所以 HMAC 是两层 HASH 的结果值。 步骤分解: 密钥填充:如果密钥不足预设长度(散列函数的分组长度),则填充’0’。如果长呢那就用散列函数计算固定长度的散列值作为密钥值 将填充后的密钥与 Ipad 进行异或操作最后达到散列函数分组长度。此时将此值称为IpadKey将IpadKey附加在 message 开头将第三步的结果输入 hash 函数得出散列值将填充后的密钥与 Opad 进行异或操作最后达到散列函数分组长度。此时将此值称为OpadKey将IpadKey附加在 message 末尾将第六步的结果输入 hash 函数得出散列值 工作原理 Alice和Bob共享一个对称密钥。Alice使用共享密钥和哈希函数生成消息认证码并将消息和消息认证码一起发送给Bob。Bob使用共享密钥和哈希函数重新计算消息认证码并与Alice发送的消息认证码比较确保消息未被篡改。 如何使用 MAC 以 Bob 和 Alice 之间借钱的例子开始说。 假设这俩人之间通过 MAC 确保安全性那么双方处理流程应该大致是这个样子 Alice 将借钱消息发给 Bob。Bob 收到借钱消息后并不急于执行而是等着 Alice 发来消息认证码 Alice通过共享密钥和散列函数计算出 macAlice 将消息认证码发送给 BobBob 按照相同的规则计算一遍 MacBob将自己计算的 Mac 和 Alice 发来的 Mac 比对一遍。通过是否相同判断请求是否合法 MAC 的问题 在 MAC 算法里面既然提到了共享密钥那么就无法逃离对称密钥体系的宿命:“密钥配送问题”。 而解决这个问题目前来说只能依靠公钥密钥、Diffie-Hellman 密钥交换密钥中心等解决方案. 使用 HMAC 可以解决消息合法性和完整性的问题但却无法抵御重放攻击。 比如 Eve 截获到 Alice 和 Bob 之间的 Hmac 报文后无限制的重复这段报文。 那么 Bob 就会无限制的进行转账。所以使用 HMAC 进行消息认证时也会配合序号、时间戳等辅助信息来判断报文是否需要处理。 同时 HMAC 也无法解决否认的问题比如 Alice 完全可以事后否认找 Bob 借过钱因为 Bob 完全有能力伪造出这段报文。即便 Bob 拿出了 MAC 值也无法证明是 Alice 生成的。 那又该如何证明钱是由 Alice 借的呢 这就需要数字签名技术了 不可否认性 不可否认性确保消息的发送者不能否认曾经发送过消息这通常通过数字签名实现。 数字签名Digital Signature 定义数字签名是一种基于非对称密码技术的认证机制用于验证消息的发送者身份和消息的完整性。 工作原理 Alice使用自己的私钥对消息的哈希值进行加密生成数字签名并将消息和数字签名一起发送给Bob。Bob使用Alice的公钥对数字签名进行解密得到消息的哈希值并计算接收到的消息的哈希值。Bob比较两个哈希值若相同则确认消息完整且由Alice发送。 优点 提供身份认证和完整性验证。防止发送者否认发送过消息。 应用场景 安全电子邮件、数字合同、软件分发等需要验证身份和完整性的场景。 总结 确保信息的机密性、完整性和不可否认性是密钥体系的重要目标。对称密码和非对称密码主要解决机密性问题。哈希函数、消息认证码MAC和数字签名是实现消息完整性和不可否认性的主要技术手段。 应用建议 对于大数据量的加密使用对称密码如AES。对于身份验证和不可否认性结合使用非对称密码和数字签名。对于消息完整性使用哈希函数和消息认证码。