URLDecoder和URLEncoder专用于application/x-www-form-urlencoded格式的参数值编解码,必须显式指定UTF-8,不可用于完整URL或路径编码;URLEncoder将空格转为+,非ASCII字符转为%XX,URLDecoder自动处理+和%XX并还原原始字符串。
Java 中的 URLDecoder 和 URLEncoder 主要用于处理 URL 中的参数编码与解码
,核心目标是确保特殊字符(如空格、中文、符号)能安全地在 HTTP 请求中传输。注意:它们操作的是 application/x-www-form-urlencoded 格式,不是通用的 URI 编码(如路径部分应使用 java.net.URI 或 java.net.URLEncoder.encode(String, String) 配合 UTF-8),且默认使用平台默认字符集(不推荐),必须显式指定 "UTF-8"。
用于对 GET 请求参数值或 POST 表单数据中的字段值进行编码。它会把空格转为 +,非字母数字字符转为 %XX 形式,并严格要求指定字符集(推荐 UTF-8)。
URLEncoder.encode(str, "UTF-8"),避免使用已废弃的无参方法+,不是 %20;若需统一为 %20,可后续替换:.replace("+", "%20")
URLEncoder.encode("你好 world+test", "UTF-8") → %E4%BD%A0%E5%A5%BD+world%2Btest
用于解析 HTTP 请求中接收到的参数值(例如 HttpServletRequest.getParameter() 通常已自动解码,但手动解析查询字符串时需自行调用)。
URLDecoder.decode(encodedStr, "UTF-8")
+ 作为空格,也支持 %20 等各种百分号编码%GZ),会抛出 IllegalArgumentException
URLDecoder.decode("%E4%BD%A0%E5%A5%BD+world%2Btest", "UTF-8") → 你好 world+test
这两个工具类容易误用,尤其在前后端协作或自定义请求构造时:
/、冒号 : 等被错误编码,破坏 URL 结构new URI(null, null, path, query, fragment) 构造,或手动编码时仅对路径段内容编码(并用 %2F 代替 /)user name → user%20name)@RequestParam 默认完成解码,一般无需手动调用 URLDecoder对于复杂场景(如完整 URI 构建、路径编码、国际化支持),推荐使用标准 API 替代:
java.net.URI 构造器,它会自动对各组件做合规编码URLEncoder.encode(pathSegment, "UTF-8").replace("+", "%20"),再拼入路径HttpServletRequest.getParameter() 的结果,它已按请求字符集解码(需确保 request.setCharacterEncoding("UTF-8") 已设置)基本上就这些。关键记两点:编码只针对参数值、必须强制指定 UTF-8;别碰 URL 结构本身,那是 URI 类的事。