信息加密——现代密码学

信息加密——现代密码学


前言

密码学技术的商业化转变发生在20世纪70年代,主要原因是计算机革命所引发的对大量的电子信息数据实施保护的需求。到20世纪70年代中期,甚至连美国政府也意识到对于安全加密技术存在着合法合理的商业诉求。


一、DES加密

DES加密是三大著名且经典的加密算法之一,为分组对称加密 算法。DES算法(或国产等效算法)在POS、ATM、磁卡及智能卡(IC卡)、加油站、高速公路收费站等领域被广泛应用,以此来实现关键数据的保密,如信用卡持卡人的PIN的加密传输,IC卡与POS间的双向认证、金融交易数据包的MAC(消息鉴别码Message Authentication Code)校验等。
DES采用了64位的分组长度和56位的密钥长度,它将64位的输入经过一系列变换得到64位的输出。解密则使用了相同的步骤和相同的密钥。参与加密的长度为56位,密钥空间含有2^56个密钥。
DES算法利用多次组合替代算法和换位算法,分散和错乱的相互作用,把明文编制成密码强度很高的密文,它的加密和解密用的是同一算法。
DES算法是一种分组加密机制,将明文分成N个组,然后对各个组进行加密,形成各自的密文,最后把所有的分组密文进行合并,形成最终的密文。
采用单钥密码系统的加密方法,同一个密钥可以同时用作信息的加密和解密,这种加密方法称为对称加密,也称为单密钥加密。
在这里插入图片描述

利用DES Tool对文本信息进行加密和解密:
在这里插入图片描述
对重复字符进行加密:
在这里插入图片描述

代码如下:

#include <bits/stdc++.h>
using namespace std;
string k;
struct node
{
   
    int c[80];
    int d[80];
    int cd[80];
    int k_n[80];
    int l[80];
    int r[80];
    node()
    {
   
        memset(c,0,sizeof(c));
        memset(d,0,sizeof(d));
        memset(k_n,0,sizeof(k_n));
        memset(l,0,sizeof(l));
        memset(r,0,sizeof(r));
    }
};
 
