zoukankan      html  css  js  c++  java
  • 发布功能完成(2017.11.28)

    1、编写要求登录的装饰器

    from functools import wraps

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

    @wraps(func)

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

              #要求登录

              return func(*args, ** kwargs)

          return wrapper #返回一个函数

    2、应用装饰器,要求在发布前进行登录,登录后可发布。

    @app.route('/question/',methods=['GET','POST'])
    @loginFirst
    def question():
    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():
        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('base'))

    3、完成发布函数。

    保存到数据库。

    重定向到首页。

    {% extends 'base.html' %}
    {% block title %}发布区{% endblock %}
    {% block head %}
        <link rel="stylesheet" type="text/css" href="../static/css/index.css">
    {% endblock %}
    {% block main %}
        <h1>发布问答</h1>
        <form action="{{ url_for('login') }}" method="post">
            <div class="box">
                <label for="question">问题</label><br>
                <textarea class="form-control" rows="4" id="question" placeholder="问题" name="title" id="title"
                          style="height: 50px"></textarea>
                <label for="questionDetail">详情</label><br>
                <textarea class="form-control" rows="4" id="questionDetail" placeholder="详细评论" name="detail" id="detail"
                          style="height: 130px"></textarea>
            </div>
            <br>
            <div class="input-area">
                <button type="submit" class="btn btn-default">发布</button>
            </div>
        </form>
    {% endblock %}

    4、建立发布内容的对象关系映射。

    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)
        datail=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()

  • 相关阅读:
    SqlServer Alwayson 搭建排错记录(一)
    SqlServer图形数据库初体验
    SqlServer报错:主体“dbo”不存在
    IIS重叠回收
    No module named 'revoscalepy'问题解决
    SqlServer查询文件组被占用情况
    SqlServer作业指定目标服务器
    [持续更新]UnsatisfiedLinkError常见问题及解决方案
    Android加载SO库UnsatisfiedLinkError错误的原因及解决方案
    _set_invalid_parameter_handler异常处理函数
  • 原文地址:https://www.cnblogs.com/laidaili/p/7908151.html
Copyright © 2011-2022 走看看