加解密技术(Cryptography)基本概念

转载自:http://www.cnblogs.com/piyeyong/archive/2010/06/10/1744692.html

要想实现在不安全的网络上的安全通信,需要考虑3个方面的问题:保密(Privacy),认证(Authentication),完整性(Integrity)。

1.保密(Privacy)

数据在网络传输的过程中,需要经过多个中间节点进行转发,因此,数据很容易就被截获,为了保证数据的保密性,就需要对数据进行加密传输,使用密文进行传输。

图一 加解密数据

如上图所示,明文数据(plaintext)经过加密算法(Encryption Algorithm)得到密文(ciphertext),在网络中传输,到达目的地后,再经过解密算法(Decryption Algorithm)还原成原文。

在网络中传输的是密文,即使被第三方截获,也不能解析其含义。注意,这里的加密和解密算法是公开的,如对称算法DES,3DES,非对称算法RSA 等,任何人都可以得到,但是每种算法都需要有一个KEY作为输入,对称算法与非对称算法的区别就在于加密的KEY和解密的KEY是否一样,一致的是对称算 法。

由于非对称机密在效率上比对称加密慢100倍以上,并不适合对大数据量的原文使用非对称加密,在实际的加密传输过程中,会随即生成一个对称密钥 (session key),使用该对称算法对原文进行加密,同时使用非对称算法将session key进行加密,一起传输给对方,接收者使用private key将session key还原后再用对称算法对数据进行解密。

 

2.认证(Authentication)

数据的接收方在收到数据后,为了验证数据确实是从发送着发送的,而不是第三方冒充的,就需要对发送方进行认证。认证需要使用一个凭据,即数字证书 (Certificate),相当于个人的护照。Certificate由专门的证书管理机构发放,就是我们常说的CA(Certificate Authority)。Certificate含有发放者(Issued by),使用者(Subject),公钥私钥等信息,并且是被CA使用自己的证书签名的。我们验证身份的时候,实际是相信发放证书的CA,就好比我们查看 护照的时候是相信发放证书的国家一样。这里需要详细说明一下签名。

如上图所示,使用Private key对明文进行加密计算,得到数字签名,改签名只能使用Private key对应的Public key才能解密,重新得到原文。Public key是公开的,所有人都可以得到,并且知道该Public key是属于谁的.如果A要发送数据给B,A就用自己的Private key计算签名,发给B,B再使用A的Public key进行验证,如果能计算出原文,则证明该数据确实是A发送的。而第三方C如果想假冒A给B发送数据,由于没法得到A的private key,就没法对数据进行签名,如果使用任意key签名,B在收到数据后使用A的public key解密时就会发现数据无法还原,从而发现数据是假冒的。实际的应用场景是这样的:

A首先对要发送的数据计算Hash,只对该Hash进行签名,这样会大大提高效率,然后将原文和签名一起发送(为了保证原文的Privacy,需要 使用B的public key进行加密,只有拥有private key的B本人才能进行解密),B在收到后,使用同样的Hash算法对原文计算Hash(如果原文加密,要先进行解密哦),同时对数字签名使用A的 public key解密,比较两者是否一致,不一致就说明数据不是由A发送过来的。

由于只有A本人采用与自己的Private key,所以数字签名还具有不可抵赖性。

 

3.完整性(Integrity)

即使数据被加密传输,第三方无法知道传输的内容,但是当第三方还是可以进行破坏活动,例如将数据截取一半,再发给接收者,接收者进行解密后并不知道 数据已经被截断。为了保证传送的数据完整性,需要对接收到的数据进行完整性校验,可以使用hash算法,对原文计算hash,接收者验证hash即可,过 程参照上一小节数字签名部分。

转载于:https://www.cnblogs.com/langqi250/archive/2012/09/26/2704376.html

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

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

相关文章

select的列子说明select内部实现原理

1:select内部是个数组,而epoll内部结构是红黑二叉树 2:select查询起来慢,而epoll查询起来快 3:每次循环,内部都要发生拷贝(查看相关代码)而epoll不需要这样的操作,也就是初始化一次拷贝 #include #include&…

.NET配置文件读写实例(附SosoftConfigHelper类)

配置文件在软件开发中起到举足轻重的作用,可以说不可或缺。.NET程序可使用.config文件作为配置文件,例如WinForm程序的*.app.config、Web程序的web.config。.config文件是标准的XML文件。本实例可读取、修改和添加app.confing或者web.config文件的appSet…

关于shared_from_this的转换

声明&#xff1a;以下这函数&#xff0c;使用场景再lambda表达式中使用 std::weak_ptr<websockets_session> weak_self() { return std::weak_ptr<websockets_session>(shared_from_this()); }

HTML5标签

<header>主要用于导航&#xff0c;头部&#xff0c;可以嵌套&#xff0c;但不可以嵌套在<address>标签中。 <hgroup>在<header>里面定义具体内容的&#xff0c;是一个小容器。 <article></article>:大块文章&#xff0c;主要用于文字的显示…

多态的调用方法

1: 父类的指针指向子类的地址&#xff0c;然后调用虚函数 列子: #include<iostream> #include<memory> class A { public: A() default; virtual ~A() default; virtual void display() { std::cout << "A" <<…

spring security3 统计在线用户

