问题描述
我对Web开发了解不多,所以我想使它变得非常基础。我有一个带有非常简单的网站的python项目,该网站具有两个文本字段和一个“提交”按钮。当按下按钮时,我希望它使用用户的参数运行python程序。 我在网站和下面都有一个页面index.html来启动python Web服务器:
import http.server
import socketserver
PORT = 8080
Handler = http.server.SimpleHTTPRequestHandler
with socketserver.Tcpserver(("",PORT),Handler) as httpd:
print("serving at port",PORT)
httpd.serve_forever()
单击“提交”按钮时,最简单的运行python脚本的方法是什么?
解决方法
使用CGIHTTPRequestHandler
代替SimpleHTTPRequestHandler
。
这默认是在文件夹cgi-bin
中执行脚本,因此请创建该文件夹并将Python脚本放在该文件夹中。然后,您可以执行以下操作:
server.py
import http.server
import socketserver
PORT = 8080
handler = http.server.CGIHTTPRequestHandler
with http.server.HTTPServer(("",PORT),handler) as httpd:
print("serving at port",PORT)
httpd.serve_forever()
index.html
<!DOCTYPE html>
<h1>Hello!</h1>
<form action="cgi-bin/foo" method="post">
<button type="submit">Submit!</button>
</form>
cgi-bin/foo
#!/usr/bin/env python3
response = '''HTTP/1.0 200 OK
Content-Type: text/html
<!DOCTYPE html>
<h1>hello from foo!</h1>
'''
print(response.replace('\n','\r\n'))
但是,这既乏味又脆弱。 The documentation明确警告不要用于生产。对于正确的Web应用程序,请使用诸如Flask之类的Web应用程序框架。
作为参考,以下是使用Flask编写相同内容的方法:
import flask
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return f'''
<h1>Hello</h1>
<form action="{flask.url_for('foo')}" method="post">
<button type="submit">Submit</button>
</form>
'''
@app.route('/foo',methods=['POST'])
def foo():
return '''
<h1>Hello from foo!</h1>
'''
export FLASK_APP=server.py
flask run
,
您必须了解的是,代码中包含两部分:服务器和客户端。 因此,当客户端执行某些操作时,您想在服务器端执行一些操作。 为此,客户端必须向服务器发出请求,然后服务器处理该请求并做出响应。
事实证明,SimpleHTTPRequestHandler
并不是真正为此而创建的。
但是你仍然可以做到^^
客户端
在这里,您向客户端显示(使用html),如果他单击该按钮,它将发出请求。
<body>
<form action="/test.html">
<input type="hidden" name="isButtonPressed" value="true">
<input type="submit">
</form>
</body>
服务器端
import http.server
import socketserver
#here you create a new handler,you had a new way to handle get request
class Handler(http.server.SimpleHTTPRequestHandler):
def do_GET(self):
#this code execute when a GET request happen,then you have to check if the request happenned because the user pressed the button
if self.path.find("isButtonPressed=true") != -1:
print("Button clicked")
#do whatever you want
return super().do_GET()
PORT = 8080
myHandler = Handler
with socketserver.TCPServer(("",myHandler) as httpd:
print("serving at port",PORT)
httpd.serve_forever()