与Cookie不同,Session(会话)数据存储在服务器上。会话是客户端登录到服务器并注销服务器的时间间隔。需要在该会话中保存的数据会存储在服务器上的临时目录中。
from flask import render_template
from flask import make_response
from flask import Flask,session,redirect,url_for,escape,request
app=Flask(__name__)
#为每个客户端的会话分配会话ID。
#会话数据存储在cookie的顶部,服务器以加密方式对其进行签名。
#对于此加密,Flask应用程序需要一个定义的SECRET_KEY。(随便写)
app.secret_key='fkdjsafjdkfdlkjfadskjfadskljdsfklj'
@app.route('/')
def index():
if 'username' in session:
username=session['username']
return '登录用户名是:'+username+'
'+\
"点击这里注销"
return "您暂未登录,
"+\
"点击这里登录"
@app.route('/login',methods=['GET','POST'])
def login():
if request.method=='POST':
#设置会话变量
session['username']=request.form['username']
return redirect(url_for('index'))
return '''
'''
@app.route('/logout')
def logout():
#释放会话变量
session.pop('username',None)
return redirect(url_for('index'))
if __name__ == '__main__':
app.run(debug=True)
http://127.0.0.1:5000/
from flask import Flask, flash, redirect, render_template, request, url_for
app = Flask(__name__)
app.secret_key = 'random string'
@app.route('/')
def index():
return render_template('index.html')
@app.route('/login', methods = ['GET', 'POST'])
def login():
error = None
if request.method == 'POST':
if request.form['username'] != 'admin' or request.form['password'] != 'admin':
error = 'Invalid username or password. Please try again!'
#如果登录成功,则会在索引模板上刷新成功消息。
else:
'''
flash(message, category)
message 参数是要闪现的实际消息。
category 参数是可选的。它可以是“error”,“info”或“warning”。
'''
flash('You were successfully logged in')
return redirect(url_for('index'))
#如果出现错误,则会重新显示登录模板,并显示错误消息。
return render_template('login.html', error = error)
if __name__ == '__main__':
app.run(debug=True)
login.html
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Logintitle>
head>
<body>
<form method = "post" action = "http://localhost:5000/login">
<table>
<tr>
<td>Usernametd>
<td><input type = 'username' name = 'username'>td>
tr>
<tr>
<td>Passwordtd>
<td><input type = 'password' name = 'password'>td>
tr>
<tr>
<td><input type = "submit" value = "Submit">td>
tr>
table>
form>
{% if error %}
<p><strong>Errorstrong>: {{ error }}p>
{% endif %}
body>
html>
index.html
DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Indextitle>
head>
<body>
{% with messages = get_flashed_messages() %}
{% if messages %}
{% for message in messages %}
<p>{{ message }}p>
{% endfor %}
{% endif %}
{% endwith %}
<h3>Welcome!h3>
<a href = "{{ url_for('login') }}">logina>
body>
html>
点击登录链接(用户名及密码在程序里设置,例子给的都是admin)
提交后显示
新建文件夹upload
用来保存成功上传后的文件
from flask import Flask,render_template,request
'''
目标文件的名称可以是硬编码的,
也可以从 request.files[file] 对象的 filename 属性中获取。
但是,建议使用 secure_filename() 函数获取它的安全版本。
'''
from werkzeug.utils import secure_filename
import os
app=Flask(__name__)
#定义上传文件夹的路径
#app.config['MAX_CONTENT_LENGTH'] 指定要上传的文件的最大大小(以字节为单位)
app.config['UPLOAD_FOLDER']='upload/'
@app.route('/upload')
def upload_file():
return render_template('upload.html')
@app.route('/uploader',methods=['GET','POST'])
def uploader():
if request.method=='POST':
f=request.files['file']
print(request.files)
#secure_filename获取中文文件名需自行百度解决,不难
f.save(os.path.join(app.config['UPLOAD_FOLDER'],secure_filename(f.filename)))
return 'file uploaded successfully'
else:
return render_template('upload.html')
if __name__ == '__main__':
app.run(debug=True)
upload.html
<html>
<head>
<title>File Uploadtitle>
head>
<body>
<form action="http://localhost:5000/uploader" method="POST" enctype="multipart/form-data">
<input type="file" name="file" />
<input type="submit" value="提交" />
form>
body>
html>
http://localhost:5000/upload
我选了一张图片提交
注意用secure_filename
获取中文文件名时,中文会被省略。网上有很多博客写了解决办法,我就不做更改了
显示提交成功
上传后的文件被保存在了upload
文件夹
Flask 的扩展通常命名为Flask-Foo
或者Foo-Flask
通过pip
安装
寻找Flask扩展地址
这篇博客就先到这里
下一篇博客再对几个扩展做进一步学习