HTTP协议:互联网通信的基石与核心技术解析

《HTTP协议:互联网通信的基石与核心技术解析》

一、HTTP协议的本质与结构

作为互联网通信的基础协议,HTTP定义了客户端与服务器之间的请求-响应规范:

  1. 请求结构

    • 首行包含方法(GET/POST等)和路径

    • 关键头部:

      http 复制代码
      User-Agent: Mozilla/5.0...  # 标识客户端类型(浏览器/爬虫)
      Referer: https://previous.page # 请求来源页(拼写应为Referrer)
      Cookie: sessionId=abc123     # 身份凭证
    • Body存放POST数据(JSON/表单/文件等)

  2. 响应结构

    • 状态行决定请求结果

    • 关键头部:

      http 复制代码
      Content-Type: application/json # 响应体类型
      Set-Cookie: sessionId=abc123  # 设置客户端Cookie

二、状态码:HTTP的"语言"

分类 含义 常见状态码
1xx 信息性响应 101 协议切换
2xx 成功 200 OK
3xx 重定向 301 永久移动
4xx 客户端错误 404 未找到,405 方法不被允许
5xx 服务器错误 500 内部服务器错误

特殊状态码趣闻:

  • 418 I'm a teapot:来自1998年愚人节玩笑(RFC2324)
  • 451 Unavailable For Legal Reasons:源于《华氏451度》小说

三、HTTP无状态与Cookie机制

HTTP本质是无状态协议,Cookie技术解决了会话保持问题:

  1. 工作流程

    sequenceDiagram participant 客户端 participant 服务器 客户端->>服务器: 首次请求(无Cookie) 服务器-->>客户端: 响应头包含Set-Cookie 客户端->>服务器: 后续请求自动携带Cookie
  2. Java模拟带Cookie请求

    java 复制代码
    // 创建带Cookie的请求
    HttpGet httpGet = new HttpGet("http://example.com/protected");
    httpGet.addHeader("Cookie", "sessionId=abc123"); 
    
    // 执行请求并获取响应
    try (CloseableHttpResponse response = httpClient.execute(httpGet)) {
        String html = IOUtils.toString(response.getEntity().getContent(), "UTF-8");
        System.out.println(html);
    }

四、反爬虫实战:Header伪装

通过设置User-Agent模拟浏览器行为:

java 复制代码
// 伪装成Chrome浏览器
httpGet.addHeader("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64)");
httpGet.addHeader("Accept-Language", "zh-CN,zh;q=0.9");

五、Java文件读写三种方式

  1. 基础流操作

    java 复制代码
    // 读取
    InputStream is = new FileInputStream(file);
    while((readInt = is.read()) != -1) {
        sb.append((char) readInt);
    }
    
    // 写入
    FileOutputStream fos = new FileOutputStream(file);
    fos.write(line.getBytes());
  2. 缓冲字符流

    java 复制代码
    // 高效读取
    BufferedReader br = new BufferedReader(new FileReader(file));
    String line;
    while((line = br.readLine()) != null) {
        lines.add(line);
    }
  3. NIO快捷操作

    java 复制代码
    // JDK7+ 单行读写
    List<String> lines = Files.readAllLines(file.toPath());
    Files.write(file.toPath(), lines);
相关推荐
想用offer打牌3 小时前
MCP (Model Context Protocol) 技术理解 - 第二篇
后端·aigc·mcp
KYGALYX4 小时前
服务异步通信
开发语言·后端·微服务·ruby
掘了4 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
爬山算法5 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
Moment5 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
Cobyte6 小时前
AI全栈实战:使用 Python+LangChain+Vue3 构建一个 LLM 聊天应用
前端·后端·aigc
程序员侠客行7 小时前
Mybatis连接池实现及池化模式
java·后端·架构·mybatis
Honmaple7 小时前
QMD (Quarto Markdown) 搭建与使用指南
后端
PP东7 小时前
Flowable学习(二)——Flowable概念学习
java·后端·学习·flowable
invicinble7 小时前
springboot的核心实现机制原理
java·spring boot·后端