最簡單的flask程序html
from flask import Flask app = Flask(__name__) @app.route('/') def hello_world(): return 'Hello World!' if __name__ == '__main__': app.run()
外部服務器可訪問flask
app.run(host='0.0.0.0')
打開調試模式api
app.debug = True
app.run()
或
app.run(debug=True)
路由服務器
@app.route('/hello') def hello(): return 'Hello World'
能夠爲函數指定多個路由cookie
url中添加變量session
@app.route('/user/<username>') def show_user_profile(username): # show the user profile for that user return 'User %s' % username @app.route('/post/<int:post_id>') def show_post(post_id): # show the post with the given id, the id is an integer return 'Post %d' % post_id
int | 接受整數 |
float | 接受浮點數 |
path | 和缺省狀況相同,但也接受斜槓 |
添加對post的支持app
@app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': do_the_login() else: show_the_login_form()
使用模板文件輸出dom
from flask import render_template @app.route('/hello/') @app.route('/hello/<name>') def hello(name=None): return render_template('hello.html', name=name)
默認使用 Jinja2 模板引擎函數
模板文件示例post
<!doctype html> <title>Hello from Flask</title> {% if name %} <h1>Hello {{ name }}!</h1> {% else %} <h1>Hello World!</h1> {% endif %}
request對象
from flask import request @app.route('/login', methods=['POST', 'GET']) def login(): error = None if request.method == 'POST': if valid_login(request.form['username'], request.form['password']): return log_the_user_in(request.form['username']) else: error = 'Invalid username/password' # 若是請求訪求是 GET 或驗證未經過就會執行下面的代碼 return render_template('login.html', error=error)
獲取url中的參數
searchword = request.args.get('key', '')
文件上傳
from flask import request @app.route('/upload', methods=['GET', 'POST']) def upload_file(): if request.method == 'POST': f = request.files['the_file'] f.save('/var/www/uploads/uploaded_file.txt') ...
須要客戶端設置enctype="multipart/form-data"
使用客戶端的文件名保存。
from flask import request from werkzeug import secure_filename @app.route('/upload', methods=['GET', 'POST']) def upload_file(): if request.method == 'POST': f = request.files['the_file'] f.save('/var/www/uploads/' + secure_filename(f.filename))
使用cookie
from flask import request @app.route('/') def index(): username = request.cookies.get('username') # 使用 cookies.get(key) 來代替 cookies[key] , # 以免當 cookie 不存在時引起 KeyError 。
存儲cookie
from flask import make_response @app.route('/') def index(): resp = make_response(render_template(...)) resp.set_cookie('username', 'the username') return resp
使用 redirect() 函數能夠重定向。使用 abort() 能夠更早 退出請求,並返回錯誤代碼:
from flask import abort, redirect, url_for @app.route('/') def index(): return redirect(url_for('login')) @app.route('/login') def login(): abort(401) this_is_never_executed()
定製404頁面
from flask import render_template @app.errorhandler(404) def page_not_found(error): return render_template('page_not_found.html'), 404
make_response() 包裹返回表達式,得到響應對象,並對該對象 進行修改,而後再返回:
@app.errorhandler(404) def not_found(error): resp = make_response(render_template('error.html'), 404) resp.headers['X-Something'] = 'A value' return resp
使用會話
from flask import Flask, session, redirect, url_for, escape, request app = Flask(__name__) @app.route('/') def index(): if 'username' in session: return 'Logged in as %s' % escape(session['username']) return 'You are not logged in' @app.route('/login', methods=['GET', 'POST']) def login(): if request.method == 'POST': session['username'] = request.form['username'] return redirect(url_for('index')) return ''' <form action="" method="post"> <p><input type=text name=username> <p><input type=submit value=Login> </form> ''' @app.route('/logout') def logout(): # 若是會話中有用戶名就刪除它。 session.pop('username', None) return redirect(url_for('index')) # 設置密鑰,複雜一點: app.secret_key = 'A0Zr98j/3yX R~XHH!jmN]LWX/,?RT'
隨機生成一個祕鑰
import os os.urandom(24)
記錄日誌
app.logger.debug('A value for debugging') app.logger.warning('A warning occurred (%d apples)', 42) app.logger.error('An error occurred')
flash()
用於閃現一個消息。在模板中,使用 get_flashed_messages()
來操做消息。