法国工程师IMT联盟 密码学及其应用 2023年期末考试题

news2025/1/22 19:44:56

1 在 Unix 下的安全性 ('30 分钟)

1.1 问题 1

1.1.1 问题

        我们注意constaté到通过 SMTP 服务器发送“假”电子邮件(垃圾邮件)相对容易。越来越常见的做法是在 SMTP 连接之上部署déployer TLS 协议protocole(即 SMTPS)。这解决了垃圾邮件的问题吗?这提供了哪些保证?

1.1.2 SMTP

        SMTP(简单邮件传输协议,Simple Mail Transfer Protocol)是一种用于发送和传输电子邮件的互联网标准协议。它定义了邮件服务器如何接收、处理和转发电子邮件消息。SMTP 通常用于发送邮件,而在接收邮件时常用的是 POP3(邮局协议版本3)或 IMAP(互联网邮件访问协议)。SMTP 通过“存储和转发”方式将您的电子邮件从一个服务器传输到另一个服务器,最终将邮件投递到收件人的邮箱。SMTP 使用 TCP 端口25作为主要的通信端口,安全的SMTP(通过 SSL 或 TLS 加密)则可能使用465或587端口。

1.1.3 问题答案

        部署 TLS 协议(即 SMTPS)在 SMTP 连接上增加了加密,这意味着数据(包括电子邮件内容和发送者/接收者的信息)在传输过程中被加密从而提高了数据传输的安全性然而,虽然 TLS 可以提供传输层的安全保障,确保数据在传输过程中不易被截获或篡改,但它并不直接解决垃圾邮件的问题。

        垃圾邮件问题主要与电子邮件的内容和发送者的身份有关, TLS 更多地关注于数据传输的安全。换句话说,TLS 确保了电子邮件在发送和接收过程中的加密,但它不对电子邮件的发送方进行验证,也不分析电子邮件内容以判断其是否为垃圾邮件。因此,即使在 SMTPS 下,发送“假”电子邮件(垃圾邮件)仍然是可能的。

        解决垃圾邮件问题通常需要采用更多层面的措施,例如:

        发送方身份验证:通过如 SPF(Sender Policy Framework)、DKIM(DomainKeys Identified Mail)、DMARC(Domain-based Message Authentication, Reporting & Conformance)等技术,可以帮助验证发件人的身份,减少伪造身份的情况。

        内容过滤:使用垃圾邮件过滤器分析电子邮件的内容,包括主题、正文、附件等,以识别和隔离垃圾邮件。

        用户培训和意识提高:教育用户识别潜在的垃圾邮件和网络钓鱼攻击,减少垃圾邮件的成功率。

        总结来说,虽然 SMTPS 提供了传输层面的安全保障,但解决垃圾邮件问题需要综合多种技术和策略。SMTPS 是确保电子邮件安全传输的重要步骤,但防止垃圾邮件还需采取额外措施。

1.2 问题 2

1.2.1 问题

        在测试我的防火墙配置configuration时,我发现可以对我的 Web 服务器进行 ping 操作,但是不能执行effectuer HTTP 请求requête。这个问题最可能的原因是什么?

1.2.2 问题答案

        如果你能够对 Web 服务器执行 ping 操作(通常使用 ICMP 协议),但无法执行 HTTP 请求(通常通过 TCP 端口 80 或者对于 HTTPS 则是 443),最可能的原因是防火墙规则配置导致了 HTTP 请求被阻止。具体来说,可能的原因包括:

        防火墙规则设置不当:防火墙可能被配置为允许 ICMP 流量通过(这使得 ping 请求能够成功),但同时阻止了 TCP 端口 80 和 443 上的流量。这会导致无法通过浏览器或其他 HTTP 客户端工具访问 Web 服务器。

        端口未开放或错误配置:Web 服务器上 HTTP(80)或 HTTPS(443)端口可能没有在防火墙中开放,或者配置错误,导致请求无法到达服务器。

        服务未运行:虽然这与防火墙直接无关,但如果 Web 服务(如 Apache、Nginx 等)没有在服务器上运行,或者配置错误,也可能导致无法处理 HTTP 请求。不过,这种情况下通常不会影响 ICMP 请求的成功。

        解决这类问题通常需要检查并调整防火墙规则,确保 HTTP 和 HTTPS 的端口(80 和 443)被允许通过。此外,确认 Web 服务器服务正在运行并且正确监听了这些端口也是重要的步骤。在进行更改后,可以使用工具如  curl 或 telnet 尝试连接到 Web 服务器的 HTTP 端口,以验证配置是否正确。

1.3 问题 3

1.3.1 问题

        出于安全原因,我在 HTTPS 服务器上安装了我的 web 应用程序。但是出于成本考虑,我选择生成了一个自签名证书。
        这对用户有什么影响?从实践的角度和安全性的属性角度来看?

1.3.2 问题答案

        使用自签名证书在 HTTPS 服务器上安装 web 应用程序对用户以及从安全性的角度来看,有以下几个影响:

1.3.2.1 用户角度的影响

        浏览器警告:用户首次访问使用自签名证书的网站时,浏览器会显示安全警告,提示证书不受信任。这可能会让用户感到困惑或不安,尤其是对于不熟悉这类警告的用户。

        额外步骤:为了继续访问网站,用户可能需要手动添加一个例外或信任该证书,这增加了额外的步骤,并可能降低用户体验。

1.3.2.2 安全性属性的影响

        加密:从积极的一面来看,即使是自签名证书,也能为网站提供传输层加密(TLS),这意味着数据传输过程中的数据将被加密,提高了数据的机密性。

        认证:然而,自签名证书缺乏第三方权威机构(CA)的验证,这意味着虽然数据传输是加密的,但不能保证服务器的身份。这减少了身份验证的可信度,因为任何人都可以生成一个自签名证书并声称是目标服务器。

        中间人攻击(MITM)的风险:由于缺乏有效的第三方身份验证,用户很难区分一个合法服务器与一个伪装的服务器(可能由攻击者控制)。这使得用户更容易受到中间人攻击的风险。

        综上所述,虽然使用自签名证书可以为 web 应用程序提供加密,降低了数据被截获的风险,但它在身份验证方面提供的安全性较低。对于那些对安全性要求较高的应用程序,建议使用受信任的证书颁发机构(CA)签发的证书,以增强用户信任并减少潜在的安全风险。

1.4 问题 4

1.4.1 问题

        在我们的实践操作travaux pratiques中,我们使用 John the Ripper 工具展示了密码破解cassage技术。

        结果显示,密码  thelittleblackdog (17个字符)在十分钟内就被找到了,而密码 é!(2个字符)需要几百万年才能被破解(放心,我没有等到那时)。

        你认为为什么会这样?关于选择密码,你有什么建议préconisations吗?

1.4.2 问题答案

        John the Ripper 破解密码的速度差异主要由两个因素决定:密码的复杂度(包括长度、字符集的复杂性)和破解方法(如暴力破解、字典攻击等)。

        密码长度和复杂性:"thelittleblackdog" 虽然较长,但完全由小写字母组成,如果使用的破解方法针对常见单词或短语进行了优化(例如,通过字典攻击dictionary attack),则可能相对较快被破解。而 "é!" 只有两个字符,但包括了一个特殊字符和一个非标准拉丁字母,这使得它不太可能出现在预定义的字典中,且如果采用暴力破解法brute force solution,需要遍历的字符集(包括特殊字符和非英文字符)远大于只包含小写英文字母的情况。

        破解方法:John the Ripper 和其他密码破解工具通常结合使用多种破解技术,包括字典攻击、暴力破解和基于规则的攻击。对于简单和常见的密码(如只包含小写字母的长密码),字典攻击或基于规则的攻击可能非常有效。而对于非常短但包含复杂字符的密码,如果不在字典中,可能需要转而使用暴力破解,这在字符集大时尤其耗时。

        密码选择的建议:

        使用足够的长度:推荐至少使用 12 个字符的密码。

        混合字符类型:结合使用大写字母、小写字母、数字、特殊字符,增加密码的复杂性。

        避免使用常见单词和短语:即使是长密码,如果由常见单词或短语组成,也可能容易被字典攻击破解。

        考虑使用密码短语:由几个不相关的单词组成的短语,既容易记忆又难以被破解。

        定期更换密码:即使密码很复杂,定期更换也可以减少被破解的风险。

        使用密码管理器:密码管理器可以帮助生成和存储复杂的随机密码,从而不必担心记忆问题。

        通过遵循这些建议,可以大大提高密码的安全性,减少被破解的风险。

1.5 问题 5

1.5.1 问题

        在 ssh 中,哪种机制允许客户端确保不存在中间人攻击?

1.5.2 SSH是什么

        SSH(安全外壳协议,Secure Shell)是一个网络协议,用于安全地在不安全的网络上进行远程登录和其他网络服务。SSH提供了一个加密的会话,使得敏感信息,如登录凭据和命令,可以在客户端和服务器之间安全地传输,防止了中间人攻击和数据泄露。

        SSH最常见的用途包括远程控制服务器和安全地传输文件(通过SCP或SFTP)。SSH工作在应用层,并默认使用TCP端口22。SSH不仅加密连接中的数据,还提供了身份验证和数据完整性的保证。SSH支持多种身份验证方法,包括基于密码的身份验证和基于公钥的身份验证,其中后者提供了更高的安全性。

1.5.3 问题

        在 SSH (安全外壳协议) 中,防止中间人攻击(Man-in-the-Middle, MITM)主要依靠 主机密钥验证 机制。当 SSH 客户端第一次连接到 SSH 服务器时,服务器会将其公钥发送给客户端。

        客户端软件会检查这个公钥是否已经被存储在本地已知主机密钥列表中(通常是在 `.ssh/known_hosts` 文件中)。

        首次连接:如果是第一次连接(即该服务器的公钥还未被存储在客户端的 `known_hosts` 文件中),客户端会显示一个警告,询问用户是否信任服务器的公钥。如果用户接受,该公钥就会被存储在  known_hosts 文件中,用于后续的验证。

        后续连接:在以后的连接中,客户端会自动检查服务器提供的公钥是否与 `known_hosts` 文件中存储的公钥匹配。如果公钥匹配,连接就会继续,因为客户端认为它正在连接到同一个服务器。如果公钥不匹配,SSH 客户端会阻止连接并显示一个警告,因为这可能表明存在中间人攻击。

        这个过程确保了客户端在连接到 SSH 服务器时,可以验证服务器的身份,防止中间人伪装成目标服务器以截获或篡改数据。

        此外,SSH 协议还采用了端到端的加密和其它安全措施,如密钥交换算法,进一步保障数据传输的安全性,减少被中间人攻击的风险。

1.5.4 防止中间人攻击

        为了防止中间人攻击(Man-in-the-Middle, MITM),通常会采用以下一些策略和技术:

        1. 加密:使用强加密协议(如 HTTPS、SSH、TLS/SSL)对数据进行加密,确保数据传输的安全。

        2. 公钥基础设施(PKI):通过证书颁发机构(CA)颁发的数字证书来验证参与通信双方的身份。

        3. 双因素认证:除了密码之外,使用一个额外的认证步骤,如手机短信验证码、身份认证应用生成的一次性密码或生物特征认证。

        4. 端点验证:在客户端和服务器之间建立连接时,对端点进行严格的验证,确保正在连接的是正确的服务和设备。

        5. DNS安全:使用DNSSEC防止DNS劫持,这是一种通过篡改域名解析过程来进行的中间人攻击。

        6. VPN:在不安全的网络(如公共Wi-Fi)上使用虚拟私人网络(VPN)来加密所有流量。

        7. 网络安全工具:使用防火墙、入侵检测系统(IDS)和入侵防御系统(IPS)等工具来监控和防止未授权的数据拦截。

        8. 常规更新和补丁应用:保持所有系统和软件的最新状态,确保已应用最新的安全补丁来防范已知的漏洞。

        通过组合使用这些策略和工具,可以显著增强网络安全,减少中间人攻击的风险。

1.6 问题 6

1.6.1 问题

        我的公司提供基于 web 解决方案的服务。一家安全公司的商务人员向我推荐了一种“VPN屏蔽器”,因为他告诉我:“VPN IP地址只是可能给您的业务带来问题的IP地址的一小部分。我们的代理检测系统提供了一种简单的解决方案,用于检测包括代理、VPN和Tor连接在内的各种坏IP地址。”

        1. 您认为,这样一个VPN屏蔽器,从技术上来说,是如何有效工作的?

        2. 而且,在您看来,它的优点和缺点可能是什么?

1.6.2 问题

1.6.2.1 技术实现

        VPN屏蔽器通常利用多种技术手段来识别和阻止VPN、代理和Tor连接。这些方法可能包括:        

        IP地址检测:屏蔽器可能拥有一个数据库,其中包含已知的VPN和代理服务器的IP地址。这些数据可以通过第三方服务获取,或者由公司自己维护。当检测到流量来自这些已知的IP地址时,连接会被阻止。

        端口和协议分析:VPN通常会使用特定的端口和协议。检测系统可以分析网络流量以寻找这些特征。

        DNS检测:如果DNS请求显示出与用户IP地址不一致的地理位置信息,那么这可能是VPN或代理使用的迹象。

        行为分析:异常的浏览器或连接行为也可能表明使用了VPN或代理。例如,一个IP地址短时间内请求大量不同账户的登录可能是自动化脚本或VPN用户。

        动态分析:实时分析IP地址的行为模式,比如使用速度和流量模式,以识别非典型用途。

1.6.2.2 优点和缺点
1.6.2.2.1 优点
        提高安全性:阻止VPN和代理IP地址可以减少恶意用户的匿名性,从而降低网络攻击和欺诈的风险。

        内容地理限制:对于需要执行地理限制的服务,屏蔽VPN可以帮助执行这些限制。

        减少滥用:防止用户使用VPN绕过帐户限制、控制访问和执行一些形式的版权或访问控制。

1.6.2.2.2 缺点

        误拦截:屏蔽器可能会误将合法用户的VPN为恶意行为,尤其是那些出于隐私保护和安全性考虑使用VPN的用户。

        隐私问题:客户可能对于无法使用VPN保护自己的隐私而感到不满,这可能会影响用户体验并造成客户流失。

        持续维护:由于VPN服务商会不断变更和更新他们的IP地址,所以VPN屏蔽器需要不断更新其数据库才能保持有效。

        逃避技术:有些VPN服务提供“隐形”或“混淆”服务器,这些服务器能够逃避VPN检测,因此屏蔽器不可能完全有效。

        合法用途受限:在某些情况下,个人和公司可能需要使用VPN以安全地进行远程工作,VPN屏蔽可能不利于这些合法的商业活动。

        在实施VPN屏蔽器时,公司应当权衡这些优点和缺点,确保他们的安全措施不会对正常业务活动造成不利影响,同时要通知用户关于这种策略及其可能的影响。

2 安全 JAVA ('20 分钟)

        我们现在讨论的是有关 Java 安全性的课程以及相关的实验课。

2.1 问题 1

2.1.1 问题

        用一到两句话解释 Java 执行模型(Java 虚拟机)中引入的隔离执行机制(沙箱)的目标。

2.1.2 问题

        Java虚拟机(JVM)中引入的隔离执行机制,也称为沙箱(sandbox),主要目标是提供一个受限制的执行环境,其中代码可以在限定的资源和权限范围内运行,这样可以防止代码访问或更改系统的关键部分,确保了系统的安全性和数据的隔离。

2.2 问题 2

2.2.1 问题

        Java虚拟机的沙箱机制增强了哪些安全属性?

2.2.2 问题

        Java虚拟机的沙箱机制增强了以下几个安全属性:

        完整性:通过限制代码对系统资源的访问和修改,沙箱机制有助于保护系统和数据的完整性。

        机密性:确保敏感数据不被未经授权的代码访问,从而保护信息不被泄露。

        可用性:防止恶意代码消耗过多资源,如内存和CPU,确保系统资源的正常可用性。

        访问控制:通过实施细粒度的权限控制,沙箱机制有助于对执行环境中的代码进行严格的访问控制。

2.3 问题 3

2.2.1 问题

        用图表和相关说明描述在Java虚拟机的沙箱中执行一个Java应用程序的解决方案,以及在应用程序需要与远程服务器通信的情况下。指出可能使用的私钥/公钥。

2.2.2 问题

        客户端应用程序在沙箱中运行:Java 应用程序被加载到 Java 虚拟机(JVM)的沙箱环境中。这通常是通过设置安全管理器(Security Manager)和安全策略(Policy File)来实现的,确保应用程序只能在授予的权限范围内操作。

        设置安全策略:安全策略定义了应用程序可以执行的操作,例如访问网络、读写文件等。在我们的情况下,策略应允许应用程序与指定的远程服务器进行网络通信。

        使用密钥进行安全通信:如果应用程序需要安全地与服务器通信(例如通过 HTTPS 或使用加密的套接字),则可能需要使用公钥和私钥。这里有几个关键步骤:

        公钥基础设施:服务器会有一个与之关联的公钥证书,该证书由证书颁发机构(CA)签发,并包含了服务器的公钥。

        密钥交换:在建立连接时,客户端应用程序使用服务器的公钥来加密信息,确保只有拥有匹配私钥的服务器才能解密并读取这些信息。

        客户端认证(如果需要):如果服务器要求客户端认证,那么客户端也可能需要有自己的私钥/公钥对。客户端的公钥需通过证书形式提供给服务器验证。

        安全通信流程:客户端通过沙箱中的网络权限发起安全的网络连接(比如使用 SSL/TLS),在握手阶段交换密钥,然后在加密的通道中与服务器进行通信。

        验证和信任:客户端通常需要验证服务器的证书以确保其真实性。这通常涉及到检查证书是否由客户端信任的 CA 签发,以及证书中的公钥是否与服务器提供的公钥一致。

        在这个过程中,Java 应用程序运行在限制性的沙箱环境中,它只允许应用程序在定义好的安全策略下执行操作。所有的网络通信都是通过加密渠道进行的,确保数据传输的机密性和完整性,同时使用了公钥和私钥来确保通信双方的身份。

3 安全概览 ('30 分钟)

3.1 练习 1

        一个用户收到一封包含恶意内容的邮件。这封邮件包含一个URL地址,将用户重定向到一个假冒为他银行的恶意网站。

3.1.1 问题

        1. 用户正在遭受什么类型的攻击?

        2. 如果用户在没有意识到这是恶意链接的情况下点击了链接,攻击者能做什么?

        3. 他可以使用哪些安全措施来限制与这种类型的攻击相关的风险?

        4. 通过这个链接,用户下载了一个被篡改的程序。如果他安装了这样的程序,会有什么风险?他可以使用哪些安全最佳实践来预防这类风险?

3.1.2 问题解答

        1. 用户正在遭受的攻击类型是 网络钓鱼攻击(Phishing)。这种攻击通过伪装成可信实体(如银行)来诱骗用户提供敏感信息,如登录凭证、个人信息或财务信息。

        2. 如果用户点击了恶意链接,攻击者可以:

        窃取用户的个人和财务信息:通过伪装的登录页面收集用户输入的用户名和密码。

        安装恶意软件:诱使用户下载并安装包含恶意软件的程序,该软件可以用来进一步控制用户的设备或窃取信息。

        劫持会话:如果用户已登录到他们的真实银行账户,恶意网站可能试图劫持用户的会话来执行未经授权的交易。

        3. 用户可以采取以下安全措施来限制这类攻击的风险:

        谨慎对待邮件链接:不要点击未经验证的邮件中的链接。直接通过浏览器访问已知的、可信的网站,而不是通过邮件中的链接。

        使用双因素认证:即使攻击者获得了您的登录凭证,双因素认证也可以提供额外的安全层。

        安装安全软件Installation of security software:使用反病毒软件和防火墙,并保持它们的更新,以帮助检测和阻止恶意活动。

        教育和意识提升:了解网络钓鱼和其他网络安全威胁,提高对可疑邮件和链接的警觉性。

        4. 如果用户下载并安装了被篡改的程序,可能面临的风险包括:        

        恶意软件感染:如病毒virus、木马或勒索软件,可能损害系统、窃取敏感数据或锁定文件以索取赎金。

        系统漏洞:恶意程序可能会利用系统中的安全漏洞,以获得更高级别的访问权限或执行未经授权的操作。        

        隐私泄露:个人和财务信息可能被窃取并用于欺诈或身份盗用。

        为了预防这类风险,用户可以采取以下安全最佳实践:

        只从可信来源下载软件:避免从未经验证的网站下载软件,尽量使用官方网站或可信的应用商店。

        定期更新系统和软件:保持操作系统、浏览器和所有应用程序的最新状态,以修补已知的安全漏洞。

        使用反病毒软件:并定期扫描系统,以识别和清除恶意软件。

        限制程序权限:尽量不要以管理员权限运行未知的软件或应用程序。

3.2 练习 2

        一个用户在网站 www.mon-site-web.fr 上有一个账户,并通过输入地址:http://www.mon-site-web.fr 来连接到该网站。在这样的网站上,要求他进行认证,然后下载一个可执行程序。

        1. 连接到这样的网站真的安全吗?如果不安全,为什么?

        连接到使用 HTTP 协议的网站并不真正安全,因为 HTTP 不是加密的传输协议。这意味着在用户和网站服务器之间传输的所有数据(包括用户名和密码等敏感信息)都是以明文形式传输的,易于被中间人攻击者截取和查看。

        2. 可能有哪些网络安全风险?

        中间人攻击(MITM):攻击者可以拦截用户和网站之间的通信,窃取或篡改传输的数据。

        数据泄露:由于数据未加密,个人信息、登录凭据和其他敏感数据可能被泄露。

        身份盗窃:攻击者可以使用截获的凭据进行身份盗窃,从而进一步进行欺诈或非法访问用户的其他账户。

        恶意软件分发:如果网站被攻击者篡改,可能会向用户分发恶意软件,危及用户设备的安全。

        3. 我们希望使用基于信任第三方的 PKI 架构。

        (a) 回顾 PKI 架构的工作原理。

      公钥基础设施(PKI)是一种安全架构,旨在通过使用证书颁发机构(CA)和数字证书来提供安全的电子交易。PKI 使用一对公钥和私钥来实现数据的加密和数字签名。公钥是公开可用的,而私钥是保密的。当一个实体(如个人或组织)请求一个数字证书时,CA 会验证该实体的身份,并颁发一个包含该实体公钥的证书。这个证书可以用来验证持有者的身份,并确保交换的信息加密和完整。

        (b) 这样的架构能保证哪些网络安全属性?

        机密性:使用公钥加密数据,确保只有持有相应私钥的实体才能解密,保护数据不被未授权访问。

        完整性:通过数字签名确保数据在传输过程中未被篡改。

        认证:数字证书帮助确认一个实体的身份,确保通信双方是他们声称的那些人。

        不可否认性(或称为不可抵赖性):数字签名还提供了不可否认性,即数据的发送者不能否认他们发送的数据。

        采用基于 HTTPS(加上 SSL/TLS)的通信,可以利用 PKI 提供的这些安全属性,从而确保网站与用户之间的交易既安全又可靠。

4 密码学 ('30 分钟)

4.1 图的3-着色问题

4.1.1 3-着色问题

        给定一个有k个顶点的图G,图中有若干边,每条边连接图中的两个顶点。从一个顶点可以引出任意数量的边。

        如果可以为图G的每个顶点指派三种颜色之一(例如,黄色、红色和蓝色),使得G中没有任何一条边的两个端点着相同的颜色,则称图G是3-可着色的。

        3-着色问题是一个NP完全问题:如果G是一个任意的图,找到G的一个3-着色方案(如果它确实存在的话)是一个非常困难的问题。

4.1.2 零知识证明协议的三个原则

        我们提出使用这个问题来构建一个零知识证明协议。回顾一下零知识证明协议的三个原则:

        任何被授权的人总是能成功地认证自己,

        未被授权的人最终总会暴露自己,

        观察被授权的人进行认证的间谍不会学到任何能够用来认证自己的信息。

4.1.3 零知识证明协议在本问题的应用

        在这个练习中,我们将考虑四个人物:证明者(Prouveur),验证者(Vérifieur),欺骗者(Tricheur)和间谍(Espion)。

        证明者首先生成一个3-可着色的图:例如,他随机为k个顶点中的每一个分配一种颜色。然后,他随机生成顶点对(s1, s2),如果s1和s2没有被着上相同的颜色,则将s1和s2通过一条边连接。

        他继续这个过程,直到例如所有他最初生成的顶点至少与其他两个顶点连接,并且图是连通的(总是存在从任意两个顶点s1到s2的路径)。按照这种方法构造的图是3-可着色的,并且他知道一种着色方案。

        证明者公开他的图G,这样G就变成了公开信息,但他保留他的着色方案C作为秘密。

        一个顶点s的颜色记为C(s),C(s)只能取三种可能的值:黄色,红色或蓝色。

        此外,我们假设有一个众所周知的单向哈希函数h。

        证明者想要向验证者证明自己的身份。协议的一轮进行如下:

        1. 对于G中的每个顶点s,证明者随机抽取一个不同的随机数Rs(每轮和每个顶点的随机数都不同),并发送所有的哈希值h(s, C(s), Rs)给验证者。

        2. 验证者随机选取G中由一条边相连的两个顶点s1和s2。

        3. 证明者发送两个消息<s1, C(s1), Rs1>和<s2, C(s2), Rs2>给验证者。

        4. 验证者计算这两个消息的哈希值,并核实这些值是否与证明者在第一步中给出的值相匹配。如果还满足C(s1) ≠ C(s2),则这一轮顺利完成。

        使用这样的协议,显然证明者总是能成功地认证自己,因为他知道函数C。

4.2 问题14.1

4.2.1 问题

        随机数Rs的作用是什么?如果从协议中系统地去除这些随机数会发生什么?如果对所有的顶点s使用同一个随机数R会怎样?

4.2.2 问题解答

        随机数Rs的作用是确保每次证明过程中对于每个顶点发送的哈希值是独一无二的

        随机数Rs的作用是为了掩盖颜色C(s)。如果没有随机数Rs,那么冒名顶替者可以计算3个可能的哈希值h(s, C),其中C=红色、黄色或蓝色,并通过将这三个哈希值与证明者宣布的h(s, C(s))进行比较来找到C(s)的值。

        此外,如果对所有顶点s使用同一个随机数R,那么从证明者宣布了某个顶点s1的(s1, C(s1), R)起,冒名顶替者可以通过将h(s, C(s), R)与h(s, C, R)进行比较并测试C的3个可能值(红色、黄色、蓝色)来找出所有顶点的颜色。

4.2.3 问题的详细解答

        确保哈希值的唯一性:随机数R_s确保每次证明过程中,即使是相同的顶点和颜色组合,也会生成不同的哈希值。这样,每一轮的验证都是独一无二的,提高了协议的安全性。

        掩盖颜色信息:通过将颜色信息与随机数一起哈希,随机数R_s帮助隐藏真实的颜色值。如果没有随机数,攻击者或冒名顶替者可以通过计算和比较哈希值来揭露颜色信息。

        防止颜色信息泄露:如果对所有顶点使用相同的随机数R,那么一旦攻击者知道了一个顶点的颜色,就可以更容易地猜测或计算出其他顶点的颜色。这是因为相同的随机数R没有为每个顶点提供独立的 掩码 ,使得哈希值之间的比较可能揭示出颜色信息。

        具体来说,如果对所有顶点s使用相同的随机数R,冒名顶替者可以通过以下步骤来破解颜色:

        证明者公布了某个顶点s_1h(s_1, C(s_1), R)

        冒名顶替者对于每个其他顶点s,可以计算h(s, C, R)对于每种颜色C(红色、黄色、蓝色)的值。

        通过比较这些计算出的哈希值与证明者提供的哈希值,冒名顶替者可以推断出每个顶点的颜色。

        这样,使用相同的随机数R降低了协议的安全性,因为它使得攻击者通过比较和分析哈希值来推断颜色变得更加容易。因此,在设计零知识证明协议时,为每个顶点使用不同的随机数 R_s是非常重要的,以确保每次验证的独立性和增强整个协议的安全性。

4.3 问题14.2

4.3.1 问题

        我们现在来关注作弊者的情况。他不知道证明者的秘密(即G的3-着色方案),但仍然会尝试冒充证明者。因此,他获取了证明者的公开图G,并尝试按照3-着色规则对其进行着色。由于他不知道图是如何构造的,而且问题是NP完全的,他失败了。我们假设他能部分正确地对G进行着色。在他无法无冲突地着色的G的部分,作弊者犯了错误(即,边的两端颜色相同)。为了简化,我们认为他在着色时只犯了一个错误。他的着色因此是不完美的,在下文中我们记作C0。

        作弊者决定采取以下态度。他在协议的第一步向验证者发送他的着色C0的哈希值。如果验证者询问他正确着色的一条边(s1,s2),他发送消息<s1, C0(s1), Rs1>和<s2, C0(s2), Rs2>。

        如果验证者询问他未能正确着色的边,他会发送例如<s1, 黄色, Rs1>和<s2, 红色, Rs2>的消息,只要两种颜色不同即可。作弊者能以这种方式欺骗验证者吗?

4.3.2 问题解答

        作弊者不能以这种方式混淆验证者,因为在第一步中,他已经对<s1, C0(s1), Rs1>进行了"承诺",通过传输量h(s1, C(s1), Rs1)给验证者(对于顶点s2也是同样的情况)。这意味着如果验证者随机选取的边恰好是作弊者无法正确着色的边,作弊者在第三步中发送的颜色信息将与他最初"承诺"的信息不符,验证者通过哈希值就能发现作弊者的不一致性,从而揭露作弊者的欺诈行为。

4.4 问题14.3

4.4.1 问题

        如果哈希函数h构造不当,特别是容易发生碰撞,比如对于任意的顶点s和颜色c以及任何数r,都能相对容易地找到另一种颜色c0和一个随机数r0,使得h(s, c, r) = h(s, c0, r0)。在这种情况下,证明作弊者即使不知道图G的3-着色方案,也总能成功地认证自己。

4.4.2 问题解答

        如果哈希函数h容易发生碰撞,那么当作弊者在某个他未能正确着色的顶点s上受到质询时,他可以对随机数Rs进行 撒谎 。他可以修改随机数Rs1和Rs2的值以保持与第一步中宣布的值的一致性,同时宣称颜色C(s1) = C(s2)。

4.5 问题14.4

4.5.1 问题

        我们假设h是一个安全的哈希函数。设n是图G中边的数量。作弊者在一轮中成功认证的概率是多少?证明如果n很大,作弊者在n轮中成功认证的概率接近1/e。

4.5.2 问题解答

        我们假设在n条边中只有一条边着色错误。如果每一轮提出的问题彼此独立,那么在一轮中被抓到的概率是1/n,而在n轮中不被抓到的概率是:P = (1 - 1/n)^n

        如果n足够大,我们可以使用以下近似:

        log P = n log(1 - 1/n) \approx n × (-1/n)

         P \approx e^{-1}

        如果我们执行k轮协议,那么不被抓到的概率是(1 - 1/n)^k,当k趋向于无穷时,这个概率趋向于0。

4.5.3 数学公式

        首先,P = (1 - \frac{1}{n})^n是在一轮中没有被抓到的概率。为了估算这个表达式,我们取对数:

\log P = \log\left((1 - \frac{1}{n})^n\right)

        根据对数的幂规则,可以把指数拿出来:

\log P = n \log(1 - \frac{1}{n})

        当n很大时,\frac{1}{n}就很小,我们可以使用泰勒级数的第一项来近似\log(1 - \frac{1}{n}),即:

\log(1 - x) \approx -x \quad \text{for small} \ x

        因此,当x = \frac{1}{n}时:

        \log(1 - \frac{1}{n}) \approx -\frac{1}{n}

        所以,\log P可以写作:

        \log P \approx n \times \left(-\frac{1}{n}\right)

        \log P \approx -1

        那么P大约是:P \approx e^{-1}

        最后,e^{-1}是数学常数e(约等于 2.71828)的倒数,大约等于 0.367879441...,这意味着作弊者在一轮中成功认证自己的概率大约是36.79\%

        当n足够大时,通过重复这个过程n轮,我们可以得到作弊者在所有n轮中都成功认证自己的概率,使用同样的逼近方法,得到的结果接近于1/e。这种情况下,如果n轮都是独立的,作弊者在所有轮中都不被发现的概率随n增大而减少,最终趋向于\frac{1}{e}

4.6 问题14.5

4.6.1 问题

        因此,我们可以看到,通过增加轮数,作弊者最终总会暴露自己。现在,我们将关注间谍的情况:他观察了证明者的所有认证过程,希望从中获取足够的信息来冒充证明者。如果使用前述协议,展示间谍最终能完全发现证明者的着色方案。

4.6.2 问题解答

        在每一轮中,证明者会透露两个顶点的颜色。逐渐地,间谍学会了图的着色方案。

4.7 问题14.6

4.7.1 问题

        通过这种修改,证明者在每一轮的第一步开始前,随机改变其着色约定:他会随机交换初始着色方案中三种颜色的名称。在协议的第三步中,证明者才明确透露关于他着色方案的信息。有了这种修改,间谍能从消息中推断出什么信息?

4.7.2 问题解答

        随着证明者在每一轮中随机改变颜色名称的约定,间谍从任何特定轮次获取的信息将无法直接用于识别证明者的确切颜色方案。

        换句话说,即使间谍知道某两个顶点在特定轮次中不共享相同的颜色,由于颜色名称的随机置换,间谍无法确定这些颜色在证明者原始着色方案中的确切身份。因此,这种修改极大地减少了间谍能够从每轮交流中收集到的有效信息量,实际上使他无法从观察到的颜色分配中学到任何有关证明者原始着色方案的具体信息。

4.7.3 关于间谍的解释

        这段文字描述了一个零知识证明过程中对于防止作弊者和间谍获取有效信息的策略。在原始的协议中,通过多轮验证,作弊者尝试冒充合法证明者的行为最终会被揭露。对于间谍,他通过观察证明者的所有认证过程,希望能够获取足够的信息来模仿证明者。在没有修改前的协议下,间谍通过每一轮中证明者透露的两个顶点的颜色信息,逐步学习到整个图的着色方案。

        为了阻止间谍学习到有用的信息,协议被修改为在每一轮开始之前,证明者会随机改变颜色的标记(即颜色的命名或指派)。这意味着,即便间谍在某一轮中得知了两个顶点的颜色不同,由于颜色标记在每轮都会随机变化,间谍无法确定这些颜色在证明者的原始着色方案中对应哪些具体颜色。因此,这种协议的修改大大降低了间谍通过观察获取有用信息的能力,使其不能通过观察得到的颜色分配信息来准确了解证明者的原始着色方案。

        简而言之,这种协议的修改有效地保护了证明过程的安全性,防止了间谍和作弊者通过分析验证过程中的信息来破解或模仿合法证明者的身份。

4.8 问题14.7

4.8.1 问题

        与像Fiat-Shamir这样的协议相比,这个协议的主要缺点是什么?

4.8.2 问题解答

        密钥的大小。

        这个问题涉及到零知识证明协议的一个重要方面:效率和实用性。

        在零知识证明中,密钥的大小 通常指的是进行证明所需的数据量大小。一个零知识证明协议的效率,部分地由生成和验证证明所需的数据量来衡量。如果一个协议需要传输大量的数据才能完成身份验证,那么它可能在实际应用中效率低下,特别是在带宽有限或计算资源受限的环境下。

        Fiat-Shamir协议是一种非交互式零知识证明协议,通过将交互式的步骤转化为非交互式的,使用哈希函数来代替验证者的随机挑战。这种转换减少了通信的需求,使得证明过程更加高效,尤其是在需要远程验证的场景中。

        相比之下,上文讨论的协议,每一轮都需要证明者和验证者之间的交互,并且证明者需要为图的每个顶点生成和发送额外的信息(如随机数和颜色的哈希值)。如果图很大,或者为了达到高安全性需要执行许多轮,那么所需传输的数据量也相应增加。此外,证明者还需要在每轮开始前随机改变颜色约定,这增加了协议的复杂性。

        因此,与Fiat-Shamir协议相比,这个协议的主要缺点是可能需要更大的密钥(或证明数据)大小,从而影响了它的通信效率和实用性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1891375.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【IDEA配置一个maven项目(详细操作流程)】

目录 一、安装Maven 1、官网下载maven链接地址&#xff1a;Maven – Download Apache Maven 2、下载完成后&#xff0c;解压到某一路径下。E:\JavaTools\apache-maven-3.9.8为例&#xff0c;实际配置环境变量时以自己安装的路径为准。 二、配置环境变量 1、右键此电脑–&g…

MybatisPlus实现AES加密解密,实现yml配置文件中数据库连接信息如用户名,密码等信息加密解密

1 生成秘钥&#xff0c;使用AES工具生成一个随机秘钥&#xff0c;然后对用户名&#xff0c;密码加密 //数据库用户名和密码加密工具测试类 public class MpDemoApplicationTests {Testvoid contextLoads() {// 数据库用户名和密码String dbUsername"改成你的数据库连接用…

LabVIEW汽车转向器测试系统

绍了一种基于LabVIEW的汽车转向器测试系统。该系统集成了数据采集、控制和分析功能&#xff0c;能够对转向器进行高效、准确的测试。通过LabVIEW平台&#xff0c;实现了对转向器性能参数的实时监测和分析&#xff0c;提升了测试效率和数据精度&#xff0c;为汽车转向器的研发和…

Ubuntu查看opencv版本c++

✗命令行中直接输入&#xff1a; pkg-config --modversion opencv✔命令行中直接输入&#xff1a; pkg-config --modversion opencv4注解&#xff1a;附上在markdown中打勾&#xff0c;对号和打叉。使用时将&和#之间的空格去掉&#xff0c;这里只是为了不让CSDN自动转换才…

UE5 04-重新加载当前场景

给关卡加一个淡出的效果 给关卡加一个淡入的效果, 这个最好放置在Player 上,这样切关卡依然有这个效果

金斗云 HKMP智慧商业软件 任意用户创建漏洞复现

0x01 产品简介 金斗云智慧商业软件是一款功能强大、易于使用的智慧管理系统,通过智能化的管理工具,帮助企业实现高效经营、优化流程、降低成本,并提升客户体验。无论是珠宝门店、4S店还是其他零售、服务行业,金斗云都能提供量身定制的解决方案,助力企业实现数字化转型和智…

【系统架构设计师】计算机组成与体系结构 ⑨ ( 磁盘管理 | “ 磁盘 “ 单缓冲区 与 双缓冲区 | “ 磁盘 “ 单缓冲区 与 双缓冲区案例 )

文章目录 一、" 磁盘 " 单缓冲区 与 双缓冲区1、" 磁盘 " 单缓冲区2、" 磁盘 " 双缓冲区 二、" 磁盘 " 单缓冲区 与 双缓冲区案例1、案例描述2、磁盘单缓冲区 - 流水线分析3、磁盘双缓冲区 - 流水线分析 一、" 磁盘 " 单缓冲…

c++习题08-计算星期几

目录 一&#xff0c;问题 二&#xff0c;思路 三&#xff0c;代码 一&#xff0c;问题 二&#xff0c;思路 首先&#xff0c;需要注意到的是3^2000这个数值很大&#xff0c;已经远远超过了long long 数据类型能够表示的范围&#xff0c;如果想要使用指定的数据类型来保存…

介绍一些好玩且实用的开源的AI工具

介绍一些好玩且实用的开源的AI工具 随着人工智能技术的迅猛发展&#xff0c;开源社区涌现出了许多关于AI的项目&#xff0c;这些项目不仅展示了技术的创新力&#xff0c;也为开发者提供了丰富的工具和资源。本文将介绍几个既有趣又实用的开源人工智能工具&#xff0c;它们不仅…

【C++】 解决 C++ 语言报错:Use of Uninitialized Variable

文章目录 引言 使用未初始化的变量&#xff08;Use of Uninitialized Variable&#xff09;是 C 编程中常见且危险的错误之一。它通常在程序试图使用尚未赋值的变量时发生&#xff0c;导致程序行为不可预测&#xff0c;可能引发运行时错误、数据损坏&#xff0c;甚至安全漏洞。…

【机器学习】机器学习与电商推荐系统的融合应用与性能优化新探索

文章目录 引言第一章&#xff1a;机器学习在电商推荐系统中的应用1.1 数据预处理1.1.1 数据清洗1.1.2 数据归一化1.1.3 特征工程 1.2 模型选择1.2.1 协同过滤1.2.2 矩阵分解1.2.3 基于内容的推荐1.2.4 混合推荐 1.3 模型训练1.3.1 梯度下降1.3.2 随机梯度下降1.3.3 Adam优化器 …

Kubernetes 离线安装的坑我采了

Kubernetes 离线安装的坑我采了 一、Error from server: Get "https://xx.xx.xx.xx:10250/containerLogs/kube-system/calico-node-8dnvs/calico-node": tls: failed to verify certificate: x509: certificate signed by unknown authority二、calico 或 pod 启动正…

目标检测入门:2.使用预训练的卷积神经网络

目录 源码下载 一、ResNet&#xff08;Deep Residual Network&#xff0c;深度残差网络&#xff09; 1.残差结构 ​编辑 2.ResNet网络结构 3.pytorch搭建ResNet 二、CIFAR-10分类&#xff1a;ResNet预训练权重的迁移学习实践 1.CIFAR-10数据集 2.ResNet18实现CIFAR-10分…

该文件没有与之关联的程序来执行该操作,请安装应用,若已经安装应用,请在‘默认应用设置’页面中创建关联。

作为一个喜欢折腾桌面外观的人,我发现桌面上的快捷方式图标都有一个小箭头。于是,我按照网上的方法在注册表中删除了 IsShortcut 键。结果,重启后任务栏上的图标点击时出现了提示:“该文件没有与之关联的程序来执行该操作,请安装应用,若已经安装应用,请在‘默认应用设置…

Markdown+VSCODE实现最完美流畅写作体验

​下载VSCODE软件 安装插件 Markdown All in One &#xff1a;支持markdown的语言的&#xff1b; Markdown Preview Enhanced &#xff1a;观看写出来文档的效果&#xff1b; Paste IMage :添加图片的 Code Spell Checker检查英文单词错误&#xff1b; 基础语法 标题 #一个…

windows USB 设备驱动开发-USB描述符

配置描述符 USB 设备以一系列称为 USB 配置的接口的形式公开其功能。 每个接口由一个或多个备用设置组成&#xff0c;每个备用设置由一组端点组成。 配置描述符中描述了 USB 配置。 配置描述符包含有关配置及其接口、备用设置及其端点的信息。 每个接口描述符或备用设置均在 …

如何使用python网络爬虫批量获取公共资源数据教程?

原文链接&#xff1a;如何使用python网络爬虫批量获取公共资源数据教程&#xff1f;https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247608240&idx4&snef281f66727afabfaae2066c6e92f792&chksmfa826657cdf5ef41571115328a09b9d34367d8b11415d5a5781dc4c…

Audio Processing Graphs 管理 Audio Units

Audio Processing Graphs 管理 Audio Units Audio Processing Graphs 管理 Audio UnitsAudio Processing Graph 拥有精确的 I/O UnitAudio Processing Graph 提供线程安全通过 graph "pull" 音频流 Audio Processing Graphs 管理 Audio Units audio processing grap…

Flutter——最详细(Badge)使用教程

背景 主要常用于组件叠加上圆点提示&#xff1b; 使用场景&#xff0c;消息数量提示&#xff0c;消息红点提示 属性作用backgroundColor红点背景色smallSize设置红点大小isLabelVisible是否显示offset设置红点位置alignment设置红点位置child设置底部组件 代码块 class Badge…

Go语言学习:每日一练3

Go语言学习&#xff1a;每日一练3 目录 Go语言学习&#xff1a;每日一练3方法接口继承类型断言 方法 方法是一类有接收者参数的函数。 接收者的类型定义和方法的声明必须在一个包里 type MyInt intfunc (m MyInt) Add(add int) int {return int(m) add } //OR func (m *MyInt)…