http的content-text对照表

"application/json;charset=utf-8" 并不是「固定写法」------ 它是 HTTP 标准中 MIME 类型(媒体类型 / Content-Type) 的一种,第二个参数本质是给 HTTP 响应头的Content-Type字段赋值,不同的返回数据格式对应不同的 MIME 值,charset是可选的附加编码说明。

MIME 类型由「主类型 / 子类型」+ 可选的「参数(如 charset)」组成,IANA(互联网号码分配局)定义了标准 MIME 类型,开发中常用的有以下几类,结合httplibset_content用法举例:

一、文本类(text/*):返回纯文本、网页、脚本等

核心是「文本数据」,通常需要指定charset=utf-8避免乱码:

MIME 类型 用途 httplib 使用示例
text/plain;charset=utf-8 纯文本(如日志、简单提示) resp.set_content("运行失败:语法错误", "text/plain;charset=utf-8");
text/html;charset=utf-8 HTML 网页(返回页面内容) resp.set_content("<h1>编译结果</h1>", "text/html;charset=utf-8");
text/css;charset=utf-8 CSS 样式表 resp.set_content("body{color:red;}", "text/css;charset=utf-8");
text/javascript;charset=utf-8 JavaScript 脚本 resp.set_content("alert('运行完成')", "text/javascript;charset=utf-8");
text/xml;charset=utf-8 XML 格式数据 resp.set_content("<result><code>0</code></result>", "text/xml;charset=utf-8");

二、应用类(application/*):返回结构化数据、二进制应用文件等

这是后端接口最常用的类别,核心是「非纯文本的结构化 / 二进制数据」:

MIME 类型 用途 httplib 使用示例
application/json;charset=utf-8 JSON 数据(接口最常用) 你代码中的写法,返回 JSON 字符串
application/json JSON 数据(简写,默认 utf-8) resp.set_content(out_json, "application/json");
application/x-www-form-urlencoded 表单提交(键值对格式) resp.set_content("username=test&code=0", "application/x-www-form-urlencoded");
application/form-data 多部分表单(含文件上传) 极少用 set_content 返回,通常用于接收上传
application/pdf PDF 文件(二进制) resp.set_content(pdf_binary_data, "application/pdf");(需传入二进制字符串)
application/octet-stream 通用二进制流(如自定义文件) resp.set_content(file_binary_data, "application/octet-stream");
application/xml;charset=utf-8 XML 数据(比 text/xml 更标准) resp.set_content(xml_str, "application/xml;charset=utf-8");

三、图片类(image/*):返回图片文件

无需指定 charset(图片是二进制,无编码概念):

MIME 类型 用途 httplib 使用示例
image/jpeg JPG/JPEG 图 resp.set_content(jpg_binary, "image/jpeg");
image/png PNG 图 resp.set_content(png_binary, "image/png");
image/gif GIF 图 resp.set_content(gif_binary, "image/gif");
image/webp WebP 图 resp.set_content(webp_binary, "image/webp");

四、其他常见类型

MIME 类型 用途 说明
audio/mp3 MP3 音频 二进制音频数据,无 charset
video/mp4 MP4 视频 二进制视频数据,无 charset
multipart/form-data 多部分请求 / 响应 主要用于文件上传,极少用 set_content 返回

关键注意事项

  1. charset 的使用场景

    • 仅「文本类数据」(text/*、application/json、application/xml 等)需要加charset=utf-8,目的是告诉客户端用 UTF-8 解码文本,避免中文 / 特殊字符乱码;
    • 二进制数据(图片、音频、PDF、octet-stream 等)不能加 charset(二进制无编码概念,加了反而可能导致客户端解析错误)。
  2. JSON 的 MIME 写法细节

    • 标准写法是application/json,HTTP/1.1 协议中 JSON 的默认编码就是 UTF-8,所以application/jsonapplication/json;charset=utf-8在绝大多数场景下等价;
    • 显式加charset=utf-8是「防御性写法」,避免部分老旧客户端 / 框架默认用其他编码(如 GBK)解析导致乱码,建议保留。
  3. MIME 类型的规范性

    • 优先使用 IANA 标准的 MIME 类型(如application/json而非自定义的application/json-utf8);
    • 如果自定义非标准类型,客户端可能无法正确解析(比如前端拿到未知 MIME 会按纯文本处理)。
  4. httplib 的兼容

    • set_content的第二个参数可以是任意合法的字符串(只要符合 HTTP 头格式),但必须和返回的resp.body格式匹配,否则客户端解析会出错(比如返回 JSON 字符串却写text/plain,前端可能不会自动 JSON.parse)。

总结

第二个参数的核心是「告诉客户端如何解析响应正文」,不是固定值,而是根据返回数据的格式选择对应的 MIME 类型:

  • 接口返回 JSON → 用application/json;charset=utf-8(推荐)或application/json
  • 返回纯文本 → 用text/plain;charset=utf-8
  • 返回图片 / 二进制文件 → 用对应 image/* 或 application/octet-stream(不加 charset)。
相关推荐
YuMiao2 天前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议
不可能的是3 天前
前端 SSE 流式请求三种实现方案全解析
前端·http
Jony_5 天前
高可用移动网络连接
网络协议
chilix5 天前
Linux 跨网段路由转发配置
网络协议
DianSan_ERP7 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
呉師傅7 天前
火狐浏览器报错配置文件缺失如何解决#操作技巧#
运维·网络·windows·电脑
gihigo19987 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
2501_946205527 天前
晶圆机器人双臂怎么选型?适配2-12寸晶圆的末端效应器有哪些?
服务器·网络·机器人
linux kernel7 天前
第七部分:高级IO
服务器·网络
数字护盾(和中)7 天前
BAS+ATT&CK:企业主动防御的黄金组合
服务器·网络·数据库