Http协议(5)—HTTP摘要认证

一、摘要认证的改进
1.用摘要保护密码
客户端不发送密码,而是发送一个摘要,服务端只需验证这个摘要是否和密码相匹配

2.单向摘要
a.摘要是一种单向函数,将无限的输入值转化为有限的
b.常见的摘要为MD5:
将任意长度的字节序列转换为一个128位的摘要;
MD5的128位摘要通常会被写成32个十六进制的字符,每个字符4位

3.用随机数防止重放攻击
a.黑客可以截获摘要对服务器无限制的重发攻击
b.可以将随机数添加到密码中,然后再根据具有随机数的密码生成摘要,这样每次生成的
摘要都不相同,可以防止重放攻击

4.摘要认证的握手机制      
(1).服务器计算出一个随机数
(2).服务器将此随机数放在www-Authenticate中,随算法列表一起发往客户端
(3).客户端选择一个算法,计算出密码和其他数据摘要
(4).客户端将摘要放在一条Authorization响应中发往服务端
(5).服务器根据客户端发送的响应计算出相同的摘要,然后服务器将本地生成的摘要与网络
传送过来的摘要进行比较,验证是否匹配

二、摘要计算
1.摘要算法的输入数据
a.由单向散列函数H(d)和摘要KD(s,d)组成的一对函数,s为密码,d为数据
b.一个包含安全信息的数据块,称为A1
c.一个包含请求报文中非保密属性的数据块,成为A2
2.算法H(d)和KD(s,d)
H(<data>) = MD5(<data>)    
KD(<secret>,<data>) = H(concatenate<secret>:<data>)

3.与安全相关的数据(A1)
密码和受保护信息的产物,包含用户名、密码、保护域、随机数
MD5
为每条请求运行单向散列函数,A1是由冒号连接起来的用户名、域、密码
MD5-sess
只在第一次www-Authenticate握手时运行一次散列函数
算法对A1的定义
ps:nonce为当前随机数;cnonce为客户端随机数            

4.与报文有关的数据(A2)
包括URL、请求方法、报文实体,有助于防止方法、资源或报文被篡改
根据保护质量(qop),为A2提供两种策略:
a.只包含HTTP请求方法和URL,默认
b.添加报文实体,当qop="auth-init"时使用
算法对A2的定义
ps:request-method为请求方法;uri-directive-value为请求URI

5.摘要认证会话
客户端响应对保护空间的WWW-Authenticate质询时,会启动一个此保护空间的认证对话

6.预授权
摘要认证:
a.服务器预先在Authentication-Info首部中发送下一个随机数
b.服务器允许在一小段时间内使用同一个随机数
c.客户端和服务器使用同步的、可预测的随机数生成算法

7.随机数的选择
BASE64(time-stamp H(time-stamp ":" ETag ":" private-key))
time-stamp:服务器产生的时间戳
ETag:与所请求实体有关的ETag首部
private-key:只有服务器知道的数据

8.对称认证
客户端对服务器的认证

三、增强保护质量(报文完整性检查)
在三种摘要首部中提供qop字段:
WWW-Authenticate
Authorization
Authentication-Info

1.报文完整性保护(qop="auth-init")

四、应该考虑的实际问题
1.多重质询
服务器可以对某个资源发起多重质询,即既提供基本认证,又提供摘要认证
2.差错处理
认证服务器一定要确保URI指令指定的资源与请求行中指定的资源相同,否则返回400  BadRequest错误
3.保护空间
.域值与被访问服务器的标准根URL结合在一起定义了保护空间
.保护空间确定了可以自动应用证书的区域
.在基本认证中,客户端会假设请求URI中或其下的所有路径都与当前的质询处处于同
一个保护空间
.在摘要认证中,质询的WWW-Authenticate:domain字段对保护空间做了更精确的定义

4.重写URI
代理可以改变URI语法而不改变实际指向的资源来重写URI
由于摘要认证需要检查URI的完整性, 故URI一经修改会破坏摘要
5.缓存
共享缓存收到Authorization首部的请求并且转接那条请求产生的响应时,当响应中提供了
Cache-Control:must-revalidate和Cache-Control:public时才会将此响应作为任何其他    
请求的应答使用    
Cache-Control:must-revalidate:
缓存可以在应答后续请求时使用响应的实体部分,但是后续请求应该和原始服务器进行
验证
Cache-Control:public:
对任意后继请求都可以使用响应实体