首先&#xff0c;我们需要使得ConcurrentSessionFilter生效并在spring-security.xml配置。[html] view plaincopy<http auto-config"true" use-expressions"true"> <!-- Uncomment to limit the number of sessions a user can have --> …

node.js编程错误记录集

这是有关于我最近学习node.js中出现的错误的记录和纠正过程&#xff0c;因为我只是一名初学者&#xff0c;所以&#xff0c;遇到的错误可能真的是非常简单&#xff0c;如拼写错误等等&#xff0c;这些我当然是不会记录下来的&#xff0c;但是如果是一些我一时看不懂&#xff0c…

wstring和string简单正则表达式使用

std::regex e("([ ])3DSMAX(\d{4})_MAIN([^ ])"); //std::regex e("([^ ])3DSMAX(\d{4})_MAIN"); std::smatch sub_match; //从第一行中解析请求方法、路径和 HTTP 版本 std::string line “VRAY30_RT_FOR_3DSMAX2016_MAIN”; if (std::regex_match(line,…

【引用】phpmyadmin提示Access denied for user 'root'@'localhost' (using password: NO)的解决办法...

一、错误内容 今天用phpmyadmin连接mysql里面的某个数据库时时遇到了下面的提示&#xff1a; #1045 - Access denied for user rootlocalhost (using password: NO) phpMyAdmin 试图连接到 MySQL 服务器&#xff0c;但服务器拒绝连接。您应该检查 config.inc.php 中的主机、用户…

Nuget 启用数据库迁移的时候一定要把包含DbContext的项目设为启动项目

在为项目启用数据库迁移的时候&#xff08;enable-migrations&#xff09;出现如下错误&#xff1a; 在程序集“XX”中未找到迁移配置类型“XX.Migrations.Configuration” 之前一直正确的&#xff0c;并没有修改项目中的代码&#xff0c;花了小半天找原因&#xff0c;stackove…

string、wstring、UTF-8、UTF-16、UTF-32之间转换

//string转wstring std::wstring string_to_wstring(const std::string& str) { setlocale(LC_ALL, “”); std::int64_t size mbstowcs(NULL, str.c_str(), 0); std::wstring w_str; w_str.resize(size); //算出代转wstring字节 mbstowcs(w_str.data(), str.c_str(), str…

论贱人

来源于我在论坛的一帖&#xff0c;个中缘由不说也罢。<<论贱人>> 天地阴阳&#xff0c;构精而生万物&#xff0c;万物生而后人生。物有性格&#xff0c;人亦有性格。性有善恶之分&#xff0c;格有贵贱之别。古人尝论人性之善恶&#xff0c;孟子云人性本善&#xff…

Delphi用ini文档实现界面无闪烁多语言转换

越来越多的程序使用了多国语言切换&#xff0c;虽然DELPHI自带多语言包的添加和配置&#xff0c; 但是那种方法在切换语言时界面会出现闪烁&#xff0c;而且实现起来很麻烦&#xff0c;这里我介绍给大家的是利用INI文件来读取界面的语种文字&#xff0c; 用这种方法&#x…

vi交互式批量替换 vi批量替换 vi查找和替换

vi中如何实现批量替换&#xff1f; 举个例子啊&#xff1a; 将文件tihuan&#xff08;假设此文本中字符a&#xff09;中的所有字符a换成字符w&#xff0c;其命令为&#xff1a; 1。vi tihuan 2。按esc键 3。按shift&#xff1a; 4。在&#xff1a;后输入 %s/a/w/g 其中s为&a…

linux的开始

这个星期天我去同学聚会了&#xff0c;开封的来了个同学李永生&#xff0c;新乡的来了个同学陈凯&#xff0c;大家在周六下午在一块吃了个饭&#xff0c;虽说有些小插曲&#xff0c;&#xff08;保成的女朋友和桂林&#xff08;桂皮&#xff09;来晚了&#xff09;&#xff0c;…

内联命名空间(inline namespace)

#include<iostream> //直接使用,不需要using inline namespace B { class A { public: A() default; ~A() default; void display() { std::cout << "a" << std::endl; } }; } i…

WordPress主题制作常用代码集合

如何你是个wordpress主题设计者&#xff0c;可能会在制作wordpress主题时为了一些寻找合适的wordpress代码焦虑&#xff0c;这里搜集总结wordpress主题开发中常用的代码片段&#xff0c;希望为你工作中带来方便 最新文章最新更新文章/页面最新评论最受欢迎文章文章分类下拉框文…

电脑配置多个git账号

配置user1 Host u1.github.com HostName github.com IdentityFile C:\Users\admin\.ssh\id_rsa1 PreferredAuthentications publickey User user1 配置user2 Host u2.github.com HostName github.com IdentityFile C:\Users\admin\.ssh\id_rsa PreferredAuthentications pub…

[Effective C++读书笔记]003_条款03_尽可能使用const

参考同事博客&#xff1a;http://www.cnblogs.com/hustcser/archive/2012/10/19/2731085.html转载于:https://www.cnblogs.com/alephsoul-alephsoul/archive/2012/10/17/2727057.html

sizeof操作

C98, sizeof只能对实例的变量或者类的静态成员进行操作&#xff0c;不能对类的非静态成员进行操作&#xff0c;若要想达成对类的非静态成员的操作&#xff0c;可以用如下ugly方式, 0强转成对象的指针&#xff0c;并解析访问对应非静态成员变量。 struct SomeType { int member…