博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
发布功能完成
阅读量:4674 次
发布时间:2019-06-09

本文共 3868 字,大约阅读时间需要 12 分钟。

  • 编写要求登录的装饰器

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

保存到数据库。

重定向到首页。

from flask import Flask,render_template,request,redirect,url_for,sessionfrom flask_sqlalchemy import SQLAlchemyimport configfrom functools import wrapsfrom datetime import datetimeapp = Flask(__name__)app.config.from_object("config")db=SQLAlchemy(app)class User(db.Model):    __tablename__ = "user"    id = db.Column(db.Integer,primary_key=True,autoincrement=True)    username = db.Column(db.String(20),nullable=False)    password = db.Column(db.String(20),nullable=False)    nickname = db.Column(db.String(20))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'))db.create_all()@app.route('/')def vi():    return render_template("base.html")@app.route('/first')def first():    return render_template("first.html")def login_first(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"])@login_firstdef 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('first'))@app.route("/login",methods=["GET","POST"])def login():    if request.method == "GET":      return render_template("login.html")    else:        usern = request.form.get("usern")        passw = request.form.get("userp")        user = User.query.filter(User.username==usern).first()        if user:            if user.password == passw:                session["user"] = usern                # session.permanent = True                return redirect(url_for("first"))            else:                return "密码错误,请重新输入!"        else:            return "用户名不存在!"@app.route("/regist",methods=["GET","POST"])def regist():    if request.method == "GET":        return render_template("regist.html")    else:        usern1 = request.form.get("newn")        passw1 = request.form.get("newp")        user = User.query.filter(User.username==usern1).first()        if user:            return "用户名已存在!"        else:            user = User(username = usern1,password = passw1)            db.session.add(user)            db.session.commit()            return redirect(url_for("login"))@app.context_processordef context():    usern=session.get("user")    if usern:        return{
'username':usern} else: return {}@app.route('/clear')def clear(): session.clear() return redirect(url_for('first'))if __name__ == '__main__': app.run(debug=True)
{% extends 'base.html' %}{% block title %}问题发布{% endblock %}{% block head %}    
{% endblock %}{% block main %}
>{% endblock %}

 

转载于:https://www.cnblogs.com/yin-yeah/p/7910609.html

你可能感兴趣的文章
MYSQL中的日期转换
查看>>
在线修改Schema
查看>>
【学术篇】SDOI2008 仪仗队
查看>>
5.递归实现,把M元用最少的硬币来凑。不同面值的硬币,有10元,5元,2元,1元。...
查看>>
第6章—渲染web视图—使用Thymeleaf
查看>>
Android动态添加Fragment
查看>>
OGRE粒子系统简介
查看>>
Windows 10 使用问题
查看>>
linux xargs命令
查看>>
用CSS3实现图像风格
查看>>
转载--黎曼
查看>>
mysql的建表语句
查看>>
免费的HTML5版uploadify
查看>>
机器学习之路:python 集成分类器 随机森林分类RandomForestClassifier 梯度提升决策树分类GradientBoostingClassifier 预测泰坦尼克号幸存者...
查看>>
通过onkeydown事件来控制只允许数字
查看>>
186. [USACO Oct08] 牧场旅行
查看>>
一个屌丝程序猿的人生(三十九)
查看>>
Linux常用命令
查看>>
Spring之@Configuration配置解析
查看>>
Windows操作系统远程Linux服务器传输文件方法(以EasyDSS云平台、EasyNVR上传部署为例)...
查看>>