HttpServletRequest详解

2023-05-16

HttpServletRequest 详解

HttpServletRequest对象代表客户端的请求,当客户端通过HTTP协议访问服务器时,HTTP请求头中的所有信息都封装在这个对象中,通过这个对象提供的方法,可以获得客户端请求的所有信息。

HttpServletRequest 接口继承自 ServletRequest 接口,其主要作用是封装 HTTP 请求消息。由于 HTTP 请求消息分为请求行请求消息头请求消息体三部分。因此,在 HttpServletRequest 接口中定义了获取请求行、请求头和请求消息体的相关方法。

客户端:客户端(Client)或称为用户端,是指与服务器相对应,为客户提供本地服务的程序。如万维网使用的网页浏览器,收寄电子邮件时的电子邮件客户端,以及即时通讯的客户端软件等。

请求头信息信息,是指postman中Header中的内容:
postman请求头

获取请求行信息的相关方法

当访问 Servlet 时,所有请求消息将被封装到 HttpServletRequest 对象中,请求消息的请求行中包含请求方法请求资源名请求路径等信息,为了获取这些信息,HttpServletRequest 接口定义了一系列方法:

获取请求行信息的常用方法

HttpServletRequest获取请求行的相关信息:

import org.springframework.web.bind.annotation.*;

import javax.servlet.http.HttpServletRequest;

@RestController
@RequestMapping("/path")
public class PersonController {
    @PostMapping("/person/add")
    public void addPerson(HttpServletRequest request) {
        // 获取请求行的相关信息
        System.out.println("getMethod : " + request.getMethod());
        System.out.println("getRequestURI:" + request.getRequestURI());
        System.out.println("getQueryString:" + request.getQueryString());
        System.out.println("getContextPath:" + request.getContextPath());
        System.out.println("getServletPath:" + request.getServletPath());
        System.out.println("getRemoteAddr : " + request.getRemoteAddr());
        System.out.println("getRemoteHost : " + request.getRemoteHost());
        System.out.println("getRemotePort : " + request.getRemotePort());
        System.out.println("getLocalAddr : " + request.getLocalAddr());
        System.out.println("getLocalName : " + request.getLocalName());
        System.out.println("getLocalPort : " + request.getLocalPort());
        System.out.println("getServerName : " + request.getServerName());
        System.out.println("getServerPort : " + request.getServerPort());
        System.out.println("getRequestURL : " + request.getRequestURL());
    }
}

postman测试:

postman测试

打印结果:

getMethod : POST
getRequestURI:/path/person/add
getQueryString:null
getContextPath:
getServletPath:/path/person/add
getRemoteAddr : 0:0:0:0:0:0:0:1
getRemoteHost : 0:0:0:0:0:0:0:1
getRemotePort : 63277
getLocalAddr : 0:0:0:0:0:0:0:1
getLocalName : 0:0:0:0:0:0:0:1
getLocalPort : 8080
getServerName : localhost
getServerPort : 8080
getRequestURL : http://localhost:8080/path/person/add

获取请求消息头的相关方法

当浏览器发送 Servlet 请求时,需要通过请求消息头向服务器传递附加信息,例如,客户端可以接收的数据类型、压缩方式、语言等。为此,在 HttpServletRequest 接口中定义了一系列用于获取 HTTP 请求头字段的方法:
获取请求消息头的方法

读取 HTTP 请求消息头字段:

import org.springframework.web.bind.annotation.*;

import javax.servlet.http.HttpServletRequest;
import java.util.Enumeration;

@RestController
@RequestMapping("/path")
public class PersonController {
    @PostMapping("/person/add")
    public void addPerson(HttpServletRequest request) {

        // 获取请求消息中的所有头字段
        Enumeration headerNames = request.getHeaderNames();
        //用循环遍历所有请求头,并通过 getHeader() 方法获取一个指定名称的头字段
        while (headerNames.hasMoreElements()) {
            String headerName = (String) headerNames.nextElement();
            System.out.println(headerName + ":" + request.getHeader(headerName)
                    + "<br />");
        }
    }
}

postman测试:

postman测试
打印结果:

