3

我正在开发一个带有多个表单的 Web 应用程序,用户需要在这些表单上输入通常包含空格和/或加号的数据。

数据通常通过GET请求发送;或通过POST带有application/x-www-form-urlencodedContent-Type 标头的请求。

我尝试过使用Perl 模块中的任何一个Vars(),但是这两种方法都坚持将符号转换为空格。paramCGI+

模块是否CGI提供任何机制来保存+标志;还是我应该放弃CGI并手动解析STDIN输入?

注意
由于表单数量众多(超过一百个),并且 CGI 预处理发生在一个集中的实用程序库中,我非常偏向于服务器端解决方案而不是客户端方法(换句话说,我宁愿在预处理代码上处理一次问题,也不愿在数百个地方添加 JS 噪声)。

提前感谢您提供的任何帮助。

示例
根据评论中的要求,这里是一些触发问题的代码的(简化)示例。

HTML

<form action="/cgi-bin/some-script.pl">
    <input name="some_field" value="1 + 1 is 2">
    <input name="submit" type="submit" value="Submit">
</form>

Perl

use CGI;
my $some_variable = CGI::param('some_field');

使用默认值提交表单并运行服务器端代码后,$some_variable' 的值为"1 1 is 2" (1 之间有三个空格,SO 站点或浏览器可能会将它们折叠成一个空格)期望的结果是获得该"1 + 1 is 2"变量中的值。

4

1 回答 1

7

CGI 参数中的加号表示空格。这在 CGI 规范中。任何向您发送加号以表示其他任何内容的 HTTP 客户端都已损坏。任何处理加号以表示其他任何内容的 HTTP 服务器都已损坏。

所以问题不在于你的 CGI 程序(它正在做正确的事情)。问题出在 HTTP 客户端中,它向您发送加号,打算将它们解释为加号。在 CGI 程序中将加号作为参数发送的正确方法是将其编码为 %2B。这就是你需要解决的问题。

更新:我在 Ubuntu 上使用 Apache 运行了一个简单的测试。

我的 HTML 文件如下所示:

<html>
  <head>
    <title>Test</title>
  </head>
  <body>
    <h1>Test</h1>
    <form action="/cgi-bin/param">
      <input name="some_field" value="1 + 1 is 2">
      <input name="submit" type="submit" value="Submit">
    </form>
  </body>
</html>

我的 Perl 程序如下所示:

#!/usr/bin/perl

use strict;
use warnings;
use 5.010;

use CGI qw[header param];

print header(-type => 'text/plain');

for (param) {
  say "$_ -> ", join ':', param($_);
}

当我访问该页面并点击“提交”按钮时,浏览器转到 URLhttp://localhost/cgi-bin/param?some_field=1+%2B+1+is+2&submit=Submit并显示以下内容:

some_field -> 1 + 1 is 2
submit -> Submit

这看起来像我期望看到的行为。浏览器在将加号发送到浏览器时将其正确编码为 %2B。Perl 的 CGI 模块在我访问该值时对其进行解码。

您需要找出您的浏览器(或您用来发送这些请求的任何其他客户端)未遵循 CGI 规范的原因。

于 2012-07-10T09:47:16.343 回答