基于DES算法加密的防撞库密码系统项目总结
项目内容:基于DES算法加密的防撞库密码系统
- 小组名:zqhzkzkj
- 目标:1.对用户输入的8位字符进行DES加密,要求用户输入8位密钥
2.对于不同的网站,不同的用户名生成不同的密码 小组成员:周岐浩、钟轲、郑凯杰
实验内容:
为了防止一个用户在不同的网站使用同一个密码,而导致一个网站被破译所有网站都被破译,于是我们修改了我们的项目。
分为四大步:
- 一、给定64bit的明文M,通过一个固定初始置换IP得到M0
- 二、进行16轮相同迭代运算,这些运算被称为轮函数f
- 三、对比特串R16L16使用逆置换IP-1,得到M1
四、把网址作为加密的明文,用户名作为加密的密钥,加密后的密文作为密码
根据这四大步我们把我们要完成的工作细化为:
- 1.界面
- 2.把用户输入的8位字符变为64bit的2进制数
- 3.对64bit进行IP置换得到M0
- 4.IP-1的逆置换
- 5.把64bit分为各32bit的L0与R0
- 6.任意长度的按位异或
下面是轮函数内容
- 7.对32bit进行重排变为48bit
- 8.与48bit的密钥进行异或
- 9.s-盒置换
- 10.p置换
下面是生成密钥的内容
- 11.64bit密钥进行PC-1置换
- 12.分为左右各28bit的c0与d0
- 13.循环左移得到c1与的d1
- 14.PC-2置换
防撞库设计:
- 1.注册/登录界面:用户输入账号及密码
- 2.设置界面:用户输入网址和用户名,把网址转换为明文,用户名转换为密钥。通过我们设置的DES算法加密出密文,并记录每个网址和用户名所生成的密文。
- 3.下次再登录该网址可以验证是否正确
完成情况:
- 可喜可贺的是我们完成了所有的任务
下面介绍一下我们项目流程
第一步 弹出窗口
-
由于我们是第一次使用,所以我们点击注册按钮第二步 注册
这里我们针对不同的用户的和不同的网址来生成不同的密码(实质是使用用户名当做明文,网址当做密钥)
当然这里是把密码以txt的形式记录下来
- 第三步 登录
回到登录界面输入刚刚注册得到的密码
当然假如输入错误
每个人完成的方面
- 钟轲:完成了轮函数内容(7-10步)与界面(防撞库的三步)的内容
- 郑凯杰:完成了第3-6步,与周岐浩一起完成了第二步
- 周岐浩:完成了密钥轮换的内容(11-14)
三人一起完成了主函数的编写
三人得的分数分配:钟轲30分,周岐浩25分,郑凯杰20分
基于DES算法加密的防撞库密码系统项目总结的更多相关文章
- 使用DES算法实现加密解密
使用DES算法实现加密解密 我们常见的加密算法有DES.MD5.IDEA.AES等等,这篇随笔介绍使用DES算法实现加密解密 首先介绍一下DES算法: DES算法为密码体制中的对称密码体制,又被称为美 ...
- 对称加密算法之DES算法
数据加密标准(data encryption standard): DES是一种分组加密算法,输入的明文为64位,密钥为56位,生成的密文为64位. DES对64位的明文分组进行操作.通过一个初始置换 ...
- 使用openssl库实现des,3des加密
原文地址: 使用openssl库实现des,3des加密 主要是调整了一下格式,以及一些变量的类型,以解决在VC2008下无法编译通过的问题. #include <stdio.h> #in ...
- 【Android工具】DES终结者加密时报——AES加密演算法
转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992 在前面的两篇文章中.我们介绍了DES算法,3DES算法以及他们的Android程序实现,并研究了怎样才干实现 ...
- 在IOS中使用DES算法对Sqlite数据库进行内容加密存储并读取解密
在IOS中使用DES算法对Sqlite 数据库进行内容加密存储并读取解密 涉及知识点: 1.DES加密算法: 2.OC对Sqlite数据库的读写: 3.IOS APP文件存储的两种方式及读取方式. 以 ...
- Asp.Net 常用工具类之加密——对称加密DES算法(2)
又到周末,下午博客园看了两篇文章,关于老跳和老赵的程序员生涯,不禁感叹漫漫程序路,何去何从兮! 转眼毕业的第三个年头,去过苏州,跑过上海,从一开始的凌云壮志,去年背起行囊默默回到了长沙准备买房,也想有 ...
- Python实现基于DES加密源码的文本加密器
这是自行制作的一个DES文本加密工具 最终效果图: 本加密器支持UTF-8字符的加解密(包含中文),由于其中的编码方式与常用编码方式不同,加密结果与网上工具不同,但是能实现正常加解密. 最终目标: 目 ...
- DES的加密与解密算法(Python实现)
DES的加密与解密算法(Python实现) 密码学实验:实现了DES的简单的加密和解密算法,DES算法的相关资料网上很多,这里不再赘述,仅仅贴出源代码给大家分享,源码中包含很多汉字注释,相信大家都是可 ...
- C#与Java同步加密解密DES算法
在实际项目中,往往前端和后端使用不同的语言.比如使用C#开发客户端,使用Java开发服务器端.有时出于安全性考虑需要将字符加密传输后,由服务器解密获取.本文介绍一种采用DES算法的C#与Java同步加 ...
随机推荐
- jquery动态加载问题
对于append的元素,原有的方法不生效 解决:用on方法 找到的:http://www.zhidao91.com/jquery-html-live-on/ 解决使用jQuery采用append添加的 ...
- DOS实用命令/工具
winver 检查Windows版本wmimgmt.msc 打开windows管理体系结构wupdmgr windows更新程序wscript windows脚本宿主设置write 写字板w ...
- Transform.InverseTransformPoint 反向变换点
JavaScript ⇒ public function InverseTransformPoint(position: Vector3): Vector3; C# ⇒public Vector3 I ...
- final关键字+const关键字
final关键字 1.如果我们希望某个类不被其它的类来继承(可能因为安全考虑),可以使用final. 例题 <? final class A{} class B extends A{};//会报 ...
- wget ftp
今天操作远端机器的时候发现少一个安装包, 需要传到对方的机器上,还能使用通过的老办法,直接SSH连上去了,发现传的很慢, 只有40K的样子, 看时间还需要二个多小时就有点受不了了.想想有一台FTP服务 ...
- GPG操作——签名验证
问题描述: 可能大家都遇到过软件在下载过程中由于网络原因导致下载的软件体积与实际软件体积不符.最常见的办法是对待下载文件附加一个摘要文件.这种做法比较常见,也比较容易实现.但是,还是会有一个问题:如果 ...
- HashSet HashTable HashMap的区别
(1)HashSet是set的一个实现类,hashMap是Map的一个实现类,同时hashMap是hashTable的替代品(为什么后面会讲到). (2)HashSet以对象作为元素,而HashMap ...
- Google物联网操作系统协同框架Weave深度解析
1. Google Weave框架 在2015年的Google I/O大会上,负责Android业务的桑达.皮查伊(SundarPichai)宣布了Google最新的物联网战略.这包括一个 ...
- Android Handler简单示例
package com.firstapp.foo.firstapp; import android.os.Handler; import android.os.Message; import andr ...
- git项目版本管理
一个很小的HTML项目,使用.Git来记录和跟踪这个项目.包括以下内容: 创建版本库. 添加与修改文件. 创建新分支. 打标签并整理版本库. 克隆版本库. 创建版本库 Creating a Repos ...