码迷,mamicode.com
首页 > 其他好文 > 详细

发布功能完成

时间:2017-11-28 13:30:28      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:发布   lte   prim   .com   cto   use   turn   session   for   

  • 编写要求登录的装饰器

from functools import wraps

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

@wraps(func)

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

          #要求登录

          return func(*args, ** kwargs)

      return wrapper #返回一个函数

def loginFirst(func):
    @wraps(func)
    def wrapper(*args, **kwargs):
        if session.get(user):
            return func(*args, **kwargs)
        else:
            return redirect(url_for(login))
    return wrapper

 

  • 应用装饰器,要求在发布前进行登录,登录后可发布。
@app.route(‘/question/‘,methods=[‘GET‘,‘POST‘])
@loginFirst
def question():
@app.route(/ask/,methods=[GET,POST])
@loginFirst
def ask():
    if request.method==GET:
        return render_template(ask.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(base))# 跳转

 

 

  • 建立发布内容的对象关系映射。
class Question(db.Model):
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)
    create_time=db.Column(db.DateTime,default=datetime.now)
    author_id =db.Column(db.Integer,db.ForeignKey(use.id))
    author=db.relationship(User,backref=db.backref(question))

 

  • 完成发布函数。

保存到数据库。

重定向到首页。

 

发布功能完成

标签:发布   lte   prim   .com   cto   use   turn   session   for   

原文地址:http://www.cnblogs.com/yybx/p/7909172.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!