如何在 Java 后端接口中提取请求头中的 Cookie 和 Token
个人名片
🎓作者简介:java领域优质创作者
🌐个人主页:码农阿豪
📞工作室:新空间代码工作室(提供各种软件服务)
💌个人邮箱:[2435024119@qq.com]
📱个人微信:15279484656
🌐个人导航网站:www.forff.top
💡座右铭:总有人要赢。为什么不能是我呢?
- 专栏导航:
码农阿豪系列专栏导航
面试专栏:收集了java相关高频面试题,面试实战总结🍻🎉🖥️
Spring5系列专栏:整理了Spring5重要知识点与实战演练,有案例可直接使用🚀🔧💻
Redis专栏:Redis从零到一学习分享,经验总结,案例实战💐📝💡
全栈系列专栏:海纳百川有容乃大,可能你想要的东西里面都有🤸🌱🚀
目录
- 如何在 Java 后端接口中提取请求头中的 Cookie 和 Token
- 1. 背景
- 1.1 什么是 HTTP 请求头?
- 1.2 为什么需要提取请求头?
- 2. 使用 Spring Boot 提取请求头
- 2.1 使用 `@RequestHeader` 注解
- 示例代码
- 说明
- 注意事项
- 2.2 使用 `HttpServletRequest`
- 示例代码
- 说明
- 优点
- 2.3 使用 `@CookieValue` 注解
- 示例代码
- 说明
- 注意事项
- 3. 提取 Token 的常见方式
- 3.1 使用 `@RequestHeader` 和字符串处理
- 说明
- 3.2 使用 `HttpServletRequest` 和字符串处理
- 4. 综合示例
- 5. 测试接口
- 5.1 请求示例
- 5.2 响应示例
- 6. 总结
如何在 Java 后端接口中提取请求头中的 Cookie 和 Token
在现代 Web 开发中,HTTP 请求头(Header)是客户端与服务器之间传递信息的重要方式之一。常见的场景包括:
- 通过
Cookie传递会话信息。 - 通过
Authorization头传递身份验证 Token。
本文将详细介绍如何在 Java 后端(以 Spring Boot 为例)中提取请求头中的 Cookie 和 Token,并提供完整的代码示例和优化建议。
1. 背景
1.1 什么是 HTTP 请求头?
HTTP 请求头是客户端(如浏览器)发送给服务器的附加信息,用于传递元数据。常见的请求头包括:
Cookie:用于传递客户端存储的会话信息。Authorization:用于传递身份验证信息,如 JWT Token。
1.2 为什么需要提取请求头?
在后端开发中,提取请求头中的信息是常见的需求。例如:
- 身份验证:从
Authorization头中提取 Token,验证用户身份。 - 会话管理:从
Cookie中提取会话 ID,维护用户会话状态。 - 数据传递:通过自定义请求头传递额外的业务数据。
2. 使用 Spring Boot 提取请求头
Spring Boot 提供了多种方式来处理 HTTP 请求头。以下是几种常见的方法:
2.1 使用 @RequestHeader 注解
@RequestHeader 注解可以直接将请求头中的值绑定到方法的参数上。
示例代码
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestHeader;
import org.springframework.web.bind.annotation.RestController;@RestController
public class HeaderController {@GetMapping("/example")public String getHeaders(@RequestHeader("Cookie") String cookie, // 提取 Cookie@RequestHeader("Authorization") String token // 提取 Token) {return "Cookie: " + cookie + ", Token: " + token;}
}
说明
@RequestHeader("Cookie"):提取请求头中的Cookie。@RequestHeader("Authorization"):提取请求头中的Token(通常放在Authorization头中)。
注意事项
- 如果请求头中没有指定的字段,Spring 会抛出
MissingRequestHeaderException。可以通过required = false设置为可选参数:@RequestHeader(value = "Cookie", required = false) String cookie
2.2 使用 HttpServletRequest
通过 HttpServletRequest 对象,可以手动获取请求头中的值。
示例代码
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletRequest;@RestController
public class HeaderController {@GetMapping("/example")public String getHeaders(HttpServletRequest request) {String cookie = request.getHeader("Cookie"); // 提取 CookieString token = request.getHeader("Authorization"); // 提取 Tokenreturn "Cookie: " + cookie + ", Token: " + token;}
}
说明
request.getHeader("Cookie"):获取Cookie头的值。request.getHeader("Authorization"):获取Authorization头的值。
优点
- 更灵活,适用于需要动态处理请求头的场景。
2.3 使用 @CookieValue 注解
如果 Cookie 是以键值对的形式传递的(例如 Cookie: name=value),可以使用 @CookieValue 注解提取特定的 Cookie 值。
示例代码
import org.springframework.web.bind.annotation.CookieValue;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class HeaderController {@GetMapping("/example")public String getCookie(@CookieValue("sessionId") String sessionId // 提取特定的 Cookie 值) {return "Session ID: " + sessionId;}
}
说明
@CookieValue("sessionId"):提取名为sessionId的Cookie值。
注意事项
- 如果
Cookie不存在,Spring 会抛出MissingRequestCookieException。可以通过required = false设置为可选参数:@CookieValue(value = "sessionId", required = false) String sessionId
3. 提取 Token 的常见方式
Token 通常放在 Authorization 头中,格式为 Bearer <token>。我们需要提取 Bearer 后面的部分。
3.1 使用 @RequestHeader 和字符串处理
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestHeader;
import org.springframework.web.bind.annotation.RestController;@RestController
public class HeaderController {@GetMapping("/example")public String getToken(@RequestHeader("Authorization") String authHeader // 提取 Authorization 头) {if (authHeader != null && authHeader.startsWith("Bearer ")) {String token = authHeader.substring(7); // 提取 Bearer 后面的部分return "Token: " + token;} else {return "Invalid Authorization header";}}
}
说明
authHeader.startsWith("Bearer "):检查Authorization头是否以Bearer开头。authHeader.substring(7):提取Bearer后面的Token。
3.2 使用 HttpServletRequest 和字符串处理
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletRequest;@RestController
public class HeaderController {@GetMapping("/example")public String getToken(HttpServletRequest request) {String authHeader = request.getHeader("Authorization"); // 提取 Authorization 头if (authHeader != null && authHeader.startsWith("Bearer ")) {String token = authHeader.substring(7); // 提取 Bearer 后面的部分return "Token: " + token;} else {return "Invalid Authorization header";}}
}
4. 综合示例
以下是一个综合示例,提取 Cookie 和 Token,并返回处理结果:
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestHeader;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletRequest;@RestController
public class HeaderController {@GetMapping("/example")public String getHeaders(@RequestHeader(value = "Cookie", required = false) String cookie, // 提取 Cookie@RequestHeader(value = "Authorization", required = false) String authHeader // 提取 Authorization 头) {// 处理 CookieString cookieInfo = (cookie != null) ? "Cookie: " + cookie : "No Cookie provided";// 处理 TokenString tokenInfo;if (authHeader != null && authHeader.startsWith("Bearer ")) {String token = authHeader.substring(7); // 提取 Bearer 后面的部分tokenInfo = "Token: " + token;} else {tokenInfo = "Invalid or missing Authorization header";}return cookieInfo + ", " + tokenInfo;}
}
5. 测试接口
可以使用 Postman 或 curl 测试接口:
5.1 请求示例
curl -X GET http://localhost:8080/example \
-H "Cookie: sessionId=abc123" \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
5.2 响应示例
{"Cookie": "sessionId=abc123","Token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
}
6. 总结
在 Java 后端(Spring Boot)中提取请求头中的 Cookie 和 Token 有多种方式:
- 使用
@RequestHeader注解:适合直接绑定请求头到方法参数。 - 使用
HttpServletRequest:适合需要动态处理请求头的场景。 - 使用
@CookieValue注解:适合提取特定的Cookie值。
对于 Token,通常需要从 Authorization 头中提取 Bearer 后面的部分。通过合理的异常处理和参数校验,可以确保代码的健壮性和可维护性。
希望本文对你有所帮助!如果有任何问题,欢迎在评论区留言。
相关文章:
如何在 Java 后端接口中提取请求头中的 Cookie 和 Token
个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[2435024119qq.com] 📱个人微信&a…...
【Python网络爬虫】爬取网站图片实战
【Python网络爬虫】爬取网站图片实战 Scrapying Images on Website in Action By Jackson@ML *声明:本文简要介绍如何利用Python爬取网站数据图片,仅供学习交流。如涉及敏感图片或者违禁事项,请注意规避;笔者不承担相关责任。 1. 创建Python项目 1) 获取和安装最新版…...
SAP ABAP VA05增强
SE18 输入增强的BADI名称:BADI_SDOC_WRAPPER 进入后,点击Interface。 进入后,点击显示对象清单。 双击增强类,下面有之前做好的增强类,没有的可以自己创建一个。 IF_BADI_SDOC_WRAPPER~ADAPT_RESULT_COMP 代码 METHOD if_badi_sdoc_wrapper~adapt_result_comp."…...
八大排序——简单选择排序
目录 1.1基本操作: 1.2动态图: 1.3代码: 代码解释 1. main 方法 2. selectSort 方法 示例运行过程 初始数组 每轮排序后的数组 最终排序结果 代码总结 1.1基本操作: 选择排序(select sorting)也…...
【清晰教程】本地部署DeepSeek-r1模型
【清晰教程】通过Docker为本地DeepSeek-r1部署WebUI界面-CSDN博客 目录 Ollama 安装Ollama DeepSeek-r1模型 安装DeepSeek-r1模型 Ollama Ollama 是一个开源工具,专注于简化大型语言模型(LLMs)的本地部署和管理。它允许用户在本地计算机…...
教程 | Proxmox VE(PVE)安装全流程指南(末尾附镜像及快速配置脚本)
Proxmox VE 是一款基于 Debian 的开源虚拟化平台,支持 KVM 虚拟机和 LXC 容器,广泛用于企业级虚拟化部署。 一、安装前准备 1. 硬件要求 CPU:64位处理器(Intel VT/AMD-V 虚拟化支持)内存:至少 4GB&#x…...
【matlab优化算法-17期】基于DBO算法的微电网多目标优化调度
基于蜣螂DBO算法的微电网多目标优化调度 一、前言 微电网作为智能电网的重要组成部分,其优化调度对于降低能耗、减少环境污染具有重要意义。本文介绍了一个基于Dung Beetle Optimizer(DBO)算法的微电网多目标优化调度项目,旨在通…...
如何使用qt开发一个xml发票浏览器,实现按发票样式显示
使用Qt开发一个按发票样式显示的XML发票浏览器,如下图所示样式: 一、需求: 1、按税务发票样式显示。 2、拖入即可显示。 3、正确解析xml文件。 二、实现 可以按照以下步骤进行: 1. 创建Qt项目 打开Qt Creator,创…...
八股文-2025-02-12
BFC BFC属于普通流。BFC全称是Block Formatting Context,意思就是块级格式化上下文。你可以把BFC看做元素的一个属性,当元素拥有BFC属性,这个元素就可以看作是隔离了的独立容器,容器里边的元素不会影响到容器外部的元素.https://b…...
解析 JavaScript 面试题:`index | 0` 确保数组索引为整数
文章目录 一、JavaScript 中的数字类型二、按位或运算符 | 的作用(一)对于整数(二)对于小数(三)对于非数字值 三、用于数组索引的意义 在 JavaScript 面试中,常常会涉及到一些看似简单却蕴含着深…...
苹果手机快捷指令----敲击背面实现自动插入日期
前一段时间因为写文章,每一次总是在手机上面敲击日期觉得非常麻烦,于是自己鼓捣如何自动插入的办法。下面分享在网络上面查阅到的资料,由于实操的原因,遇到了很多困难。现在补充上去。先演示一遍效果。 https://www.bilibili.com…...
Base64 PDF解析器
<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>Base64 PDF解析器</title><style>body {font-family: Arial, sans-serif;max-width: 800px;margin: 20px auto;padding: 20px;}.contain…...
SQL-leetcode—1393. 股票的资本损益
1393. 股票的资本损益 Stocks 表: ---------------------- | Column Name | Type | ---------------------- | stock_name | varchar | | operation | enum | | operation_day | int | | price | int | ---------------------- (stock_name, operation_day) 是这张…...
Java NIO基础与实战:如何提升IO操作性能
Java NIO 概述 Java NIO(新 I/O)是 Java 提供的一个更为高效的 I/O 处理框架。Java NIO(New I/O)是对传统 I/O(java.io)模型的改进,它引入了非阻塞 I/O 操作和面向缓冲区的数据读写方式&#x…...
46 map与set
目录 一、序列式容器和关联式容器 二、set系列的使用 (一)set和mutilset参考文档链接 (二)set类模板介绍 1、set类声明 2、set的构造和迭代器 3、set的增删查 (三)multiset类模板 1、multiset和se…...
GPT 系列模型发展史:从 GPT 到 ChatGPT 的演进与技术细节
从 GPT 到 ChatGPT,OpenAI 用短短几年时间,彻底改变了自然语言处理(NLP)的格局。让我们一起回顾这段激动人心的技术演进史!🚀 🔹 GPT(2018): 划时代的起点&a…...
RAGFlow和Dify对比
RAGFlow和Dify都是基于大语言模型(LLM)的应用开发平台,具有相似的功能和应用场景,但它们在技术架构、部署要求和用户体验上存在一些差异。 RAGFlow和Dify对比 2025-02-13 22.08 RAGFlow 技术栈:RAGFlow…...
Dart 3.5语法 14-16
017自定代码段让变量有默认值 List下标访问和2种for循环遍历_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1RZ421p7BL?spm_id_from333.788.videopod.episodes&vd_source68aea1c1d33b45ca3285a52d4ef7365f&p42原作者链接,此为修订补充版本 014main…...
yanshee机器人初次使用说明(备注)-PyCharm
准备 需要: 1,(优必选)yanshee机器人Yanshee 开发者说明 2,手机-联网简单操控 / HDMI线与显示器和键鼠标-图形化开发环境 / 笔记本(VNC-内置图形化开发环境/PyCharm等平台)。 3,P…...
面试题:如何在10亿个数中判断某个数是否存在?
参考视频 参考视频: 如何用10只老鼠试出藏在99瓶清水中的那瓶毒药 参考视频...
【设计模式】【行为型模式】观察者模式(Observer)
👋hi,我不是一名外包公司的员工,也不会偷吃茶水间的零食,我的梦想是能写高端CRUD 🔥 2025本人正在沉淀中… 博客更新速度 👍 欢迎点赞、收藏、关注,跟上我的更新节奏 🎵 当你的天空突…...
[创业之路-299]:图解金融体系结构
一、金融体系结构 1.1 概述 金融体系结构是一个国家以行政的、法律的形式和运用经济规律确定的金融系统结构,以及构成这个系统的各种类型的银行和非银行金融机构的职能作用和相互关系。以下是对金融体系结构的详细分析: 1、金融体系的构成要素 现代金…...
STM32、GD32驱动TM1640原理图、源码分享
一、原理图分享 二、源码分享 /************************************************* * copyright: * author:Xupeng * date:2024-07-18 * description: **************************************************/ #include "smg.h"#define DBG_TAG "smg&…...
框架ThinkPHP(小迪网络安全笔记~
免责声明:本文章仅用于交流学习,因文章内容而产生的任何违法&未授权行为,与文章作者无关!!! 附:完整笔记目录~ ps:本人小白,笔记均在个人理解基础上整理,…...
09-轮转数组
给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。 方法一:使用额外数组 function rotate(nums: number[], k: number): void {const n nums.length;k k % n; // 处理 k 大于数组长度的情况const newNums new A…...
CSV数据列智能合并技术解析
这几天编AI工具信息推荐平台系统,经常遇到数据获取和清洗的问题。今天分享一个将一个csv文件里的列合并到另一个csv文件里。 源码如下: import pandas as pd# 读取源CSV文件 source_file tools_data.csv # 替换为您的源CSV文件路径 data_source pd.…...
Postman如何流畅使用DeepSeek
上次写了一篇文章是用chatBox调用api的方式使用DeepSeek,但是实际只能请求少数几次就不再能给回响应。这回我干脆用最原生的方法Postman调用接口请求好了。 1. 通过下载安装Postman软件 postman下载(https://pan.quark.cn/s/c8d1c7d526f3),包含7.0和10…...
土星云边缘计算微服务器 SE110S-WA32加持DeepSeek,本地部署企业私有推理大模型!
模型介绍 DeepSeek-R1-Distill-Qwen-7B是一款高性能的语言模型,基于DeepSeek-R1的推理能力,通过蒸馏技术将推理模式迁移到较小的Qwen模型上,在保持高性能的同时,显著降低了资源消耗,更适合在资源受限的环境中部署。 该…...
Linux权限提升-内核溢出
一:Web到Linux-内核溢出Dcow 复现环境:https://www.vulnhub.com/entry/lampiao-1,249/ 1.信息收集:探测⽬标ip及开发端⼝ 2.Web漏洞利⽤: 查找drupal相关漏洞 search drupal # 进⾏漏洞利⽤ use exploit/unix/webapp/drupal_dr…...
【大语言模型】最新ChatGPT、DeepSeek等大语言模型助力高效办公、论文与项目撰写、数据分析、机器学习与深度学习建模等科研应用
ChatGPT、DeepSeek等大语言模型助力科研应用 随着人工智能技术的快速发展,大语言模型如ChatGPT和DeepSeek在科研领域的应用正在为科研人员提供强大的支持。这些模型通过深度学习和大规模语料库训练,能够帮助科研人员高效地筛选文献、生成论文内容、进行数…...
