• 发布功能完成


    • 编写要求登录的装饰器

    from functools import wraps

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

    @wraps(func)

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

    复制代码
     1 def loginFirst(func):
     2     # 定义一个函数将其返回
     3     @wraps(func)
     4     def wrapper(*args,**kwargs):
     5         if session.get('title'):
     6             return func(*args, **kwargs)
     7         else:
     8             return redirect(url_for('login'))
     9     # 返回一个函数
    10     return wrapper
    复制代码

              #要求登录

              return func(*args, ** kwargs)

          return wrapper #返回一个函数

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

    复制代码
     1 #发布问答
     2 @app.route('/question' , methods=['GET','POST'])
     3 @loginFirst
     4 def question():
     5     if request.method == 'GET':
     6         return render_template('question.html')
     7     else:
     8         book_title = request.form.get('title')
     9         book_content = request.form.get('content')
    10         user_id = request.form.get('user_id')
    11         book = Book(id='1', title=book_title, content=book_content, author_id=user_id)
    12         db.session.add(book)  # 加入数据库
    13         db.session.commit()
    14         return  redirect(url_for('index'))
    复制代码
    • 建立发布内容的对象关系映射。
    class Question(db.Model):
    • 完成发布函数。
    复制代码
     1 class Question(db.Model):
     2     __tablname__ = 'question'
     3     id = db.Column(db.String(17), primary_key=True)  # 数据库唯识别id
     4     title = db.Column(db.String(30)) #文章标题
     5     abstracts = db.Column(db.String(30)) #文章摘要
     6     content = db.Column(db.TEXT) #文章内容
     7     createdate = db.Column(db.DATETIME) #发布时间
     8     author_id = db.Column(db.String(17),db.ForeignKey('user.id')) #发布者id
     9     size = db.Column(db.String(30)) #文章长度
    10     chilk = db.Column(db.String(30)) #阅读数
    11     disc = db.Column(db.String(30))
    12     classification = db.Column(db.String(17),db.ForeignKey('classification.id')) #文章分类id
    13     authorClass = db.relationship('User',backref=db.backref('book'))
    14     classificationClass = db.relationship('Classification',backref=db.backref('book'))
    复制代码
  • 相关阅读:
    2017-2018 ACM-ICPC, NEERC, Moscow Subregional Contest
    2017-2018 ACM-ICPC, NEERC, Northern Subregional Contest
    BZOJ5104 : Fib数列
    2017-2018 ACM-ICPC Southeast Regional Contest (Div. 1)
    2017 ACM Jordanian Collegiate Programming Contest
    BZOJ4910 : [Sdoi2017] 苹果树
    2017-2018 ACM-ICPC Pacific Northwest Regional Contest (Div. 1)
    BZOJ4912 : [Sdoi2017]天才黑客
    BZOJ4739 : 定向越野
    概率笔记11——一维正态分布的最大似然估计
  • 原文地址:https://www.cnblogs.com/lianghaohui123/p/7912534.html
Copyright © 2020-2023  润新知