zoukankan      html  css  js  c++  java
  • 发布功能完成。

    编写要求登录的装饰器

    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('/questions/',methods=['GET','POST'])
    @loginFirst
    def questions():
        if request.method == 'GET':
            return render_template('questions.html')
        else:
            title = request.form.get('title')  # 获取form中的数据
            detail = request.form.get('detail')
            author_id = User.query.filter(User.username == session.get('user')).first().id
            questions = Question(title=title, detail=detail, author_id=author_id)
            db.session.add(questions)  # 保存到数据库
            db.session.commit()  # 提交
            return redirect(url_for('index'))  # 跳转
    • 建立发布内容的对象关系映射。
    class Question(db.Model):
    • 完成发布函数。
    #创建发布问答模型
    class Question(db.Model):
        __tablename__ ='questions'
        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('user.id'))#外键约束,数据类型db.Integer第二个参数指定外键是user表的id
        author=db.relationship('User',backref=db.backref('questions'))

    保存到数据库。

    重定向到首页。

  • 相关阅读:
    MS SQL入门基础:SQL数据库中的事务
    MS SQL入门基础:删除数据
    MS SQL入门基础:触发器的高级应用
    MS SQL入门基础:SQL Server 安全性管理的途径
    MS SQL入门基础:权限管理
    MS SQL入门基础:打开游标
    MS SQL入门基础:数据库更新添加数据
    MS SQL入门基础:游标、游标的优点和种类
    MS SQL入门基础:创建和管理视图
    MS SQL入门基础:数据库中的连接查询
  • 原文地址:https://www.cnblogs.com/iamzhuangyuan/p/7909294.html
Copyright © 2011-2022 走看看