1. 程式人生 > 其它 >flask(四)初步實現使用者登入

flask(四)初步實現使用者登入

登入頁渲染

專案檔案中建立目錄static,用於存放靜態檔案,我這裡使用的是H-ui.admin_v3.1.3.1,需要的可以自己去下載,將解壓後的資料夾中的lib、static、temp放入剛建立的static中。
templates中建立檔案:admin/login.html

<!DOCTYPE HTML>
<html lang="zh">
<head>
    <meta charset="utf-8">
    <meta name="renderer" content="webkit|ie-comp|ie-stand">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no" />
    <meta http-equiv="Cache-Control" content="no-siteapp" />

    <!--[if lt IE 9]>
    <script type="text/javascript" src="{{url_for('static',filename='lib/html5shiv.js')}}"></script>
    <script type="text/javascript" src="{{url_for('static',filename='lib/respond.min.js')}}"></script>
    <![endif]-->

    <link rel="stylesheet" href="{{url_for('static',filename='static/h-ui/css/H-ui.min.css')}}">
    <link rel="stylesheet" href="{{url_for('static',filename='static/h-ui.admin/css/H-ui.login.css')}}">
    <link rel="stylesheet" href="{{url_for('static',filename='static/h-ui.admin/css/style.css')}}">
    <link rel="stylesheet" href="{{url_for('static',filename='lib/Hui-iconfont/1.0.8/iconfont.css')}}">

    <!--[if IE 6]>
    <script type="text/javascript" src="{{url_for('static',filename='lib/DD_belatedPNG_0.0.8a-min.js')}}"></script>
    <script>DD_belatedPNG.fix('*');</script>
    <![endif]-->

    <title>登入 </title>
    <meta name="keywords" content="後臺登陸">
    <meta name="description" content="後臺登陸">
</head>
<body>
<input type="hidden" id="TenantId" name="TenantId" value="" />
<div class="header"></div>
<div class="loginWraper">
  <div id="loginform" class="loginBox">
    <form class="form form-horizontal" action="" method="post">
      <div class="row cl">
        <label class="form-label col-xs-3"><i class="Hui-iconfont">&#xe60d;</i></label>
        <div class="formControls col-xs-8">
          <input id="username" name="username" type="text" placeholder="賬戶" class="input-text size-L">
        </div>
      </div>
      <div class="row cl">
        <label class="form-label col-xs-3"><i class="Hui-iconfont">&#xe60e;</i></label>
        <div class="formControls col-xs-8">
          <input id="password" name="password" type="password" placeholder="密碼" class="input-text size-L">
        </div>
      </div>
      <div class="row cl">
        <div class="formControls col-xs-8 col-xs-offset-3">
          <label for="online">
            <input type="checkbox" name="online" id="online" value="">
            使我保持登入狀態</label>
        </div>
      </div>
      <div class="row cl">
        <div class="formControls col-xs-8 col-xs-offset-3">
          <input name="" type="submit" class="btn btn-success radius size-L" value="&nbsp;登&nbsp;&nbsp;&nbsp;&nbsp;錄&nbsp;">
          <input name="" type="reset" class="btn btn-default radius size-L" value="&nbsp;取&nbsp;&nbsp;&nbsp;&nbsp;消&nbsp;">
	  {% if  message %}
            <p style="color:red">{{ message }} </p>
          {% endif %}
        </div>
      </div>
    </form>
	
  </div>
</div>
<div class="footer"></div>

<script type="text/javascript" src="{{url_for('static',filename='lib/jquery/1.9.1/jquery.min.js')}}"></script> 
<script type="text/javascript" src="{{url_for('static',filename='static/h-ui/js/H-ui.min.js')}}"></script>

</body>
</html>

檢視函式渲染靜態頁面:修改admin下的views.py

from flask import Blueprint, render_template

bp = Blueprint('admin',__name__)
@bp.route("/admin")
def index():
  return render_template('admin/index.html')

訪問:http://127.0.0.1:5000/admin/ 可檢視執行效果

初步實現使用者登入

修改admin/views.py檔案:

from flask import Blueprint, render_template,request,session,redirect,url_for
from .models import Users

bp = Blueprint('admin',__name__,url_prefix='/admin')
@bp.route("/login/",methods=['GET','POST'])
def login():
    error = None
    if request.method == 'GET':
        return render_template('admin/login.html')
    else:
        user = request.form.get('username')
        pwd = request.form.get('password')
        users = Users.query.filter_by(username=user).first()
        if users:
            if user == users.username and users.chek_password(pwd):
                session['user_id'] = users.uid  # 使用者id存於session
                return redirect(url_for('admin.index'))
            else:
                error = "使用者名稱或密碼錯誤"
                return render_template('admin/login.html',message=error)
        else:
            return render_template('admin/login.html',message="別試了,沒有此使用者!")
@bp.route('/')
def index():
    return render_template('admin/index.html')

訪問:http://127.0.0.1:5000/admin/login/可以進行登入驗證