【HTTP协议(超文本传输协议)】

文章详细介绍了HTTP协议的请求与响应过程,包括请求方法、响应状态代码以及常见的请求头字段。同时,讨论了HTTP的安全问题,如数据明文传输,对比了HTTP与更安全的HTTPS协议。此外,还阐述了Cookie和Session在维持用户会话状态中的作用,Cookie存储在客户端,而Session存储在服务器端,两者对于Web应用程序的身份验证至关重要。
摘要由CSDN通过智能技术生成

http协议请求与响应

client server 请求 响应 client server

http协议请求与响应报文:

部分描述
请求行包括请求方法、URL和HTTP协议版本
消息报头包括一系列的名称/值对,用于描述请求/响应的属性
请求正文可选的,用于在HTTP请求中传递数据
状态行 (响应)包括HTTP协议版本、状态代码和状态代码的描述
消息报头包括一系列的名称/值对,用于描述响应的属性
响应正文包含服务器返回的数据

请求头字段

请求头描述
Host主要用于指定被请求资源的Internet主机和端口号
User-Agent向服务端传递客户端操作系统、浏览器、和其他属性
Referer包含一个URL,代表当前URL的上一个URL
Cookie是一段文本,通常来表示请求者的身份
RangeRange可以请求实体部分内容,多线程下载一定会用到此请求头
x-forward-for即XFF头,代表请求端的IP,也可以是多个,中间用逗号隔开
Accept用于指定客户端接收哪些MIME类型的信息
Accept-Charset用于指定客户端接收的字符集

HTTP响应
状态代码有三位数字组成,第一个数字定义了响应的类别,且有五种可能取值:

  • 1xx:指示信息–表示请求已接收,继续处理,范围是100~101
  • 2xx:成功–表示请求已被成功接收、理解、接受,范围是200~206
  • 3xx:重定向–要完成请求必须进行更进一步的操作,范围是300~305
  • 4xx:客户端错误–请求有语法错误或请求无法实现,范围是400~415
  • 5xx:服务器端错误–服务器未能实现合法的请求,范围是500~505
常见状态码含义
200客户端请求成功
302重定向
404请求的资源不存在
400客户端请求有语法错误,不能被服务器所理解
401请求未授权
403服务器收到请求,但是拒绝提供服务
500服务器内部错误
503服务器当前不能处理客户端的请求,一段时间后可能恢复正常

HTTP请求方式

GETGET方法用于获取请求页面的指定形式
POSTGET方法没有请求内容,而POST是有请求内容的,且GET请求会将发送的数据显示在浏览器端,而POST请求则不会
HEADHEAD方法除了服务器不能在响应里返回消息主体,其他的与GET方法相同
PUTPUT方法用于请求服务器把请求实体存储在请求资源下,如果请求资源已经存在服务器中,将会用此请求中的数据替换原先的数据,作为指定支援的最新修改版。
DELETEDELETE方法用于请求资源服务器删除指定的支援
TRACETRACE方法一般用于激发一个远程应用层的请求消息回路。回显服务器收到得到请求。
CONNECT为了用于能动态的切换到隧道的代理
OPTIONSOPTIONS方法用于请求获取URI标识的资源在请求/响应的通信过程中可以使用的功能选项。

HTTP安全问题

HTTP与HTTPS

HTTP面临着数据明文传送和缺乏对消息完整性的验证这两个
问题。
HTTPS协议,通过在TCP层与HTTP层增加一个SSL(安全套接字层)来增强数据传输时的安全性。

HTTP协议HTTPS协议
信息明文传输有安全性的SSL加密传输协议
HTTP是80端口HTTPS是443端口
需要到CA申请证书而HTTP不需要
连接相对简单,是无状态的由SSL+HTTP协议构建的可进行加密传输

Cookie与session

Cookie通过在客户端记录信息确定用户身份
Session通过在服务器端记录信息确定用户身份。

Session 与 Cookie 的作用都是为了保持访问用户与后端服务器的交互状态。

Cookie——长期门禁

客户 服务器 客户请求这个范围的URL 提供这个cookie 访问 置入Set-Cookie(响应HTTP头) 客户 服务器
图2:Cookie——长期门禁

Cookie由服务器端向客户端写入,包含在http响应头中的setcookie字段,格式如下
Set-Cookie:NAME=VALUE[;domain=DOMAIN][;path=PATH][;max- age=AGE][;expire=EXPIRE][;secue][;HttpOnly]

部分功能
path部分控制哪些访问能够触发该Cookie的发送,如果没有指定path。cookie对全站生效
expire部分指明了过期时间,如果没有指定,cookie会持续到这次回话结束,现在已经被max-age取代
secure如果指定了secure,那么该cookie只能通过安全通道传输(SSL通道)
httponly支持httponly cookie的浏览器中,JavaScript无法读取和修改cookie,这样可以让cookie免受脚本攻击

Session——临时门禁

Created with Raphaël 2.3.0 攻破cookie 获取sessionID 启动session_start? 结束 yes no
获取sessionID流程
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值