第六篇 HttpServletRequest对象

HttpServletRequest对象

HttpServletRequest是Java Servlet API中的一个接口,用于封装客户端请求信息。当客户端(如浏览器)向服务器发送HTTP请求时,服务器会创建一个HttpServletRequest对象,包含请求的所有细节。

主要功能和方法:

  • 获取请求参数 :通过getParameter(String name)获取表单或URL中的参数值。
  • 请求头信息 :使用getHeader(String name)读取请求头内容,如User-Agent
  • 路径信息getRequestURI()返回请求的URI路径,getContextPath()获取应用上下文路径。
  • 会话管理getSession()返回或创建与请求关联的HttpSession对象。
  • 请求方法getMethod()返回HTTP方法类型(GET/POST等)。

示例代码:

java 复制代码
String username = request.getParameter("username");
String userAgent = request.getHeader("User-Agent");

HttpServletResponse对象

HttpServletResponse用于生成服务器对客户端的响应。通过该对象可以设置响应头、状态码及返回数据。

主要功能和方法:

  • 设置状态码setStatus(int sc)设置HTTP响应状态码(如404、200)。
  • 响应头配置setHeader(String name, String value)添加自定义响应头。
  • 内容类型setContentType(String type)指定响应MIME类型(如text/html)。
  • 输出流getWriter()返回PrintWriter对象,用于输出文本;getOutputStream()输出二进制数据。
  • 重定向sendRedirect(String location)实现客户端重定向。

示例代码:

java 复制代码
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<html><body>Hello World</body></html>");

常见应用场景

请求处理流程

  1. 客户端发送HTTP请求到服务器。
  2. 服务器创建HttpServletRequest和HttpServletResponse对象。
  3. Servlet通过request对象解析请求数据。
  4. 业务逻辑处理后,通过response对象返回响应。

注意事项

  • 字符编码 :需在读取参数前调用request.setCharacterEncoding("UTF-8")避免乱码。
  • 响应缓存 :默认情况下响应会被缓存,可通过response.setHeader("Cache-Control", "no-cache")禁用。
  • 线程安全:HttpServletRequest和HttpServletResponse非线程安全,需在方法内局部使用。

HttpSession

HttpSession 简介

HttpSession 是 Java Servlet 技术中的核心接口,用于在服务器端存储用户会话数据。它通过唯一的会话 ID(通常通过 Cookie 或 URL 重写传递)标识用户,实现跨请求的数据共享。

HttpSession 的核心方法

  • setAttribute(String name, Object value):将对象绑定到会话,键值对形式存储。
  • getAttribute(String name):根据键名获取绑定的对象。
  • removeAttribute(String name):移除指定键的会话数据。
  • invalidate():销毁当前会话,释放所有绑定数据。
  • getId():获取会话的唯一标识符。

HttpSession 的生命周期

  • 创建 :首次调用 request.getSession() 时,服务器会创建新会话。
  • 超时 :默认超时时间由服务器配置(如 Tomcat 默认为 30 分钟),可通过 setMaxInactiveInterval(int seconds) 调整。
  • 销毁 :调用 invalidate() 或超时后,会话自动销毁。

代码示例

java 复制代码
// 获取或创建会话
HttpSession session = request.getSession();

// 存储数据
session.setAttribute("username", "Alice");

// 读取数据
String username = (String) session.getAttribute("username");

// 移除数据
session.removeAttribute("username");

// 销毁会话
session.invalidate();

注意事项

  • 性能影响:会话数据存储在服务器内存中,大量会话可能导致内存压力。
  • 分布式环境:在集群部署时,需借助 Redis 等工具实现会话共享。
  • 安全性:避免存储敏感信息,防止会话固定攻击(Session Fixation)。

配置会话超时

web.xml 中配置全局超时时间(分钟):

XML 复制代码
<session-config>
    <session-timeout>15</session-timeout>
</session-config>
相关推荐
wang09075 分钟前
Linux性能优化之内存管理基础知识
java·linux·性能优化
掘金码甲哥7 分钟前
AI编程智能体登味太浓了,必须治一治!
后端
StackNoOverflow15 分钟前
SpringCloud的声明式服务调用 Feign 全面解析
后端·spring·spring cloud
范什么特西18 分钟前
idea创建一个普通的Maven项目运行javaweb
java·maven·intellij-idea
木心术119 分钟前
RESTful API设计最佳实践:构建可扩展的后端服务
后端·restful
Jooolin21 分钟前
把 OpenClaw 接进电商后台之后,我对 AI 落地这件事的理解变了
后端·ai编程
好家伙VCC24 分钟前
# 发散创新:用 Rust实现高性能物理引擎的底层架构设计与实战在游戏开发、虚拟仿真和机器人控
java·开发语言·python·rust·机器人
六道对穿肠25 分钟前
Java 直连 USB 打印机实战:从 JNI 崩溃到「拷贝即用」的架构演进
java
壹方秘境30 分钟前
为什么有人用 ChatTCP 查看和分析网络数据包,而不是 Wireshark?
后端
石榴树下的七彩鱼35 分钟前
图片去水印 API 哪个好?5种方案实测对比(附避坑指南 + 免费在线体验)
图像处理·人工智能·后端·python·api接口·图片去水印·电商自动化