• 编写要求登录的装饰器

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):
  • 完成发布函数。

保存到数据库。

重定向到首页。

 1 class Question(db.Model):
 2     __tablename__='question'
 3     id = db.Column(db.Integer, primary_key=True, autoincrement=True)
 4     title = db.Column(db.String(100),nullable=False)
 5     detail = db.Column(db.Text,nullable=False)
 6     creat_time = db.Column(db.DateTime,default=datetime.now)
 7     author_id = db.Column(db.Integer, db.ForeignKey('user.id'))
 8     author = db.relationship('User',backref=db.backref('question'))
 9 
10 
11 def loginFirst(func):
12     @wraps(func)
13     def wrapper(*args, **kwargs):
14         if session.get('user'):
15             return func(*args, **kwargs)
16         else:
17             return  redirect(url_for('login'))
18         return wrapper
19 
20 
21 
22 @app.route('/question',methods=['GET','POST'])
23 @loginFirst
24 def question():
25     if request.method == 'GET':
26         return render_template('question问答.html')
27     else:
28         title = request.form.get('title')
29         detail = request.form.get('detail')
30         author_id = User.query.filter(User.username == session.get('user')).first().id
31         question = Question(title = title,detail = detail,author_id = author_id)
32         db.session.add(question)

 

posted on 2017-11-28 09:58  016李云基  阅读(116)  评论(0编辑  收藏  举报