代码拉取完成,页面将自动刷新
# -*- coding: utf-8 -*-
from functools import wraps
from flask import Flask, request, session, g, redirect, url_for, abort, render_template, flash, jsonify
import MySQLdb
config = {
'host': '127.0.0.1',
'port': 3306,
'user': 'root',
'passwd': '123456',
'db': 'citest',
'charset': 'utf8'
}
db = MySQLdb.connect(**config)
cursor = db.cursor()
app = Flask(__name__)
app.config.from_object('config')
@app.before_request
def before_request():
#app.logger.info('before request started')
pass
@app.teardown_request
def teardown_request(exception):
#app.logger.info('teardown request')
pass
def login_required(func):
@wraps(func)
def decorated_function(*args, **kwargs):
if session['username'] == None:
abort(401)
return func(*args, **kwargs)
return decorated_function
@app.errorhandler(401)
def page_forbidden(error):
app.logger.info(u'无权限')
return redirect('/login')
@app.route('/')
@app.route('/login', methods=['GET'])
def login():
return render_template('login.html')
@app.route('/login', methods=['POST'])
def login_post():
username = request.form['username']
password = request.form['password']
count = cursor.execute('select * from t_user where username=%s and password=%s', (username, password))
if count == 1:
flash(u'登录成功')
session['username'] = cursor.fetchone()[1]
return redirect('/user/list')
error_tip = u'用户名或密码错误'
return render_template('login.html', error_tip=error_tip)
@app.route('/logout')
def logout():
session['username'] = None
return redirect('/login')
@app.route('/user/list')
@login_required
def user_list():
cursor.execute('select * from t_user limit 10')
users = [dict(id=row[0], username=row[1], password=row[2], create_date=row[3]) for row in cursor.fetchall()]
'''
results = cursor.fetchall()
users = []
for row in results:
id = row[0]
username = row[1]
password = row[2]
create_date = row[3]
user = {'id': id, 'username': username, 'password': password, 'create_date': create_date}
users.append(user)
'''
return render_template('user-list.html', users=users)
@app.route('/user/new', methods=['GET'])
@login_required
def user_new():
return render_template('user-new.html')
@app.route('/user/create', methods=['POST'])
@login_required
def user_create():
username = request.form['username']
password = request.form['password']
cursor.execute('insert into t_user(username, password, create_date) values(%s,%s,current_timestamp())', (username, password))
flash(u'创建成功')
return redirect('/user/list')
@app.route('/user/<user_id>')
@login_required
def user_show(user_id):
cursor.execute('select * from t_user where id=%s', (user_id,))
row = cursor.fetchone()
id = row[0]
username = row[1]
password = row[2]
create_date = row[3]
user = {'id': id, 'username': username, 'password': password, 'create_date': create_date}
return render_template('user-show.html', user=user)
@app.route('/json')
def json_show():
user = {'id': 1, 'username': u'中文名字', 'pasword': '123456'}
#return jsonify(user=user)
return jsonify(user)
@app.route('/user/delete/<user_id>')
@login_required
def user_delete(user_id):
cursor.execute('delete from t_user where id=%s', (user_id))
flash(u'删除成功')
return redirect('/user/list')
if __name__ == '__main__':
app.run()
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。