发布功能完成。

本文介绍了一个使用Python Flask框架实现的简单登录验证装饰器及基于该装饰器的问题发布功能。通过ORM方式创建了问题发布的数据模型,并实现了问题的前端发布页面。

  • 编写要求登录的装饰器

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

保存到数据库。

重定向到首页。

PY:

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('user.id'))
    author=db.relationship('User',backref=db.backref('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('index'))

HTML:

{% extends'index.html' %}

{% block title %}发布问答 {% endblock %}

{% block head %}
<link rel="stylesheet" type="text/css" href="{{ url_for('static',filename='css/886.css') }}">
<script src="{{ url_for('static',filename='js/tt.js')}}"></script>
{% endblock %}

{% block main %}
<div class="form-group">
<form action="{{ url_for('question') }}" method="post">
<label for="questionDetail">标题</label><br>
<textarea class="form-control" rows="1" cols="50" id="questionDetail" name="title"></textarea><br>
<label for="questionDetail">详情</label><br>
<textarea class="form-control" rows="5" cols="50" id="questionDetail"name="detail"></textarea><br>
<input type="checkbox" name="c1" id="c1" value="">记住我<br>
<button type="submit" onclick="foLogin()">发布问答</button>
</form>
</div>
{% endblock %}

 

转载于:https://www.cnblogs.com/JUNJUNER/p/7908124.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值