博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
发布功能完成。
阅读量:4921 次
发布时间:2019-06-11

本文共 4315 字,大约阅读时间需要 14 分钟。


  • 编写要求登录的装饰器

from functools import wraps

def loginFirst(func): #参数是函数

@wraps(func)

      def wrapper(*args, ** kwargs): #定义个函数将其返回

          #要求登录

          return func(*args, ** kwargs)

      return wrapper #返回一个函数

  • 应用装饰器,要求在发布前进行登录,登录后可发布。
@app.route('/question/',methods=['GET','POST']) @loginFirst def question():

 

  • 建立发布内容的对象关系映射。
class Question(db.Model):
  • 完成发布函数。

保存到数据库。

重定向到首页。

 py

from flask import Flask,render_template,request,redirect,url_for,sessionfrom flask_sqlalchemy import SQLAlchemyfrom datetime import datetimefrom functools import wrapsimport configapp = Flask(__name__)app.config.from_object(config)db = SQLAlchemy(app)class User(db.Model):    __tablename__ = 'user'    id = db.Column(db.Integer,primary_key=True,autoincrement=True)    username = db.Column(db.String(20),nullable=False)    password = db.Column(db.String(20),nullable=False)class Question(db.Model):    __tablename__='question'    id = db.Column(db.Integer, primary_key=True, autoincrement=True)    title =db.Column(db.String(100), nullable=False)    detail = db.Column(db.Text, nullable=False)    creat_time=db.Column(db.DateTime,default=datetime.now)    author_id = db.Column(db.Integer,db.ForeignKey('user.id'))    author=db.relationship('User',backref=db.backref('question'))#db.create_all()#user=User(username='yyyy1',password='111111')#db.session.add(user)#db.session.commit()#user = User.query.filter(User.username == 'yyyy1').first()#user=User.query.filter(User.username=='yyyy1').first()#user.password='234567'#print(user.username,user.password)#db.session.commit()#user=User.query.filter(User.username == 'yyyy1').first()#db.session.delete(user)#db.session.commit()#@app.route('/')def base2():    return render_template('base2.html')@app.route('/register/', methods=['GET','POST'])def register():    if request.method=='GET':        return render_template('register.html')    else:        usern=request.form.get('username')        passw= request.form.get('password')        user=User.query.filter(User.username==usern).first()        if user:            return 'username existed'        else:            user=User(username=usern,password=passw)            db.session.add(user)            db.session.commit()            return redirect(url_for('login2'))@app.route('/login2/', methods=['GET','POST'])def login2():    if request.method=='GET':        return render_template('login2.html')    else:        usern=request.form.get('username')        passw= request.form.get('password')        user=User.query.filter(User.username==usern).first()        if user:                if user.password == passw:                    session['user'] = usern                    session.permanent=True                    return redirect(url_for('base2'))                else:                    return "密码错误,请重新输入。"        else:                    return "用户名不存在!"@app.route('/logout/')def logout():    session.clear()    return redirect(url_for('base2'))@app.context_processordef mycontext():    usern=session.get('user')    if usern:        return {
'username':usern} else: return {}def loginFirst(func): @wraps(func) def wrapper(*args, **kwargs): if session.get('user'): return func(*args, **kwargs) else: return redirect(url_for('login2')) return wrapper@app.route('/question/',methods=['GET','POST'])@loginFirstdef question(): if request.method == 'GET': return render_template('question.html') else: title = request.form.get('title') detail = request.form.get('detail') author_id = User.query.filter(User.username == session.get('user')).first().id question = Question(title=title, detail=detail, author_id=author_id) db.session.add(question) db.session.commit() return redirect(url_for('base2'))if __name__ == '__main__': app.run(debug=True)

html

{% extends 'base2.html' %}{
% block title %} 问题反馈{
% endblock %}{
% block head %}
{
% endblock %}{
% block main %}

问题反馈

{
% endblock %}

 

转载于:https://www.cnblogs.com/222ya/p/7911330.html

你可能感兴趣的文章
[Xcode 实际操作]六、媒体与动画-(14)使用SystemSoundId播放简短声音
查看>>
Letter Combinations of a Phone Number
查看>>
对象序列化
查看>>
UVA 208 Firetruck (DFS+剪枝)
查看>>
windows设置电脑的固定IP
查看>>
Python
查看>>
犀牛Phinoceros 如何切换中文语言
查看>>
Win7如何解决精简版的迅雷7无法运行
查看>>
C#.NET常见问题(FAQ)-如何判断某个字符是否为汉字
查看>>
直接用postman测试api ,服务器端没提供跨域也可以访问。
查看>>
数据的类型以及内置方法
查看>>
继承之super关键字的使用
查看>>
XML - 报表数据的新大陆
查看>>
echart在X轴下方添加字
查看>>
Map集合的两种取出方式
查看>>
GridView,Repeater增加自动序号列
查看>>
SMO算法精解
查看>>
第k小元素学习记录
查看>>
avi文件格式详解【转】
查看>>
django
查看>>