五、安全性考虑
1.首部篡改
防篡改机制:
端到端加密与首部进行数字加密

2.重放攻击
3.多重认证机制

4.词典攻击
密码猜测估计

5.恶意代理攻击和中间人攻击
6.选择明文攻击
预先计算的词典攻击
批量暴力型攻击

7.存储密码

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

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

相关文章

c#常用正则表达式

public class RegexUtil {private RegexUtil() { }private static RegexUtil instance null;/// <summary>/// 静态实例化单体模式/// 保证应用程序操作某一全局对象&#xff0c;让其保持一致而产生的对象/// </summary>/// <returns></returns>publi…

Http协议(4)—HTTP认证机制

一、认证1.HTTP质询/响应认证框架服务器收到一条请求并没有按照请求执行动作,而是以一个认证质询执行响应,要求用户提供一个保密信息说明他是谁,当用户再次发送请求时要附上保密证书,如果证书匹配则执行请求,否则返回一条错误信息2.认证协议与首部官方的两个认证协议:基本认证、…

C#加密解密DES字符串转

using System; using System.Collections.Generic; using System.Text; using System.Security.Cryptography; using System.IO;namespace Component {public class Security{public Security(){ }//默认密钥向量private static byte[] Keys { 0x12, 0x34, 0x56, 0x78, 0x90, …

Http协议(6)—安全HTTP

一、保护HTTP的安全1.功能:.服务器认证:客户端知道它是在与真正的服务器进行通信.客户端认证:服务器知道它是在与真正的客户端进行通信.完整性:服务器与客户端的数据不会被修改.加密:客户端与服务器的对话是私密的,不会被窃听.效率:运行足够快的算法.普适性:所有客户端和服务器…

restful处理

重写/覆盖 HTTP 方法 一些HTTP客户端仅能处理简单的的GET和POST请求&#xff0c;为照顾这些功能有限的客户端&#xff0c;API需要一种方式来重写HTTP方法. 尽管没有一些硬性标准来做这事&#xff0c;但流行的惯例是接受一种叫 X-HTTP的请求头&#xff0c;重写是用一个字符串值…

Http协议(7)—Http缓存

一、冗余的数据传输有些客户端访问服务器页面时,服务器会多次响应同一个页面的副本给客户端&#xff0c;这会产生冗余数据&#xff0c;故使用缓存就可以保留第一条相应的副本&#xff0c;以后就响应缓存的数据二、带宽瓶颈在需要下载大型文件时,如果在局域网中放入该文件的一个…

Apache JMeter--网站自动测试与性能测评

Apache JMeter--网站自动测试与性能测评2013-02-28 15:48:05标签&#xff1a;JmeterFrom:http://bdql.iteye.com/blog/291987 出于学习热情&#xff0c;翻译总结Emily H. Halili的《Apache JMeter》一书的部分内容。 JMeter的简介 可以肯定的是&#xff0c;JMeter至少符合以下几…

Linux 重命名文件

inux下重命名文件或文件夹的命令mv既可以重命名&#xff0c;又可以移动文件或文件夹. 例子&#xff1a;将目录A重命名为B mv A B 例子&#xff1a;将/a目录移动到/b下&#xff0c;并重命名为c mv /a /b/c 其实在文本模式中要重命名文件或目录的话也是很简单的&#xff0c;我们只…

苦逼的.net程序员, 转行高富帅iOS移动开发

先知先觉,后知后觉 **- 在做了两三年.net开发后, 还是感觉.net不是那么牛逼, 许多给我一起搞.net的同学, 不是去做了android, 就是去做了iOS, 或者java; 这让我对.net的前景有了一些动摇, 在三思考之后,还是决定放弃.net ,理由很简单,就是工资有点低; 由于蓝鸥iOS培训机构,一…

C# DataTable的詳細使用方法

在项目中经经常使用到DataTable,假设DataTable使用得当&#xff0c;不仅能使程序简洁有用&#xff0c;并且可以提高性能&#xff0c;达到事半功倍的效果&#xff0c;现对DataTable的使用技巧进行一下总结。 一、DataTable简单介绍 (1)构造函数 DataTable() 不…

mysql设置环境变量

-- 设置或修改系统日志有效期SET GLOBAL expire_logs_days8;SHOW VARIABLES LIKE %expire_logs_days%;-- 设置或修改系统最大连接数SET GLOBAL max_connections 2648;SHOW VARIABLES LIKE %max_connections%;-- 修改MYSQL自动编号步长SHOW VARIABLES LIKE %auto_increment%;SE…

CentOS7 编译安装LVS 互为主备 (实测 笔记 Centos 7.0 + ipvsadm 1.27 + keepalived 1.2.15 )

环境&#xff1a; 系统硬件&#xff1a;vmware vsphere (CPU&#xff1a;2*4核&#xff0c;内存2G&#xff0c;双网卡) LVS服务器&#xff08;两台&#xff09;&#xff1a; 系统&#xff1a;Centos7.0 64位&#xff08;LVSkeepalived&#xff09; LvsMaster:192.168.1.21 (主…

shell 执行mysql语句

<pre name"code" class"plain">#变量定义 sqlname"test.sql" dir"/sdb2/backup/mysql_db_backup/backup/databases" host"127.0.0.1" user"root" passwd"root" dbname"test" #导…

hdu3081 Marriage Match II(最大流)

转载请注明出处&#xff1a; http://www.cnblogs.com/fraud/ ——by fraud Marriage Match II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 2410 Accepted Submission(s): 820 Problem Descriptio…

CentOS6安装tomcat6

首先我们要下载一个tomcat的安装包 http://ftp.riken.jp/net/apache/ wget http://ftp.riken.jp/net/apache/tomcat/tomcat-6/v6.0.41/src/apache-tomcat-6.0.41.tar.gz 下载好后解压到一个以目录&#xff0c;我的是放在了/usr/apache-tomcat-6.0.41 tar –zxvf apache-t…

修复 XE7 , XE8 Frame 内 PopupMenu 快捷键失效问题

问题&#xff1a;将 Frame 含 PopupMenu 放置 Form 后&#xff0c;在 Frame 里的 PopupMenu 失效&#xff0c;无法按快捷键。 适用&#xff1a;(XE7 update 1 / XE8) for Windows 平台 修正方法&#xff1a; 请将源码 FMX.Forms.pas 复制到自己的工程目录里&#xff0c;再进行修…

Vmware Centos中安装vmtools工具

在Vmware安装虚拟机是很好玩的&#xff0c;可是有时候在虚拟机与本地主机之间相互传递文件时却是一件比较麻烦的事情&#xff0c;这时候我们安装一个vmtools的工具这样我们就可以随意的在虚拟机与主机之间相互拖拽文件&#xff0c;下面我们就来说说如何安装vmtools 点击虚拟机会…

关于Dapper - 能否不创建定义表对应类使用

1.是可以的&#xff0c;而且支持的很棒 1 /*2 lcg3 * 1.看看能不能用4 * 2.怎么用 - 引哪个文件即可&#xff1f;5 */6 7 //数据库连接参数8 private const string strConn "Data SourceAlen;Initial Catal…

动态规划 背包九讲的实现。

最近在学习动态规划&#xff0c;会了不少基础的之后就开始挑战比较困难的背包问题了&#xff0c;我这里自己写了每一讲的问题&#xff0c;解析&#xff0c;代码&#xff0c;注释。如果dp还没入门的孩纸就去看看我的另一篇文章http://www.cnblogs.com/luyi14/p/4344946.html …

Linux中查看负载

行车过桥 一只单核的处理器可以形象得比喻成一条单车道。设想下&#xff0c;你现在需要收取这条道路的过桥 费 — 忙于处理那些将要过桥的车辆。你首先当然需要了解些信息&#xff0c;例如车辆的载重、以及 还有多少车辆正在等待过桥。如果前面没有车辆在等待&#xff0c;那么你…