试图了解CGI和AJAX如何工作 - 为什么这个演示不起作用?

时间:2013-12-16 19:24:00

标签: javascript html ajax cgi

所以我试图理解这一切是如何工作的,我发现了一个很棒的小演示。

我有一个名为simple-ajax-example.cgi的CGI脚本,位于我的Web服务器的cgi-bin目录中。

#!C:\strawberry\perl\bin\perl.exe
use CGI;

$query = new CGI;

$secretword = $query->param('w');
$remotehost = $query->remote_host();

print $query->header;
print "<p>The secret word is <b>$secretword</b> and your IP is <b>$remotehost</b>.</p>";

我还有一个名为simpleAJAX.html的.html文件(根据我的理解,与我命名的文件无关)。我不确定在哪里放置它,所以我把它放在cgi-bin目录中......

<html>
<head>
<title>Simple Ajax Example</title>
<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);  // NOTE: no '?' before querystring
    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/simple-ajax-example.cgi")'></p>
  <div id="result"></div>
</form>
</body>
</html>

我在浏览器中打开两个标签,导航到两个文件。一切都很顺利,直到我在simpleAJAX.html中更新字段。我输入“Hello”并单击Go,但是在我的浏览器中,simple-ajax-example.cgi中的单词没有更新。有任何想法吗?我正在学习的演示在这里:http://www.degraeve.com/reference/simple-ajax-example.php

1 个答案:

答案 0 :(得分:0)

Perl cgi 100%正常 html ajax 100%确定

所以一步一步地调试

1,单击按钮会执行cgi脚本吗?是/否    怎么检查(在cgi中放一些行来创建一个文件)    如果不检查“/cgi-bin/simple-ajax-example.cgi”是否是您的cgi的正确路径    以及权利

  

是的,我的权限设置为可执行文件。我在httpd.conf文件中添加了这个

不,它是 chmod 755 simple-ajax-example.cgi 用于将可执行文件设置为文件的命令 它与httpd.conf无关,httpd.conf实际上是服务器本身的少数配置文件之一

如果是,则在代码中进一步检查并检查返回值,但我确定答案是你的cgi没有执行