char mikey[18]={
   '0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
 
//IP初始置换表
int pc_ip[80]= {
   0,58,50,42,34,26,18,10,2,
                60,52,44,36,28,20,12,4,
                62,54,46,38,30,22,14,6,
                64,56,48,40,32,24,16,8,
                57,49,41,33,25,17,9,1,
                59,51,43,35,27,19,11,3,
                61,53,45,37,29,21,13,5,
                63,55,47,39,31,23,15,7};
 
//置换选择PC-1
int pc_1[60]= {
   0,57,49,41,33,25,17,
               9,1,58,50,42,34,26,
               18,10,2,59,51,43,35,
               27,19,11,3,60,52,44,
               36,63,55,47,39,31,23,
               15,7,62,54,46,38,30,
               22,14,6,61,53,45,37,
               29,21,13,5,28,20,12,4};
 
//置换选择PC-2
int pc_2[60]= {
   0,14,17,11,24,1,5,
               3,28,15,6,21,10,
               23,19,12,4,26,8,
               16,7,27,20,13,2,
               41,52,31,37,47,55,
               30,40,51,45,33,48,
               44,49,39,56,34,53,
               46,42,50,36,29,32};
 
//E盒扩展变换
int pc_e[80]= {
   0,32,1,2,3,4,5,
               4,5,6,7,8,9,
               8,9,10,11,12,13,
               12,13,14,15,16,17,
               16,17,18,19,20,21,
               20,21,22,23,24,25,
               24,25,26,27,28,29,
               28,29,30,31,32,1};
 
//P盒置换表
int pc_p[80]= {
   0,16,7,20,21,
               29,12,28,17,
               1,15,23,26,
               5,18,31,10,
               2,8,24,14,
               32,27,3,9,
               19,13,30,6,
               22,11,4,25};
 
//逆初始置换表
int pc_ip_1[80]= {
   0,40,8,48,16,56,24,64,32,
                  39,7,47,15,55,23,63,31,
                  38,6,46,14,54,22,62,30,
                  37,5,45,13,53,21,61,29,
                  36,4,44,12,52,20,60,28,
                  35,3,43,11,51,19,59,27,
                  34,2,42,10,50,18,58,26,
                  33,1,41,9,49,17,57,25};
 
//S盒
int s_box[8][4][16]={
   
	14,4,13,1,2,15,11,8,3,10,6,12,5,9,0,7,
	0,15,7,4,14,2,13,1,10,6,12,11,9,5,3,8,
	4,1,14,8,13,6,2,11,15,12,9,7,3,10,5,0,
	15,12,8,2,4,9,1,7,5,11,3,14,10,0,6,13,
 
	15,1,8,14,6,11,3,4,9,7,2,13,12,0,5,10,
	3,13,4,7,15,2,8,14,12,0,1,10,6,9,11,5,
	0,14,7,11,10,4,13,1,
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MMX-密码学书籍包-共3部分.zip.001 注意:本资源一共三部分,只有把三部分都下载了放在同一目录下才能完全解压缩成功! 剩下两部分在这里: MMX-密码学书籍包-共3部分.zip.002 全部 pdf-CSDN下载 http://download.csdn.net/download/bjarnecpp/10197748 MMX-密码学书籍包-共3部分.zip.003 全部 pdf-CSDN下载 http://download.csdn.net/download/bjarnecpp/10197733 详细内容见这里: http://blog.csdn.net/bjarnecpp/article/details/79012425 本压缩包包含书籍 计算机安全和密码学.Computer.Security.And.Cryptography.pdf 英文版 《深入浅出密码学——常用加密技术原理与应用》-有书签.pdf 程序员密码学.pdf 计算机加密解密200例-带书签.pdf 计算密码学+卢开澄-走向数学丛书.pdf 经典密码学与现代密码学.pdf 带自制 书签 密码学的数学基础-英文版-Jeffrey+Hoffstein.pdf 密码编码学:加密方法的C与C++实现.pdf -带书签 密码编码学与网络安全 原理与实践(原书第5版)和习题解答 共2本.pdf 密码学基础[以色列]Oded.Goldreich 英文三本书.zip 密码学-加密算法-带目录.pdf 密码学原理与实践-冯登国译-带书签.pdf 《密码学实践》电子工业出版社,作者是(美)弗格森 椭圆曲线及其在密码的应用(英文).pdf 椭圆曲线密码学导论.pdf 应用密码学:协议、算法与c源程序.PDF(两本,一本完整版,一本不完整高清文字版).zip 应用密码学(英文版 Applied Cryptography - Bruce Schneier 2nd ed).pdf 应用密码学——协议、算法、C源程序.pdf 战争的数学——军事密码学,李长生,邹祁编著.pdf 信息论、编码与密码学 田丽华.pdf 应用密码学手册 英文版 Handbook of Applied Cryptography.pdf -有书签 文字版
MMX-密码学书籍包-共3部分.zip.002 注意:本资源一共三部分,只有把三部分都下载了放在同一目录下才能完全解压缩成功! 详细内容见这里: http://blog.csdn.net/bjarnecpp/article/details/79012425 本压缩包包含书籍 计算机安全和密码学.Computer.Security.And.Cryptography.pdf 英文版 《深入浅出密码学——常用加密技术原理与应用》-有书签.pdf 程序员密码学.pdf 计算机加密解密200例-带书签.pdf 计算密码学+卢开澄-走向数学丛书.pdf 经典密码学与现代密码学.pdf 带自制 书签 密码学的数学基础-英文版-Jeffrey+Hoffstein.pdf 密码编码学:加密方法的C与C++实现.pdf -带书签 密码编码学与网络安全 原理与实践(原书第5版)和习题解答 共2本.pdf 密码学基础[以色列]Oded.Goldreich 英文三本书.zip 密码学-加密算法-带目录.pdf 密码学原理与实践-冯登国译-带书签.pdf 《密码学实践》电子工业出版社,作者是(美)弗格森 椭圆曲线及其在密码的应用(英文).pdf 椭圆曲线密码学导论.pdf 应用密码学:协议、算法与c源程序.PDF(两本,一本完整版,一本不完整高清文字版).zip 应用密码学(英文版 Applied Cryptography - Bruce Schneier 2nd ed).pdf 应用密码学——协议、算法、C源程序.pdf 战争的数学——军事密码学,李长生,邹祁编著.pdf 信息论、编码与密码学 田丽华.pdf 应用密码学手册 英文版 Handbook of Applied Cryptography.pdf -有书签 文字版
MMX-密码学书籍包-共3部分.zip.003 注意:本资源一共三部分,只有把三部分都下载了放在同一目录下才能完全解压缩成功! 详细内容见这里: http://blog.csdn.net/bjarnecpp/article/details/79012425 本压缩包包含书籍 计算机安全和密码学.Computer.Security.And.Cryptography.pdf 英文版 《深入浅出密码学——常用加密技术原理与应用》-有书签.pdf 程序员密码学.pdf 计算机加密解密200例-带书签.pdf 计算密码学+卢开澄-走向数学丛书.pdf 经典密码学与现代密码学.pdf 带自制 书签 密码学的数学基础-英文版-Jeffrey+Hoffstein.pdf 密码编码学:加密方法的C与C++实现.pdf -带书签 密码编码学与网络安全 原理与实践(原书第5版)和习题解答 共2本.pdf 密码学基础[以色列]Oded.Goldreich 英文三本书.zip 密码学-加密算法-带目录.pdf 密码学原理与实践-冯登国译-带书签.pdf 《密码学实践》电子工业出版社,作者是(美)弗格森 椭圆曲线及其在密码的应用(英文).pdf 椭圆曲线密码学导论.pdf 应用密码学:协议、算法与c源程序.PDF(两本,一本完整版,一本不完整高清文字版).zip 应用密码学(英文版 Applied Cryptography - Bruce Schneier 2nd ed).pdf 应用密码学——协议、算法、C源程序.pdf 战争的数学——军事密码学,李长生,邹祁编著.pdf 信息论、编码与密码学 田丽华.pdf 应用密码学手册 英文版 Handbook of Applied Cryptography.pdf -有书签 文字版

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值