完成登录功能,用session记住用户名
登录功能完成:
- js:设置return
- html:设置
- form
- input
- py:
- @app.route设置methods
- GET
- POST
- 读取表单数据
- 查询数据库
- 用户名密码对:
- 记住用户名
- 跳转到首页
- 用户名密码不对:
- 提示相应错误。
- 用户名密码对:
session:
- 从`flask`中导入`session`
- 设置`SECRET_KEY`
- 操作字典一样操作`session`:增加用户名`session['username']=`username
1 from flask import Flask, render_template, request, redirect, url_for, session
2 from flask_sqlalchemy import SQLAlchemy
3 import config
4
5 app = Flask(__name__)
6 app.config.from_object(config)
7 db = SQLAlchemy(app)
8
9
10 class User(db.Model):
11 __tablename__ = 'user'
12 id = db.Column(db.Integer, primary_key=True, autoincrement=True)
13 username = db.Column(db.String(20), nullable=False)
14 password = db.Column(db.String(20), nullable=False)
15 nickname = db.Column(db.String(50))
16
17
18 # user = User(username = 'misjiaojiao',password = 'misjiaojiao')
19 # db.session.add(user)
20 # db.session.commit()
21
22 # user = User.query.filter(User.username == 'misjiaojiao').first()
23 # db.session.delete(user)
24 # db.session.commit()
25
26 # user = User.query.filter(User.username == 'misjiaojiao').first()
27 # user.password='1234657'
28 # db.session.commit()
29
30 # db.create_all()
31
32 @app.route('/')
33 def index():
34 return render_template('switch切换.html')
35
36
37 @app.route('/login/', methods=['GET', 'POST'])
38 def login():
39 if request.method == 'GET':
40 return render_template('login登录.html')
41 else:
42 usern = request.form.get('username')
43 passw = request.form.get('password')
44 user = User.query.filter(User.username == usern).first()
45 if user:
46 session['user'] = usern
47 session.permanent = True
48 return redirect(url_for('index'))
49 else:
50 return u'error username or password'
51
52
53 @app.route('/regist/', methods=['GET', 'POST'])
54 def regist():
55 if request.method == 'GET':
56 return render_template('regist注册.html')
57 else:
58 username = request.form.get('username')
59 password = request.form.get('password')
60 nickname = request.form.get('nickname')
61 user = User.query.filter(User.username == username).first()
62 if user:
63 return u'username existed'
64 else:
65 user = User(username=username, password=password, nickname=nickname)
66 db.session.add(user) # 数据库操作
67 db.session.commit()
68 return redirect(url_for('login'))
69
70
71 if __name__ == '__main__':
72 app.run(debug=True)
1 import os 2 SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:@127.0.0.1:3306/mis_db?charset=utf8' 3 SQLALCHEMY_TRACK_MODIFICATIONS = False 4 SECRET_KEY = os.urandom(24)

浙公网安备 33010602011771号