在 Flask 中重定向到 URL
- 2025-02-28 08:23:00
- admin 原创
- 62
问题描述:
我正在尝试做Response.redirect
与 C# 中等效的事情 - 即:重定向到特定的 URL - 我该怎么做呢?
这是我的代码:
import os
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello():
return 'Hello World!'
if __name__ == '__main__':
# Bind to PORT if defined, otherwise default to 5000.
port = int(os.environ.get('PORT', 5000))
app.run(host='0.0.0.0', port=port)
解决方案 1:
您必须返回重定向:
import os
from flask import Flask,redirect
app = Flask(__name__)
@app.route('/')
def hello():
return redirect("http://www.example.com", code=302)
if __name__ == '__main__':
# Bind to PORT if defined, otherwise default to 5000.
port = int(os.environ.get('PORT', 5000))
app.run(host='0.0.0.0', port=port)
代码的默认值为 302,因此code=302
可以省略或用其他重定向代码(301、302、303、305 和 307 中的一个)替换。
请参阅flask docs 上的文档。
解决方案 2:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import os
from flask import Flask, redirect, url_for
app = Flask(__name__)
@app.route('/')
def hello():
return redirect(url_for('foo'))
@app.route('/foo')
def foo():
return 'Hello Foo!'
if __name__ == '__main__':
# Bind to PORT if defined, otherwise default to 5000.
port = int(os.environ.get('PORT', 5000))
app.run(host='0.0.0.0', port=port)
看一下文档中的示例。
解决方案 3:
来自Flask API 文档(v. 2.0.x):
flask.redirect (,,)
location
`code=302`Response=None
返回一个响应对象(WSGI 应用程序),如果调用该对象,则将客户端重定向到目标位置。支持的代码为 301、302、303、305 和 307。不支持 300,因为它不是真正的重定向;不支持 304,因为它是带有已定义 If-Modified-Since 标头的请求的答案。
0.6 版中的新功能:位置现在可以是使用 iri_to_uri() 函数编码的 unicode 字符串。
参数:
location
– 响应应重定向到的位置。
code
– 重定向状态代码。默认为 302。
Response
(class) – 实例化响应时使用的 Response 类。如果未指定,则默认为 werkzeug.wrappers.Response。
解决方案 4:
我认为这个问题值得更新,只需与其他方法进行比较。
以下是在 Flask(0.12.2)中从一个 URL 重定向(3xx)到另一个 URL 的方法:
#!/usr/bin/env python
from flask import Flask, redirect
app = Flask(__name__)
@app.route("/")
def index():
return redirect('/you_were_redirected')
@app.route("/you_were_redirected")
def redirected():
return "You were redirected!"
if __name__ == "__main__":
app.run(host="0.0.0.0", port=8000, debug=True)
官方文件在这里。
解决方案 5:
flask.redirect(location, code=302)
文档可以在这里找到。
解决方案 6:
Flask 包含redirect
重定向到任意 URL 的功能。此外,你可以使用以下错误代码提前中止请求abort
:
from flask import abort, Flask, redirect, url_for
app = Flask(__name__)
@app.route('/')
def hello():
return redirect(url_for('hello'))
@app.route('/hello'):
def world:
abort(401)
默认情况下,每个错误代码都会显示黑白错误页面。
该redirect
方法默认采用代码 302。此处是http 状态代码的列表。
解决方案 7:
如果你只想重定向到一个没有任何状态代码或类似内容的 URL,你可以简单地说
from flask import Flask, redirect
app = Flask(__name__)
@app.route('/')
def redirect_to_link():
# return redirect method, NOTE: replace google.com with the link u want
return redirect('https://google.com')
以下是 Flask 文档的链接,了解更多解释
解决方案 8:
为此,您只需使用redirect
包含在flask
from flask import Flask, redirect
app = Flask(__name__)
@app.route('/')
def hello():
return redirect("https://www.exampleURL.com", code = 302)
if __name__ == "__main__":
app.run()
另一个有用的提示(因为您是 flask 新手)是在初始化 flask 对象后添加,app.debug = True
因为调试器输出在找出错误时会很有帮助。
解决方案 9:
有两种方法可以重定向到 Flask 中的 URL。
例如,您想在用户登录后将其重定向到另一条路线等。
您可能还希望将用户重定向到需要某些变量的路线,例如:
@app.route('/post/<string:post_id>')
好吧,要实现案例#1的Flask重定向,很简单,只需执行以下操作:
from flask import Flask,redirect,render_template,url_for
app = Flask(__name__)
@app.route('/login')
def login():
# if user credentials are valid, redirect to user dashboard
if login == True:
return redirect(url_for(app.dashboard))
else:
print("Login failed !, invalid credentials")
return render_template('login.html',title="Home Page")
@app.route('/dashboard')
def dashboard():
return render_template('dashboard.html',title="Dashboard")
要实现案例 #2 的 Flask 重定向,请执行以下操作
from flask import Flask,redirect,render_template,url_for
app = Flask(__name__)
@app.route('/home')
def home():
# do some logic, example get post id
if my_post_id:
# **Note:** post_id is the variable name in the open_post route
# We need to pass it as **post_id=my_post_id**
return redirect(url_for(app.open_post,post_id=my_post_id))
else:
print("Post you are looking for does not exist")
return render_template('index.html',title="Home Page")
@app.route('/post/<string:post_id>')
def open_post():
return render_template('readPost.html',title="Read Post")
同样的事情也可以在视图中完成
<a href="{{url_for(app.open_post,post_id=my_post_id)}}"></a>
请注意:重定向时始终使用app.home
或app.something..
(路由或视图函数名称),而不是使用。原因是,如果您出于某种原因redirect("/home")
将路由示例从 修改为,那么您的代码将会中断,"/home"
`"/index/page"`
解决方案 10:
你可以这样使用:
import os
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello():
# Redirect from here, replace your custom site url "www.google.com"
return redirect("https://www.google.com", code=200)
if __name__ == '__main__':
# Bind to PORT if defined, otherwise default to 5000.
port = int(os.environ.get('PORT', 5000))
app.run(host='0.0.0.0', port=port)
这是该代码的参考链接。
解决方案 11:
如何在 Flask 中重定向用户/请求
在 API 处理函数中抛出错误会将用户重定向到错误处理程序,该处理程序可以处理重定向。或者,您可以redirect
像其他人所说的那样直接调用,但这是重定向未经授权用户的另一种方式。为了说明我的意思,我在下面提供了一个示例。
在需要授权用户的情况下
首先让我们假设您有一条受保护的路线,并且您像这样进行保护。
def handle_api_auth(func):
"""
**handle_api_auth**
wrapper to handle public api calls authentications
:param func: a function to be wrapped
:return: wrapped function
"""
@functools.wraps(func)
def auth_wrapper(*args, **kwargs):
api_key: Optional[str] = request.headers.get('x-api-key')
secret_token: Optional[str] = request.headers.get('x-secret-token')
domain: Optional[str] = request.base_url
if is_request_valid(api_key=api_key, secret=secret_token, domain=domain):
return func(*args, **kwargs)
# NOTE: throwing an Error Here will redirect your user to an error handler or alteratively you can just call redirect like everyone else is saying, but this is another way of redirecting unathorized users
message: str = "request not authorized"
raise UnAuthenticatedError(status=error_codes.un_auth_error_code, description=message)
return auth_wrapper
is_request_valid的定义如下
@app_cache.cache.memoize(timeout=15 * 60, cache_none=False) # timeout equals fifteen minutes // 900 seconds
def is_request_valid(api_key: str, secret: str, domain: str) -> bool:
"""
**is_api_key_valid**
validates api keys on behalf of client api calls
:param api_key: str -> api_key to check
:param secret: str -> secret token
:param domain: str -> domain registered for the api_key and secret_token
:return: bool -> True if api_key is valid
"""
organization_id: str = config_instance.ORGANIZATION_ID
# NOTE: lets assumy api_keys_view.get_api_key will return the api keys from some database somewhere
response = api_keys_view.get_api_key(api_key=api_key, organization_id=organization_id)
response_data, status_code = response
response_dict = response_data.get_json()
if not response_dict.get('status'):
return False
api_instance: dict = response_dict.get('payload')
if not isinstance(api_instance, dict):
return False
domain: str = domain.lower().strip()
# NOTE accessing the keys this way will throw ValueError if keys are not available which is what we want
# Any Error which gets thrown Ridirects the Users from the path the user is on to an error handler.
is_secret_valid: bool = hmac.compare_digest(api_instance['secret_token'], secret)
is_domain_valid: bool = hmac.compare_digest(api_instance['domain'], domain)
_request_valid: bool = is_secret_valid and is_domain_valid
return not not api_instance.get('is_active') if _request_valid else False
像这样定义你的错误处理程序
from flask import Blueprint, jsonify, request, redirect
from werkzeug.exceptions Unauthorized
error_handler = BluePrint('error_handlers', __name__)
@error_handler.app_errorhandler(Unauthorized)
def handle_error(e : Unauthorized) -> tuple:
"""default unath handler"""
return jsonify(dict(message=e.description)), e.code if request.headers.get('content-type') == 'application/json' else redirect('/login')
处理其他错误相同,并注意,如果请求
不是 json,用户会被重定向到登录页面,如果 json 向用户发送了未登录的响应,那么就由前端来处理 Unath 错误。
扫码咨询,免费领取项目管理大礼包!