Result of CGI script on the same page(同一页面上的CGI脚本的结果)
本文介绍了同一页面上的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脚本的结果的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:同一页面上的CGI脚本的结果


基础教程推荐
猜你喜欢
- 包装空间模型 2022-01-01
- 无法导入 Pytorch [WinError 126] 找不到指定的模块 2022-01-01
- PermissionError: pip 从 8.1.1 升级到 8.1.2 2022-01-01
- 求两个直方图的卷积 2022-01-01
- 在同一图形上绘制Bokeh的烛台和音量条 2022-01-01
- 修改列表中的数据帧不起作用 2022-01-01
- Plotly:如何设置绘图图形的样式,使其不显示缺失日期的间隙? 2022-01-01
- PANDA VALUE_COUNTS包含GROUP BY之前的所有值 2022-01-01
- 在Python中从Azure BLOB存储中读取文件 2022-01-01
- 使用大型矩阵时禁止 Pycharm 输出中的自动换行符 2022-01-01