密码学课程设计报告要求及模板.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机与信息工程学院 《密码学课程设计》报告 (2013/2014学年 第 二学期) 题 目: Diffie-Hellman密钥交换协议 系 别: 计算机与信息工程学院 专 业: 信息安全 班 级: 学 号: 姓 名: 成绩类别 成 绩 个人考勤(20) 实践成绩(40) 总结报告(40) 总成绩(100) 等级制成绩 2014年05月30日 (一)题目Diffie-Hellman密钥交换协议 (二)开发工具与环境: window7环境下的Visual Studio2010 (三)设计原理: Diffie-Hellman算法的安全性基于求离散对数的困难性。算法的惟一目的是使得两个用户能够安全地交换密钥,得到一个共享的会话密钥,算法本身不能用于加、解密,因此,这里用产生的最终的密钥作为仿射变换加密的密钥来实现对消息的加解密。 Diffie-Hellman的设计原理如下:A和B两方要生成共享密钥Y,则首先选定一个大素数p,以及p的原根g,p,g为双方共享,用户A选择一保密的随机证书Xa,并将Ya=g^Xa modp发送给用户 B,类似,B选择一保密的随机整数Xb,并将Yb=g^Xb modp发送给用户A.之后A和B分别由Y=Yb^Xa modp和Y=Ya^Xb计算出的就是共享密钥。因为Xa,Xb是保密的,敌手只能得到p,a,Ya,Yb,要想得到Y,必须得到Xa,Xb中的一个,这意味着要求离散对数,因此敌手求Y是不可行的,保证了安全。 (四)系统功能描述及软件模块划分 系统需手动输入随机数Xa,Xb,点击确定后可以隐藏输入的随机数。在原文框中输入需要处理的原文,选择加密或者解密按钮,在结果框中会生成对应的解密或者加密的结果。 系统共分为两个模块,一块是Diffie-Hellman模块,用来处理输入的随机数,系统随机生成大素数并找到该大素数的原根,再按照算法思想最终生成共享密钥Y.Mainwindow 模块通过函数接收Diffie-Hellman模块的密钥 (五)设计的核心代码 MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui-setupUi(this); label1=findChildQLabel*(label1); label2=findChildQLabel*(label2); label3=findChildQLabel*(label3); label4=findChildQLabel*(label4); text1=findChildQTextEdit*(textEdit1); text2=findChildQTextEdit*(textEdit2); yuanwen=findChildQTextEdit*(textEdit3); jieguo=findChildQTextBrowser*(textBrowser1); queren=findChildQPushButton*(pushButton1); jiami=findChildQPushButton*(pushButton2); jiemi=findChildQPushButton*(pushButton3); fanhui=findChildQPushButton*(pushButton4); init();} MainWindow::~MainWindow() {delete ui;} void MainWindow::on_pushButton1_clicked() { unsigned __int64 p,g,Alice_Y,Bob_Y,Alice_key,Bob_key; DiffieHellman Alice,Bob; Alice.init(); Bob.init(); Alice.CreatePrimeAndGenerator(); p=Alice.GetPrime(); g=Alice.GetGenerator(); Bob.SetPrimeAndGenerator(p,g);

文档评论(0)

wuailuo + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档