请求参数丢失加号

Posted

技术标签:

【中文标题】请求参数丢失加号【英文标题】:Request Parameter Losing Plus Sign 【发布时间】:2011-12-12 03:43:18 【问题描述】:

我正在编辑一个搜索表单并试图防止数据库中的特殊字符。在 JSP 搜索表单中,(多选)下拉列表允许用户选择将在查询中使用的描述(注意:描述是字符串列表):

<select id="descriptionSelect" multiple="multiple">
    <c:forEach items="$descriptions" var="description">
        <option value="$fn:escapeXml(description)")">                            
            <c:out value="$description" />
        </option>
    </c:forEach>
</select>

当表单提交时,页面会动态生成 URL,该 URL 采用 URL 中的查询参数(丑陋,我知道,手被束缚)。这是制作描述部分的片段。

var descriptionSelectBox = document.getElementById("descriptionSelect");
var descriptionsUrlAddition = "";

for (var i = 0; i < descriptionSelectBox.options.length; i++) 
    if (descriptionSelectBox.options[i].selected) 
        descriptionsUrlAddition += "&descriptions=" + escape(descriptionSelectBox.options[i].value);
    

我在数据库中有一个测试条目,其描述是:

AAA `~!@#$%^&*()_+-=|[]\:";'?,./ 哇这有很多特殊字符。

使用上面的代码,由于某种原因,当请求到达控制器时,描述丢失了+号(它变成了一个空格)。

有谁知道可能会发生什么以及如何解决它?我不确定这是否与 URL 特殊使用 + 或什么有关。我可以编辑描述列表的填充方式(可能在那里转义)。如果您将此作为建议,请使用 Java 特定代码(无 Apache 转义实用程序类等)。

如果有帮助,在 javascript 中使用警报表明 + 号在发送请求之前没有被转换。

【问题讨论】:

【参考方案1】:

+ 表示 URL 中的“空格”。将其替换为%2B。例如,您可以在编写 descriptionsUrlAddition 之后执行此操作。

descriptionsUrlAddition = descriptionsUrlAddition.replace("+", "%2B");

【讨论】:

你将如何实现这个? @Rachel G.,只需将 URL 字符串中的所有 + 符号替换为 %2B。一旦你的 URL 被组合成一个字符串,你就可以使用Stringreplace() 方法。添加示例。 将代码 (escape(descriptionSelectBox.options[i].value).replace("+", "%2B")) 添加到您的答案中,我会将其标记为正确。谢谢=) @Rachel G.,更好的是,在整个字符串中替换它。这样会更有效率,因为您只需调用一次replace() 不适合我,我有一个带有 + 号的网址将它们替换为 %2B,但没有用。【参考方案2】:

对于 javascript,您应该使用 encodeURIComponent() 或 encodeuri()。例如:

var uri = "fj74cvg+fd1==ee";
var res = encodeURIComponent(uri);

并且 res 将被编码为"fj74cvg%2Bfd1%3D%3Dee"

对于 php,您可以使用 urlencode()。例如:

<?php
echo '<a href="mycgi?foo=', urlencode($userinput), '">';
?>

这些函数将替换字符串中用作 url 一部分的任何特殊字符。

【讨论】:

encodeURI() 不会将 + 更改为 %2B。只有encodeURIComponent() 可以。【参考方案3】:

你应该在前端使用 javascript encodeuri 函数来编码你的参数。

【讨论】:

以上是关于请求参数丢失加号的主要内容,如果未能解决你的问题,请参考以下文章

tomcat 对请求参数中的加号是如何处理的

get请求时 参数中+号变空格

服务请求丢失了参数

[踩坑]url传参+变空格

RedirectToAction() 丢失请求数据

openFeign远程调用丢失请求头