authorization:Bearer eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6IjVmODEwMTJkLTlkYTUtNDcwMC1hNWUyLTk0NmQ2NjFlN2JhOCJ9.cycMQn6fMGQOymGhol7_dknpkFWD3uW7nwzlspqIBInTgJHTf4ROKjNLsETXo6el8IjrZk2HL6OtG78MKPQkgg<br />
user-agent:PostmanRuntime/7.26.8<br />
accept:*/*<br />
postman-token:325bdf26-ec7f-47ad-b7f4-37d4f8b6fd8b<br />
host:localhost:8080<br />
accept-encoding:gzip, deflate, br<br />
connection:keep-alive<br />
content-length:0<br />

会发现,打印结果就是postman中Header中的所有属性元素。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

HttpServletRequest详解 的相关文章

  • PID算法(位置式pid算法和增量式pid算法)

    这里写目录标题 PID算法介绍比例环节比例 43 积分环节比例 43 积分 43 微分环节 位置式PID增量式PIDPID参数整定采样周期选择PID参数整定方法 请添加图片描述 https img blog csdnimg cn 849bf
  • C++ 关于编译出现“undefined reference to `std::cout‘“的问题

    1 问题概述 在使用gcc编译c 43 43 代码时会出现undefined reference to 96 std cout 39 xff0c 如编译如下代码 xff1a include lt iostream gt using name
  • 在ubuntu20.4下安装ROS-noetic

    换源方法 xff1a 打开software amp updates 在里面找到china 然后选择对应的源 1 添加ROS软件源 将以下命令复制到ubuntu的终端执行 sudo sh c 39 echo 34 deb http packa
  • ubuntu安装pip,setuptools

    https pypi python org pypi pip 解压下载后的文件 xff1a azheng 64 ubuntu16 tar zxvf pip 10 0 0 tar gz 进入目录后安装 xff1a 提示setuptools模块
  • 用putty连接ubuntu

    1 软件更新 sudo apt get update 2 下载openssh server sudo apt get install openssh server 3 查看当前tcp监听端口 netstat tl 4 查看是否安装成功 ps
  • ROS2话题入门

    1 订阅发布模式 一个节点发布数据到某个话题上 xff0c 另外一个节点就可以通过订阅话题拿到数据 除了上述这种一个节点发布 xff0c 一个节点接受的形式外 xff0c ROS2话题通信其实还可以是1对n xff0c n对1 xff0c
  • 比较程序查询方式、程序中断方式、DMA方式对CPU工作效率的影响

    xff08 1 xff09 程序查询方式是由CPU通过程序不断查询I O设备是否已经做好准备 xff0c 从而控制I O设备与主机交换信息 xff0c 只要一启动I O设备 xff0c CPU便不断查询I O设备的准备情况 xff0c 从而
  • ros_canopen使用心得

    近期开始准备上位机与机器人底盘进行CAN通讯 xff0c 花了很长时间在网上整理学习资料 xff0c 现将自己的心得和参考的链接整理如下 首先 xff0c 机器人操作系统中有ros canopen可以去调用 xff0c 其中socketca
  • ROS调用功能包的使用

    在我们学习做项目的时候难免会使用别人的功能包 我在这其中也遇到了许多坑 我在学习motion planning的时候想实现一下tangent bug算法于是就在giuhub找功能包 1是否需要其他依赖包 找到之后就把功能包放在工作空间的sr

随机推荐

  • conda中镜像源添加与删除

    1 查看当前已经添加的镜像源 conda config show sources 2 镜像源添加 conda config add channels http 3 镜像源删除 conda config remove channels htt
  • uwsgi常用指令

    1 uwsgi安装 pip install uwsgi 2 配置uwsgi touch uwsgi ini uwsgi 项目路径 chdir 61 srv xxxx Flask 的uwsgi文件 wsgi file 61 srv xxxx
  • TypeError: conv2d(): argument ‘input‘ (position 1) must be Tensor, not tuple

    搭建网络过程遇到这个问题 xff0c 检查训练过程 xff0c 已经将输入数据通过 transforms ToTensor 转换为Tensor格式 经检查发现是网络结构问题 网络搭建过程中MaxPool2d xff08 xff09 中设置r
  • pytorch搭建神经网络过程

    1 torch nn Conv2d 卷积层 用法 xff1a Conv2d in channels out channels kernel size stride 61 1 padding 61 0 dilation 61 1 groups
  • SyntaxError: future feature annotations is not defined

    作者遇到这个问题是在使用NVIDIA Jetson Xavier NX开发套件控制舵机时遇到的 xff0c 作者采用IIC通信方式控制PCA9685模块进而控制舵机 在此问题解决过程中发现有人遇到相同问题 xff0c 所以做个补充 别人给出
  • Qt error: collect2: error: ld returned 1 exit status的解决办法

    Ubuntu安装好Qt后 xff0c 新建最简单的项目测试环境是否OK时 xff0c 出现 error collect2 error ld returned 1 exit status 代码本身是没有任何问题 xff0c 经检查后 xff0
  • NVIDIA Jetson Xavier NX/NANO安装Visual Studio Code

    官网下载安装即可 步骤 xff1a 1 官网下载安装包 Visual Studio Code Code Editing Redefined 下载Ubuntu版本 deb格式安装包 xff0c 注意要下载ARM64的 2 将文件传输至开发板
  • Spring对IoC的实现

    4 1 IoC 控制反转 控制反转是一种思想 控制反转是为了降低程序耦合度 xff0c 提高程序扩展力 xff0c 达到OCP原则 xff0c 达到DIP原则 控制反转 xff0c 反转的是什么 xff1f 将对象的创建权利交出去 xff0
  • 51单片机——自动浇花系统(含全部代码)

    目录 正文 设计目的 功能设计 所需元件 设计方法 主要代码 详细代码 正文 设计目的 生活中难免会忘记给自己可爱的花花浇水 xff0c 本设计就来给我们解决这一难题 功能设计 可实现自动浇花 xff0c 遥控浇花 xff0c 按键浇花 x
  • 自动控制原理——期末题型总结

    目录 二阶系统指标计算 劳斯表判断系统稳定 根轨迹绘制 绘制伯德图求相位裕量 二阶系统指标计算 已知单位负反馈系统开环传递函数 Wk s 61 求 1 最大超调量 xff0c 调节时间 95 2 r t 为单位阶跃求稳态误差 xff0c 并
  • 51单片机——多文件的建立

    目录 建立目的 简单项目实例 以按键控制动态数码管为例 建立目的 如果遇到大项目 xff0c 单文件修改会很麻烦 多文件项目这时候发挥了重要作用 简单项目实例 以按键控制动态数码管为例 第一步 建立文件夹 第二步 建立 CODE 文件 存放
  • 51单片机——汇编语言 1(延时函数与led闪烁)

    目录 前言 延时函数 所用汇编语法 延时函数编写 xff1a led闪烁 所用汇编语法 LED程序编写 xff1a 前言 汇编语言是一种底层的机械语言 xff0c 对时间控制精准下面我们以代码为例 xff0c 讲解51汇编命令 延时函数 所
  • 51单片机——LCD1602

    目录 LCD1602简介 特征 工作参数 液晶屏的分类 按字符和行数命名 按行数和列数命名 引脚说明 LCD1602指令集 指令总览 设置输入模式 显示开关 光标或字符移动 功能设置 DDRAM地址设置 读忙标志 LCD1602时序 字符表
  • 51单片机——LCD12864

    目录 LCD12864简介 特征 工作参数 LCD12864引脚说明 LCD12864常用指令集 基本指令 扩充指令 字符表 汉字显示地址编排 编辑 绘图地址与汉字显示编排示意图 程序设计 图形显示程序 字符显示程序设计 LCD12864简
  • 51单片机——DS18B20温度传感器

    目录 DS18B20特性 内部存储器表 ROM指令表 RAM指令表 DS18B20暂存器表 单个DS18B20温度转换过程 温度读取及计算 配置寄存器 xff08 分辨率 xff09 读写时序 复位及存在检测 写时序 读时序 程序实现 DS
  • 51红外循迹智能车——红外循迹模块设计

    目录 赛道环境 红外传感器的特征 TCRT5000传感器 LM339单限电压比较器 LM339简介 编辑 单限电压比较器仿真 红外循迹模块的设计 红外循迹模块原理图 红外循迹模块原理图讲解 赛道环境 上图为赛道示意图 xff0c 两端为黑色
  • 开发板烧写程序方法

    开发板烧写程序方法 如果开发板上没有预装bootloader程序 xff0c 那么可以通过JTAG进行烧写 常用的JTAG工具有并口JTAG xff0c 它的特点是便宜但是速度比较慢 USB转JTAG RS232串口二合一的工具OpenJT
  • 51单片机——汇编指令合集

    目录 指令格式 编译语句实例 单片机的寻址方式 立即数 xff08 Immediate Constants xff09 寻址方式 直接 xff08 Direct Addressing xff09 寻址方式 寄存器 xff08 Registe
  • 电子专业英语(持续更新)

    前言 23考研刚刚结束 xff0c 但在我复试的两个学校的专业英语翻译我都不会 发现自己在专业英语方面很差 xff0c 故写此文章记录我专业英语的学习历程 2023 4 17日学习 Analog n l signal 模拟信号 Contin
  • HttpServletRequest详解

    HttpServletRequest 详解 HttpServletRequest对象代表客户端的请求 xff0c 当客户端通过HTTP协议访问服务器时 xff0c HTTP请求头中的所有信息都封装在这个对象中 xff0c 通过这个对象提供的