HTTP/HTTPS协议基础
nanshan 2025-05-11 17:22 20 浏览 0 评论
以下是对 HTTP/HTTPS协议 的全面基础讲解,包含请求/响应结构、状态码、Header/Cookie的核心概念,并附带代码示例和实际应用场景分析。
1. HTTP/HTTPS协议基础
HTTP (HyperText Transfer Protocol)
- 无状态协议:每次请求独立,不保留之前交互的信息(依赖Cookie/Session维持状态)。
- 明文传输:数据未加密,易被窃听(HTTPS解决了此问题)。
- 默认端口:80。
- HTTPS (HTTP Secure)
- 加密传输:基于TLS/SSL协议,对HTTP内容加密。
- 身份验证:通过证书验证服务器身份。
- 默认端口:443。
- 核心流程:
- 客户端与服务端通过TLS握手交换密钥。
- 使用对称加密传输数据。
2. HTTP请求与响应结构
HTTP请求(Request)
GET /index.html HTTP/1.1 # 请求行(方法 + 路径 + 协议版本)
Host: www.example.com # 必需Header(指定目标域名)
User-Agent: Mozilla/5.0 # 客户端标识
Accept: text/html # 可接受的内容类型
Cookie: session_id=abc123 # 客户端携带的Cookie
(空行) # 分隔Header和Body
(请求体,GET方法通常无Body)
HTTP响应(Response)
HTTP/1.1 200 OK # 状态行(协议版本 + 状态码 + 状态描述)
Content-Type: text/html # 响应内容类型
Set-Cookie: session_id=abc123 # 服务端设置Cookie
Content-Length: 1024 # 响应体长度
(空行) # 分隔Header和Body
<!DOCTYPE html> # 响应体(HTML内容)
<html>...</html>
3. 常见HTTP方法
方法 | 作用 | 安全性与幂等性 |
GET | 获取资源 | 安全、幂等 |
POST | 提交数据(如表单) | 不安全、不幂等 |
PUT | 更新资源 | 不安全、幂等 |
DELETE | 删除资源 | 不安全、幂等 |
HEAD | 获取Header元数据 | 安全、幂等 |
4. HTTP状态码详解
状态码 | 类别 | 常见状态码 | 渗透测试中的意义 |
1xx | 信息响应 | 100 Continue | 少见,通常用于大文件上传 |
2xx | 成功 | 200 OK, 201 Created | 请求成功 |
3xx | 重定向 | 301 永久重定向, 302 临时重定向 | 检查重定向目标是否可控(钓鱼攻击) |
4xx | 客户端错误 | 400 Bad Request, 401 Unauthorized, 403 Forbidden, 404 Not Found | 探测权限漏洞(如403绕过) |
5xx | 服务器错误 | 500 Internal Server Error | 暴露服务端漏洞(如SQL注入错误回显) |
5. 核心HTTP Header
请求头(Request Headers)
Header | 作用 | 安全相关场景 |
Cookie | 携带会话凭证 | 会话劫持、Cookie篡改 |
Referer | 请求来源页面 | 检查CSRF防护(Referer验证) |
User-Agent | 客户端浏览器/设备信息 | 伪造UA绕过WAF检测 |
Authorization | 认证信息(如Basic Token) | 弱密码爆破、Token泄露 |
响应头(Response Headers)
Header | 作用 | 安全相关场景 |
Set-Cookie | 设置客户端Cookie | 检查Secure/HttpOnly属性缺失 |
Content-Type | 响应内容类型(如text/html) | 检测MIME类型混淆漏洞 |
Location | 重定向目标URL | 开放重定向漏洞(钓鱼攻击) |
CORS相关头 | 跨域资源共享控制 | 配置错误导致跨域数据泄露 |
6. Cookie机制与安全
Cookie属性
Set-Cookie: session_id=abc123; Path=/; Secure; HttpOnly; SameSite=Lax
属性 | 作用 | 安全意义 |
Secure | 仅通过HTTPS传输 | 防止明文传输被窃听 |
HttpOnly | 禁止JavaScript访问Cookie | 防御XSS窃取Cookie |
SameSite | 限制跨站请求携带Cookie(Strict/Lax/None) | 防御CSRF攻击 |
Expires | 设置Cookie过期时间 | 会话固定攻击检查 |
Cookie在渗透测试中的应用
- 会话劫持:通过XSS窃取Cookie后伪造用户身份。
- Cookie篡改:修改Cookie参数尝试越权访问(如user_role=admin)。
- 会话固定攻击:强制用户使用已知的Session ID。
7. 实战代码示例
Python模拟HTTP请求(包含Header/Cookie操作)
import requests
# 自定义Header和Cookie
headers = {
"User-Agent": "Mozilla/5.0 (渗透测试专用)",
"Referer": "http://evil.com"
}
cookies = {"session_id": "hacked_123"}
# 发送GET请求并获取响应头
response = requests.get(
"http://example.com/admin",
headers=headers,
cookies=cookies
)
# 输出关键信息
print("状态码:", response.status_code)
print("响应头:", response.headers)
print("Set-Cookie:", response.headers.get("Set-Cookie"))
分析HTTPS请求(使用Wireshark抓包)
- 过滤TLS握手包:tls.handshake.type == 1(Client Hello)
- 观察加密后的应用数据包(内容不可读,但可分析元数据)。
8. 渗透测试中的应用场景
- 信息泄露:
- 检查HTTP响应头是否暴露敏感信息(如Server: Apache/2.4.6)。
- 会话管理漏洞:
- 验证Cookie是否缺少HttpOnly或Secure属性。
- 开放重定向:
- 修改Location头参数,测试是否可跳转到恶意网站。
- CORS配置错误:
- 检查Access-Control-Allow-Origin: *是否允许任意域访问。
9. 学习建议
- 动手实践:
- 使用浏览器开发者工具(F12)查看每个请求的Header和Cookie。
- 在Kali Linux中用curl -v http://example.com观察原始HTTP交互。
─(kalikali)-[~]
└─$ curl -v http://example.com
* Host example.com:80 was resolved.
* IPv6: 2600:1406:3a00:21::173e:2e65, 2600:1406:bc00:53::b81e:94c8, 2600:1408:ec00:36::1736:7f31, 2600:1406:bc00:53::b81e:94ce, 2600:1406:3a00:21::173e:2e66, 2600:1408:ec00:36::1736:7f24
* IPv4: 23.215.0.136, 23.192.228.84, 96.7.128.198, 23.192.228.80, 23.215.0.138, 96.7.128.175
* Trying 23.215.0.136:80...
* Trying [2600:1406:3a00:21::173e:2e65]:80...
* Immediate connect fail for 2600:1406:3a00:21::173e:2e65: 网络不可达
* Trying [2600:1406:bc00:53::b81e:94c8]:80...
* Immediate connect fail for 2600:1406:bc00:53::b81e:94c8: 网络不可达
* Trying [2600:1408:ec00:36::1736:7f31]:80...
* Immediate connect fail for 2600:1408:ec00:36::1736:7f31: 网络不可达
* Trying [2600:1406:bc00:53::b81e:94ce]:80...
* Immediate connect fail for 2600:1406:bc00:53::b81e:94ce: 网络不可达
* Trying [2600:1406:3a00:21::173e:2e66]:80...
* Immediate connect fail for 2600:1406:3a00:21::173e:2e66: 网络不可达
* Trying [2600:1408:ec00:36::1736:7f24]:80...
* Immediate connect fail for 2600:1408:ec00:36::1736:7f24: 网络不可达
* Connected to example.com (23.215.0.136) port 80
> GET / HTTP/1.1
> Host: example.com
> User-Agent: curl/8.5.0
> Accept: */*
>
< HTTP/1.1 200 OK
< Content-Type: text/html
< ETag: "84238dfc8092e5d9c0dac8ef93371a07:1736799080.121134"
< Last-Modified: Mon, 13 Jan 2025 20:11:20 GMT
< Cache-Control: max-age=1544
< Date: Sat, 12 Apr 2025 08:00:51 GMT
< Content-Length: 1256
< Connection: keep-alive
<
<!doctype html>
<html>
<head>
<title>Example Domain</title>
<meta charset="utf-8" />
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<style type="text/css">
body {
background-color: #f0f0f2;
margin: 0;
padding: 0;
font-family: -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
}
div {
width: 600px;
margin: 5em auto;
padding: 2em;
background-color: #fdfdff;
border-radius: 0.5em;
box-shadow: 2px 3px 7px 2px rgba(0,0,0,0.02);
}
a:link, a:visited {
color: #38488f;
text-decoration: none;
}
@media (max-width: 700px) {
div {
margin: 0 auto;
width: auto;
}
}
</style>
</head>
<body>
<div>
<h1>Example Domain</h1>
<p>This domain is for use in illustrative examples in documents. You may use this
domain in literature without prior coordination or asking for permission.</p>
<p><a href="https://www.iana.org/domains/example">More information...</a></p>
</div>
</body>
</html>
* Connection #0 to host example.com left intact
以下是针对 curl -v http://example.com 输出的逐段讲解:
1. DNS 解析
* Host example.com:80 was resolved.
* IPv6: 2600:1406:3a00:21::173e:2e65, ...
* IPv4: 23.215.0.136, ...
● 域名解析:curl 首先将域名 example.com 解析为 IPv4 和 IPv6 地址。
● IPv6/IPv4 地址列表:服务器返回了多个 IP 地址,确保高可用性(部分地址为冗余备份)。
2. 尝试连接
* Trying 23.215.0.136:80...
* Trying [2600:1406:3a00:21::173e:2e65]:80...
* Immediate connect fail for ...: 网络不可达
● IPv4 优先:curl 默认尝试 IPv4 地址(如 23.215.0.136:80)。
● IPv6 失败:所有 IPv6 地址均提示 网络不可达,可能原因:
○ 本地网络未启用 IPv6。
○ 防火墙/路由器阻止了 IPv6 流量。
○ 目标服务器 IPv6 地址不可达。
3. 成功建立连接
* Connected to example.com (23.215.0.136) port 80
● 最终选择 IPv4:成功通过 IPv4 地址 23.215.0.136 的 80 端口建立 TCP 连接。
4. 发送 HTTP 请求
> GET / HTTP/1.1
> Host: example.com
> User-Agent: curl/8.5.0
> Accept: */*
● 请求行:GET / HTTP/1.1 表示请求根路径 /,使用 HTTP/1.1 协议。
● 请求头:
○ Host: 必需字段,指定目标域名。
○ User-Agent: 客户端标识(这里是 curl 版本)。
○ Accept: */*: 表示客户端接受任何响应类型。
5. 接收 HTTP 响应
< HTTP/1.1 200 OK
< Content-Type: text/html
< ETag: "84238dfc8092e5d9c0dac8ef93371a07:1736799080.121134"
< Last-Modified: Mon, 13 Jan 2025 20:11:20 GMT
< Cache-Control: max-age=1544
< Date: Sat, 12 Apr 2025 08:00:51 GMT
< Content-Length: 1256
< Connection: keep-alive
● 状态行:HTTP/1.1 200 OK 表示请求成功。
● 响应头:
○ Content-Type: text/html: 响应内容是 HTML 文本。
○ ETag: 资源标识符,用于缓存验证。
○ Last-Modified: 资源最后修改时间(注意:日期为未来的 2025 年,可能是服务器配置错误或测试数据)。
○ Cache-Control: max-age=1544: 响应可缓存 1544 秒(约 25 分钟)。
○ Connection: keep-alive: 保持 TCP 连接复用。
6. 响应体(HTML 内容)
<!doctype html>
<html>
<head>
<title>Example Domain</title>
<!-- 页面元数据和样式 -->
</head>
<body>
<div>
<h1>Example Domain</h1>
<p>This domain is for use in illustrative examples...</p>
<p><a href="https://www.iana.org/domains/example">More information...</a></p>
</div>
</body>
</html>
● 示例页面:这是 IANA(互联网编号分配机构)提供的标准示例页面,用于文档演示。
7. 连接保持
* Connection #0 to host example.com left intact
● Keep-Alive:TCP 连接未关闭,可复用后续请求,减少握手开销。
关键问题总结
1. IPv6 连接失败:本地网络或中间设备可能不支持 IPv6。
2. 未来日期:响应头中的 Last-Modified 和 Date 为 2025 年,可能是服务器时间错误或刻意设置的测试数据。
3. 缓存策略:Cache-Control 和 ETag 帮助客户端高效缓存资源。
通过此过程,可以清晰看到从 DNS 解析到 HTTP 请求/响应的完整生命周期。
- 靶场练习:
- 在DVWA中修改Cookie尝试绕过登录(设置security=low)。
- 协议分析工具:
- Wireshark抓包分析HTTP/HTTPS流量(过滤条件:http或tls)。
掌握HTTP/HTTPS协议是Web安全的基础,后续学习漏洞利用时,需时刻关注协议层面的细节(如请求参数如何构造、Header如何影响服务端行为)。
- 上一篇:腾讯云国际站:如何设置缩容保护时间?
- 下一篇:AD 域环境下Windows时间同步
相关推荐
- 基于 Linux 快速搭建企业级 DNS 服务器(Bind9 ...
-
一、引言在大型企业网络或自建系统中,搭建一套高可用、自控的DNS解析服务器至关重要。本文将带你基于Linux环境,从零搭建企业级DNS服务平台,采用Bind9实战配置,确保解析稳定、安...
- Linux无法解析域名的解决办法(linux无法解析域名的解决办法有哪些)
-
如果由于误操作,删除了系统原有的dhcp相关设置就无法正常解析域名。 此时,需要手动修改配置文件: /etc/resolv.conf 将域名解析服务器手动添加到配置文件中 该文件是DNS域名解...
- 在centos7 创建基于域名的虚拟主机nginx服务器
-
直接用ip地址访问首先是不安全,其次不太容易记住,如果你的服务器上的项目有很多个,你创建多个基于Ip的虚拟主机,很容易导致公网ip冲突或乱用的情况。这时候我们就可以选择基于域名的虚拟主机。第一步、安装...
- Linux之DNS服务(linux dnsserver)
-
一、学习路线如下二、DNS介绍1.域名的概念域名由特定的格式组成,用来表示互联网中某一台计算机或者计算机组的名称,能够使人更方便的访问互联网,而不用记住能够被机器直接读取的IP地址。2.DNS(dom...
- Linux环境下DNS服务器配置图文详细教程
-
测试环境为vmware虚拟机下,linux系统为RedHatEnterpriseLinuxServer6.0(Santiago),内核版本Linux2.6.32-71.el6.i686...
- 构建基于 Linux 的高性能 DNS 服务器
-
在现代网络架构中,DNS(域名解析)是访问互联网的关键环节。搭建一个高性能、低延迟、可缓存加速的私有DNS服务器,不仅可以提升访问速度,还能增强网络隐私和安全性。本文将基于Linux系统,详细...
- 从运维的角度带你初识neo4j图形数据库的安装及配置
-
前言随着公司业务架构的改变,以前我部署环境的时候,一般只是部署Mysql,jdk,tomcat即可,现在还要部署一些nosql,如redis,neo4j,在之前从来没了解过,随着学习的深入而做了一些笔...
- [超全整理] Java 程序员必备的 100 条 Linux 命令大全
-
一、基础操作(10条)#1.ls-查看目录内容ls-l#长格式显示文件和目录ls-a#显示隐藏文件ls-lh#带单位显示文件大小#2.cd-切换目录...
- 软件测试|一文教你轻松搭建docker环境
-
前言Docker提供轻量的虚拟化,你能够从Docker获得一个额外抽象层,你能够在单台机器上运行多个Docker微容器,而每个微容器里都有一个微服务或独立应用,例如你可以将Tomcat运行在一个Do...
- docker基础知识/尚硅谷docker学习笔记
-
最近看了好多docker的资料,找了一些尚硅谷docker的教学视频,大概总结了一下前前后后的学习笔记。分享给大家。安装Docker的基本组成镜像Docker镜像(Image)就是一个只读的模板。镜...
- 前端_react项目从windows部署到centos
-
前言:从工程角度来讲,本地开发完就要把项目部署到生产环境,此过程的快慢也直接影响着整体的效率。所以也有很多人做持续集成的工作,例如:CI/CD/一键部署。但对于个人开发者而言,如果能有工具支撑是最好的...
- Springboot项目使用docker部署(docker中运行springboot项目)
-
环境:SpringBoot2.2.10.RELEASE+Docker+Centos7+JDK8安装配置Dockeryum包更新到最新yumupdate卸载旧版本dockeryumre...
- Spring Boot 3.x + Redis 7.x,轻松掌握Redisson分布式锁实战技巧
-
大家好,我是袁庭新。在分布式环境中,确保数据的一致性和正确性是至关重要的。对于需要高性能、高并发和分布式数据存储的应用程序来说,Redisson是一个很好的选择。同时,Redisson提供的分布式锁功...
- Docker篇(二):Docker实战,命令解析
-
大家好,我是杰哥上周我们通过几个问题,让大家对于Docker有了一个全局的认识。然而,说跟练往往是两个概念。从学习的角度来说,理论知识的学习,往往只是第一步,只有经过实战,才能真正掌握一门技术所以,本...
- 新手快速入门Docker,轻松掌握Docker安装与使用
-
安装使用官方安装脚本自动安装curl-fsSLhttps://get.docker.com|bash-sdocker--mirrorAliyun手动安装CentOS7(使用yum进...
你 发表评论:
欢迎- 一周热门
-
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
手机如何设置与显示准确时间的详细指南
-
NAS:DS video/DS file/DS photo等群晖移动端APP远程访问的教程
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
一加手机与电脑互传文件的便捷方法FileDash
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)