python - 405 Method not Allow, methods=["POST", "GET"] 不工作
问题描述
我正在从在线烧瓶教程中学习,并且正在观看有关 POST 和 GET 的视频。其中一个练习是运行一个简单的表单提交,在新的@app.route() 上返回用户名。我尝试添加密码和用户名来尝试模拟登录,因为我认为我很酷但失败了。代码如下。
from flask import Flask, redirect, url_for, render_template, request
app = Flask(__name__)
realUser: str = "name"
realPass: str = "pass"
@app.route("/")
def home():
return render_template("extension.html")
@app.route("/login", methods=["POST", "GET"])
def login():
if request.method == "POST":
user = request.form["un"]
password = request.form["password"]
if realUser == user and password == realPass:
return redirect(url_for("user", usr=user))
else:
return render_template("extension.html")
@app.route("/<usr>")
def user(usr):
return f"<h1>{usr}</h1>"
if __name__ == "__main__":
app.run(debug=True)
扩展名.html:
{% extends "ThePurpleLounge.html" %}
{% block title %}Home Page{% endblock %}
{% block content %}
<h1>Login</h1>
<form method="post">
<p>Name:</p>
<p><input type="text" name="un" /></p>
<p>Password:</p>
<p><input type="text" name="password" /></p>
<p><input type="submit" value="submit" /></p>
</form>
{% endblock %}
ThePurpleLounge.html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>{% block title %}{% endblock %}</title>
</head>
<body>
{% block content %}
{% endblock %}
</body>
</html>
我什至尝试将我的代码简化为:
from flask import Flask, redirect, url_for, render_template, request
app = Flask(__name__)
@app.route("/")
def home():
return render_template("extension.html")
@app.route("/login", methods=["POST", "GET"])
def login():
if request.method == "POST":
user = request.form["un"]
return redirect(url_for("user", usr=user))
else:
return render_template("extension.html")
@app.route("/<usr>")
def user(usr):
return f"<h1>{usr}</h1>"
if __name__ == "__main__":
app.run(debug=True)
但是,它仍然显示 405 Method Not Allowed。本教程直接进入代码,所以也许我必须安装或配置一些东西。
解决方案
在@app.route("/")
您不允许 POST 方法中。因此,当您尝试使用 url http://127.0.0.1:5000/发送表单时,服务器会拒绝它。但如果你纠正了,还有另一个问题:你在另一个 url ( @app.route("/login", methods=["POST", "GET"])
) 处实现了登录方法。
这是您的代码的工作修改(/
重定向到/login
)
from flask import Flask, redirect, url_for, render_template, request
app = Flask(__name__)
realUser: str = "name"
realPass: str = "pass"
@app.route("/")
def home():
return redirect(url_for("login"))
@app.route("/login", methods=["POST", "GET"])
def login():
if request.method == "POST":
user = request.form["un"]
password = request.form["password"]
if realUser == user and password == realPass:
return redirect(url_for("user", usr=user))
else:
return render_template("extension.html")
@app.route("/<usr>")
def user(usr):
return f"<h1>{usr}</h1>"
if __name__ == "__main__":
app.run(debug=True)
这种代码对于理解烧瓶的工作原理很有趣。要进一步了解身份验证方法,您应该查看Flask HTTP Basicauth - 它是如何工作的?.
推荐阅读
- javascript - jquery中的某些事件调用后如何自动单击我的textarea
- python - Why explicit string conversion is required in .format method in python is required?
- beautifulsoup - 使用mechanicalsoup设置表单元素的值w/oa名称
- android - 在后台线程中工作,停止 UI 线程
- ibm-cloud-infrastructure - 尽管定义了对象掩码,但缺少键
- c# - 如何在 Windows 窗体中移动鼠标指针时突出显示 TabControl 选项卡页?
- java - 如何使用 Jackson API 在序列化和反序列化上使用不同的 JSONProperty?
- java - 从具有两个不同大小/长度的两个数组列表中获取相同值的索引
- jquery - 内部锚在固定并行网站中不起作用
- string - Golang 中 Big Ints 前导零填充的 Format 方法的使用示例