将字符串变量从Perl CGI脚本传递到HTML前端

时间:2013-08-27 11:22:58

标签: javascript jquery ajax cgi

我是 AJAX 的新手,我在将变量传回HTML脚本时遇到了一些问题。

我正在使用 XAMPP 网络服务器, JavaScript jQuery 作为HTML脚本和 Perl cgi 脚本作为后端。

我需要获取一个输入字符串,将其传递给CGI脚本,它将在Perl函数中使用。 Perl cgi脚本中生成的字符串变量需要传递回HTML前端,并用于$(document).ready(function(){})内的函数。

截至目前,我能够将用户定义的输入传递给cgi脚本,并将结果显示为简单的HTML文本。但是如何将cgi输出用作进一步JavaScript / jQuery函数的变量?

非常感谢任何帮助。

这是我的HTML和JavaScript代码:

<!doctype html>
<html>
<head>
    <title>AJAX example</title>

    <script type="text/javascript" src="_lib/jquery.js"></script>
    <script type="text/javascript" src="jquery.jstree.js"></script>

    <script type="text/javascript">

        $(document).ready(function() {

            /*
            I need to use the string variable "#searchtext" in this example function:

            $("#filter").click(function () {
                $("#testtree").jstree("search",$("#searchtext").val());
            });
            */

        });

    </script>

    <script language="Javascript">

        function xmlhttpPost(strURL) {
            var xmlHttpReq = false;
            var self = this;
            // Mozilla/Safari
            if (window.XMLHttpRequest) {
                self.xmlHttpReq = new XMLHttpRequest();
            }
            // IE
            else if (window.ActiveXObject) {
                self.xmlHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
            }
            self.xmlHttpReq.open('POST', strURL, true);
            self.xmlHttpReq.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
            self.xmlHttpReq.onreadystatechange = function() {
                if (self.xmlHttpReq.readyState == 4) {
                    updatepage(self.xmlHttpReq.responseText);
                }
            }
            self.xmlHttpReq.send(getquerystring());
        }

        function getquerystring() {
            var form     = document.forms['f1'];
            var word = form.word.value;
            qstr = 'w=' + escape(word);
            return qstr;
        }

        function updatepage(str){
            document.getElementById("result").innerHTML = str;
        }
    </script>
</head>

<body>      
    <form name="f1">
        <p>word: <input name="word" type="text">  
        <input value="Go" type="button" onclick='JavaScript:xmlhttpPost("/cgi-bin/ajax_test.cgi")'></p>
        <div id="result"></div>
    </form>

</body>
</html>

这是我的Perl脚本ajax_test.cgi:

#!/usr/bin/perl -w

use strict;
use warnings;
use CGI;

my $query = new CGI;

my $word = $query->param('w');

print $query->header;
print "<p>You are searching for: <b>$word</b>.</p>";

更新

我尝试使用 collapsar 建议的第一个解决方案,但我仍然不确定将js vars放在哪里,因为我需要能够在中调用它们 $(document).ready(function(){})

<script language="Javascript">

function xmlhttpPost(strURL) {
    //...//
}

function getquerystring() {
    //..//
}

function updatepage(str){
    //...//
}

var resp_html = self.xmlHttpReq.responseText;
var resp_dom  = jQuery.parseHTML(resp_html );
var mydata1 = $('#<custom-id-1>', resp_dom).text();

// the alert doesn't work
$("#alertbutton").click(function () {

    alert( "You entered: " + mydata1);

});

1 个答案:

答案 0 :(得分:1)

选项1:内容处理

如果您传输(半)结构化数据,则必须从客户端上的服务器解析内容,即。 html或xml。为了简化对感兴趣的数据的访问,将id属性发布到您将在服务器端生成的标记/元素。

服务器端代码(扩充您的示例):

print "<p>You are searching for: <b id="<custom-id-1>">$word</b>.</p>";

客户端检索和处理:

var resp_html = self.xmlHttpReq.responseText;
var resp_dom  = jQuery.parseHTML(resp_html );

var mydata1 = $('#<custom-id-1>', resp_dom).text();

代码段根据您问题的标签推测您使用jquery(如果不是为什么不这样做?)。您也可以使用普通的dom方法,请参阅适用的documentation on mdn

如果您使用纯文本响应,则不需要标记,因此无需解析响应并使用dom方法提取相关数据。你可以通过文本搜索获得所需的数据&amp;替换操作。哪种方式取决于数据的复杂性和预期用途。

警告:你最好避免使用html / xml并使用search&amp; amp;提取信息。更换。虽然在许多环境中技术上都是可行的,但它通常是可维护性的噩梦,并且在软件的演变(阅读:新功能的集成)过程中经常会出现故障。

选项2:http标头(不推荐)

您可以选择在自定义http标头中发送您的信息。虽然这种方法可以避免解析内容和内容编码的潜在问题,但你肯定会违反rfc 6648中的建议(讨论见this SO thread)。

已经说过,该方法在技术上是可行的。在你的perl脚本中使用

print $query->header(
    { 
        '<custom-header-1-name>' => '<custom-header-1-value>'
      , '<custom-header-2-name>' => '<custom-header-2-value>'
# ...          
    }
);

对于客户端检索,请使用:

var mydata1 = self.xmlHttpReq.getResponseHeader('<custom-header-1-name>')
var mydata2 = self.xmlHttpReq.getResponseHeader('<custom-header-2-name>')
// ...

你的问题的标签表明你正在使用jquery(如果你没有,为什么不呢?;-)),所以当你在它时看看jquery ajax api