zoukankan      html  css  js  c++  java
  • 登录之后更新导航

    1. from flask import Flask, render_template, request, redirect, url_for,session
      from flask_sqlalchemy import SQLAlchemy
      import config
      
      app = 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)
          Telphone = db.Column(db.String(20), nullable=True)
      
      
      # db.create_all()
      @app.route('/')
      def index():
          return render_template('index.html')
      
      @app.route('/login/', methods=['GET', 'POST'])
      def login():
          if request.method == 'GET':
              return render_template('login.html')
          else:
              usern = request.form.get('Username')
              passn = request.form.get('Password')
              user = User.query.filter(User.Username == usern).first()
              if user:
                  if user.Password == passn:
                      session['user'] = usern
                      return redirect(url_for('index'))
                  else:
                      return '密码错误'
                      # return window.alert("密码错误")
              else:
                  # return window.alert("用户名不存在")
                  return '用户名不存在'
      
      @app.context_processor
      def mycontext():
          usern=session.get('user')
          if usern:
              return  {'Username':usern}
          else:
              return {}
      
      # def login_re(func):
      #     @wraps(func)
      #     def wrapper(*args:**kwargs):
      @app.route('/logout/')
      def logout():
          session.clear()
          return  redirect(url_for("index"))
      
      
      @app.route('/register/', methods=['GET', 'POST'])
      def register():
          if request.method == 'GET':
              return render_template('register.html')
          else:
              usern = request.form.get('Username')
              passn = request.form.get('Password')
              teln = request.form.get('Telphone')
              user = User.query.filter(User.Username == usern).first()
              if user:
                  return '用户名已经存在'
              else:
                  user1 = User(Username=usern, Password=passn, Telphone=teln)
                  db.session.add(user1)
                  db.session.commit()
                  return redirect(url_for('login'))
      
      
      @app.route('/question/')
      def question():
          return render_template('question.html')
      
      
      if __name__ == '__main__':
          app.run(debug=True)
      <!DOCTYPE html>
      <html>
      <head>
          <meta charset="utf-8">
          <title>
              首页
              {% block denglutitle %}{% endblock %}
          {% block zhucetitle %}{% endblock %}
          {% block tupiantitle %}{% endblock %}
          </title>
          <link rel="stylesheet" href="http://cdn.static.runoob.com/libs/bootstrap/3.3.7/css/bootstrap.min.css">
          <script src="http://cdn.static.runoob.com/libs/jquery/2.1.1/jquery.min.js"></script>
          <script src="http://cdn.static.runoob.com/libs/bootstrap/3.3.7/js/bootstrap.min.js"></script>
          <script src="{{ url_for('static',filename='js/daohang.js') }}"></script>
      {% block dengluhead %}{% endblock %}
      {% block zhucehead %}{% endblock %}
      {% block tupianhead %}{% endblock %}
      </head>
      <body id="mybody">
      
      <nav class="navbar navbar-inverse" role="navigation">
          <div class="container-fluid">
              <div class="navbar-header">
                  <a class="navbar-brand" href="{{ url_for('daohang') }}">首页</a>
              </div>
              <div>
                  <ul class="nav navbar-nav">
                      <li><a href="{{ url_for('denglu') }}" onclick="">登陆</a></li>
                      <li><a href="{{ url_for('zhuce') }}" onclick="">注册</a></li>
                      <li class="dropdown">
                          <a href="#" class="dropdown-toggle" data-toggle="dropdown">
                              设置 <b class="caret"></b>
                          </a>
                          <ul class="dropdown-menu">
                              <li><a href="#">收藏</a></li>
                              <li><a href="#">分享</a></li>
                              <li><a href="#">搜索</a></li>
                              <li class="divider"></li>
                              <li><a href="#">点赞</a></li>
                          </ul>
                      </li>
                      <li><a href="#">||</a></li>
                  </ul>
              </div>
              <div style="float: left">
                  <img id="myonoff" onclick="mySwitch()" src="http://www.runoob.com/images/pic_bulbon.gif" style="40px" >
              </div>
              <div>
                  <ul class="nav navbar-nav">
                      <li><a href="{{ url_for('tupian') }}" onclick="">图片区</a></li>
                  </ul>
              </div>
              <div>
                  <input type="text" name="user" id="user" placeholder="请输入内容">
                  <input type="button" value="搜索" class="btn btn-success" onclick="">
              </div>
          </div>
      </nav>
      
      <nav class="navbar navbar-inverse navbar-fixed-bottom" role="navigation">
          <ul class="nav navbar-nav">
              <li><img src="http://www.gzcc.cn/2016/images/footer1-logo.png"></li>
              <li style="color: bisque;">版权所有@lin</li>
          </ul>
      </nav>
      
      <center>
          <script>document.write(Date())</script>
      </center>
      
      
      {% block denglubody %}{% endblock %}
      {% block zhucebody %}{% endblock %}
      {% block tupianbody %}{% endblock %}
      </body>
      </html>
      用上下文处理器app_context_processor定义函数
      1. 获取session中保存的值
      2. 返回字典
    2. 在父模板中更新导航,插入登录状态判断代码。
      1. 注意用{% ... %}表示指令。
      2. {{ }}表示变量
    3. 完成注销功能。
      1. 清除session
      2. 跳转
  • 相关阅读:
    VML编程之shape多边型.shapetype模版.shape与curve曲线《VML极道教程》原著:沐缘华
    VML编程之image图片《VML极道教程》原著:沐缘华
    软件开发项目的风险管理 (转)
    VML编程之polyline多边型《VML极道教程》原著:沐缘华
    VML编程之标记实战与line线《VML极道教程》原著:沐缘
    xml操作类,封装了常用的对XML文件的操作功能....
    Bugzilla 安装手册
    IT项目管理之<<少林练步拳>>(转)
    Atlas学习手记(8):调用本地Web Service简单介绍(转摘)
    WF从设计器出发,到对从设计器出来的工作流的调用加载,已经完成了整个工作流的详细设计,目前工作流设计器已经完成!
  • 原文地址:https://www.cnblogs.com/123hyf/p/7889865.html
Copyright © 2011-2022 走看看