同一页面上的CGI脚本的结果 [英] Result of CGI script on the same page

查看:28
本文介绍了同一页面上的CGI脚本的结果的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

例如,我有一个html页面:

<html>
    <body>
        <form action="http://127.0.0.1/cgi-bin/test.py" method="post" target="_blank">
            PRESS BUTTON TO TEST PYTHON CGI
            <br><input type="submit" value="Submit" />
        </form>
    </body>
</html>

和Python CGI脚本(test.py):

#!/usr/bin/python
print "Content-type: text/html"
print
print "<html><head><title>CGI</title></head>"
print "<body>"
print "hello cgi"
print "</body>"
print "</html>"
因此,当我按下按钮时,它将打开带有脚本结果的新页面(‘Hello CGI’) 我如何用按钮在同一页上输出‘Hello CGI’?(不是新页面!)

感谢您的帮助。

推荐答案

最后,我决定使用AJAX。

Python:

#!/usr/local/bin/python
import cgi
str = 'hello from cgi!'
print "Content-type: text/html

"
print "%s" % str

HTML:

<html>
<head>
<title>Simple Ajax Example</title>
<script type="text/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 = encodeURI(word);
    return qstr;
}

function updatepage(str){
    document.getElementById("result").innerHTML = str;
}
</script>
</head>
<body>
<form name="f1">
  <input value="Submit" type="button" onclick='JavaScript:xmlhttpPost("http://127.0.0.1/cgi-bin/test.py")'></p>
  <div id="result"></div>
</form>
</body>
</html>

这篇关于同一页面上的CGI脚本的结果的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