当前位置: 首页 > news >正文

Tomcat部署项目get请求中文乱码

问题描述

  1. tomcat部署的项目,get请求到后端后,打印日志发现通过@RequestParam()接收的参数值乱码。

问题猜测

编码错误导致的乱码。

流程梳理

  1. 浏览器发送请求时会自动对请求链接中自带的参数进行编码。编码时一般都是采用UTF-8的格式进行编码。
  2. 请求到达Tomcat后,Tomcat会对其进行解码。操作。这里是重点,tomcat8之前的版本默认解码格式是使用的ISO8859-1。tomcat8之后的版本默认是采用UTF-8
  3. 将解码后的参数值送到对应的controller中的指定方法进行处理。

问题分析

  1. 确认tomcat版本。若是8之前的版本,查看server.xml配置文件中的Connector标签的配置,若没有配置URIEncoding,则默认是ISO8859-1编码格式。导致乱码问题。
    在这里插入图片描述

问题解决

方法一:

修改tomcat配置。增加URIEncoding配置,指定为UTF-8编码格式。如图

<Connector port="8080" protocol="HTTP/1.1"connectionTimeout="20000"redirectPort="8443" URIEncoding="UTF-8"/>

在这里插入图片描述

方法二:

修改代码在对应的后端代码中对乱码字符串进行恢复。

//fileName为接收的参数。
fileName = new String(fileName.getBytes("ISO8859-1"),"UTF-8");

在这里插入图片描述

代码解释:

  • 获取 ISO-8859-1 编码的字节 → 这些字节实际上是 UTF-8 编码的原始字节
  • 使用 UTF-8 重新解码这些字节 → 得到正确的中文字符

编码错误问题解释

  1. 浏览器发送请求时会自动对字符进行编码,这时使用的是UTF-8的格式进行编码。
  2. 请求到达tomcat后,connector中的uriEncoding默认是 ISO8859-1编码格式。此时会用此编码进行解码。由于编码不是该格式。导致解码后乱码。
  3. 请求到达controller对应的方法后。接收到的字符串就是乱码的字符串。

end


http://www.mrgr.cn/news/2212.html

相关文章:

  • 为什么apple email的邮件显示不全
  • avx2 计算一个uint8_t数组的平方加速
  • react中 useContext 和useReducer的使用
  • RabbitMQ环境搭建
  • 【Vue3】编程式路由导航
  • React学习笔记(一)——react基础
  • 存储和传输/寻找大端字节序/有哪款MCU或MPU是真支持大端?
  • I/O模型
  • C++ IO流
  • 特洛伊木马:现代网络安全的隐形威胁
  • Matplotlib库学习之scatter(模块)
  • 【LeetCode热题100】双指针
  • 微信小程序蓝牙函数流程图
  • 鸿蒙内核源码分析(时钟任务篇)
  • Windows系统命令
  • 游戏引擎phaser.js3的使用之玩家的添加和图片的点击事件
  • 加密请求包的爆破
  • linux memory cgroup的memory.move_charge_at_immigrate含义
  • Elasticsearch 不允许直接修改现有索引的映射来添加新字段
  • 42.【C语言】冒泡排序