Javascript提高:get和post等请求,对于汉字和空格信息进行编码的原则-由Deepseek产生

为什么必须编码?

HTTP 协议规定 URL 中只能包含 ASCII 字符,非 ASCII 字符(如汉字)和保留字符(如空格、&= 等)必须进行 百分号编码(URL encoding),否则:

  • 空格会被服务器误认为分隔符或被截断
  • 汉字可能被解析为乱码,甚至导致请求失败
  • 参数分隔符(&=)会被误认为结构符号,破坏参数结构

不同场景的编码规则

1. GET 请求(URL 查询字符串)

必须编码

例如,将 name=张三 city=北京 拼接到 URL 中:

javascript 复制代码
// 错误(未编码)
fetch('/api?name=张三&city=北京')   // 可能无法正确解析

// 正确
const name = encodeURIComponent('张三');
const city = encodeURIComponent('北京');
fetch(`/api?name=${name}&city=${city}`);

编码后:

复制代码
/api?name=%E5%BC%A0%E4%B8%89&city=%E5%8C%97%E4%BA%AC

2. POST 请求(application/x-www-form-urlencoded

必须编码

这是表单默认的编码格式,参数以 key=value 形式放在请求体中,同样要求 URL 编码。

javascript 复制代码
// 使用 URLSearchParams 自动编码
const body = new URLSearchParams();
body.append('name', '张三');
body.append('city', '北京');

fetch('/api', {
  method: 'POST',
  headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
  body: body
});

实际发送的 body 为:

复制代码
name=%E5%BC%A0%E4%B8%89&city=%E5%8C%97%E4%BA%AC

3. POST 请求(multipart/form-data,常用于文件上传)

不需要手动编码

浏览器会自动处理每个字段的编码(包含汉字和空格),且二进制数据原样传输。

javascript 复制代码
const formData = new FormData();
formData.append('name', '张三 李四');  // 空格保留
formData.append('file', fileInput.files[0]);

fetch('/api', {
  method: 'POST',
  body: formData   // 浏览器自动设置 Content-Type 并编码
});

4. POST 请求(application/json

不需要编码

JSON 本身支持 Unicode,汉字和空格直接作为字符串传输。

javascript 复制代码
fetch('/api', {
  method: 'POST',
  headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify({ name: '张三 李四' })
});

库的自动处理

  • Axios :默认对 params(GET 参数)和 application/x-www-form-urlencodeddata 自动编码。
  • jQuery AJAX$.ajaxdata 对象会被自动编码(若未指定 contentType: false)。
  • FetchURLSearchParamsFormData 会编码,但手动拼接 URL 需自己调用 encodeURIComponent
  • XHR :手动拼接时需调用 encodeURIComponent

总结

请求类型 数据位置 格式 是否必须编码 说明
GET URL 查询字符串(query string) ✅ 必须 所有非 ASCII 和保留字符都需百分号编码
POST Body application/x-www-form-urlencoded ✅ 必须 同 GET 规则
POST Body multipart/form-data ❌ 不需要 浏览器自动处理,各字段独立边界分隔
POST Body application/json ❌ 不需要 JSON 原生支持 Unicode

最佳实践 :永远不要手动拼接 URL 参数而不编码。使用现代库或 URLSearchParams 等 API 让浏览器/库自动处理。

相关推荐
竹林8182 小时前
从ethers.js迁移到Viem:我在一个DeFi项目前端重构中踩过的坑
前端·javascript
黑眼圈子2 小时前
总结一下用Java做算法的常用类和方法
java·开发语言·算法
码界筑梦坊2 小时前
353-基于Python的大湾区气候数据可视化分析系统
开发语言·python·信息可视化·数据分析·django·vue·毕业设计
像我这样帅的人丶你还2 小时前
从交稿到甩锅预防:AI 前端流水线
前端·ai编程
想想弹幕会怎么做2 小时前
如何构建一颗可交互的ui树?
前端
程序员陆业聪2 小时前
我见过的最反直觉的 Android 架构问题:UseCase 越多,项目越烂
前端
Arya_aa2 小时前
网络:前端向后端发送网络请求渲染在页面上,将EasyMock中的信息用前端vue框架编写代码,最终展示在浏览器
前端·vue.js
LlNingyu2 小时前
文艺复兴,什么是CSRF,常见形式(一)
前端·安全·web安全·csrf
晓13132 小时前
React篇——第三章 状态管理之 Redux 篇
前端·javascript·react.js