目前在做后台管理页面,那就一定要有登陆页面,有登录页面那就有验证码和本地cookie或者session记住密码的操作。
验证码这里用到的是图片验证码,设计思路是用img标签来挂img的路径,路径是后台请求的(mounted时发送获取)。
在点击登陆之后,先将用户输入的值发送到后台获取response后,对验证码进行验证,验证通过后发送请求验证用户名和密码时候正确。这里这么写是防止恶意登录,在前三次可以没有验证码,超过三次就要有验证码,这就是要将对验证码和用户登录名密码的验证(登录次数在这里控制,cookie或者session的书写也在这里,验证通过后,如果用户勾选了记住密码,那就写入)分成两个请求,放到两个方法里面。如果次数少于三次则直接调用第二个,如果大于了则验证码页面div要显示v-if,也要先执行验证码验证if。这就是主要思路了。
当然验证码还可以是短信码,逻辑也可以是其他的,但是呢,总的思路并没有差别。
备注:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<!-- 告诉浏览器网页所识别的文件类型及语言类型 -->
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>登录</title>
<!-- 让一些搜索引擎搜索到你的网页 -->
<meta name="description" content="">
<meta name="keywords" content="">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/4.0.0-beta/css/bootstrap.min.css" rel="external nofollow" >
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/popper.js/1.12.5/umd/popper.min.js"></script>
<script src="https://cdn.bootcss.com/bootstrap/4.0.0-beta/js/bootstrap.min.js"></script>
<script src="tool.js"></script>
<style>
.carousel-inner img {
width:100%;
height:100%;
}
.jumbotron {
margin-top: 10px;
margin-bottom: 0px;
padding-top: 10px;
}
#demo {
width:100%;
height: 500px;
}
.row {
height: 264px;
}
.left {
float: left;
width: 70%;
}
.right {
float: left;
width: 30%;
}
.card {
height: 340px;
}
.carousel-inner {
height: 500px;
}
.footer {
position: absolute;
bottom: 0;
height: 60px;
}
.jumheight1 {
height: 100px;
}
.jumheight2 {
height: 100px;
}
.end_name {
margin-bottom: 5px;
}
.footer2 {
padding-top: 210px;
text-align: center;
}
.test{
margin-bottom: 75px;
}
.carousel-control-prev,
.carousel-control-next{
bottom: 120px;
}
</style>
</head>
<body>
<div>
<form class="form active" method="post" action="{:url('index/Login/doLogin')}">
<div class="jumbotron text-info bg-light jumheight1">
<h1>图书阅读网</h1>
<p>一个免费的图书网站</p>
</div>
<!-- 轮播图 -->
<!-- 指示符 -->
<div class="row">
<div class="left">
<div id="demo" class="carousel slide " data-ride="carousel">
<ul class="carousel-indicators">
<li data-target="#demo" data-slide-to="0" class="active"></li>
<li data-target="#demo" data-slide-to="1"></li>
<li data-target="#demo" data-slide-to="2"></li>
</ul>
<!-- 轮播图片 -->
<div class="carousel-inner">
<div class="carousel-item active">
<img src="http://static.runoob.com/images/mix/img_fjords_wide.jpg">
</div>
<div class="carousel-item">
<img src="http://static.runoob.com/images/mix/img_nature_wide.jpg">
</div>
<div class="carousel-item">
<img src="http://static.runoob.com/images/mix/img_mountains_wide.jpg">
</div>
</div>
<!-- 左右切换按钮 -->
<a href="#demo" rel="external nofollow" rel="external nofollow" class="carousel-control-prev" data-slide="prev">
<span class="carousel-control-prev-icon"></span>
</a>
<a href="#demo" rel="external nofollow" rel="external nofollow" class="carousel-control-next" data-slide=next>
<span class="carousel-control-next-icon"></span>
</a>
</div>
</div>
<div class="right">
<!-- 登陆窗口 -->
<div class="card">
<div class="card-header">
用户登陆
</div>
<div class="card-body">
<form>
<table style="border-collapse: separate;/*border-spacing: 30px 20px;*/">
<tr>
<td class="margin-top:10">
<label>电话号码:</label>
</td>
<td>
<input type="text" name="username" pattern="^\d{11}" id="username" class="form-control" placeholder="请输入您的电话号码">
<!-- <input type="text" name="username" pattern="^\d{11}" id="username" class="form-control" placeholder="请输入您的电话号码" required> -->
</td>
</tr>
<tr>
<td>
<label>密码:</label>
</td>
<td>
<input type="password" name="password" id="password" class="form-control" placeholder="请输入您的密码">
</td>
</tr>
<tr>
<td>
<label for="captcha" class="test">验证码:</label>
</td>
<td>
<input type="text" name="captcha" class="form-control " id="captcha" placeholder="请输入验证码">
<!-- 点击验证码更换 -->
<br>
<div class="code-img"><img height="50px" src="{:captcha_src()}" alt="captcha" onClick="this.src='{:captcha_src()}?'+Math.random()"/></div>
</td>
</tr>
</table>
<div class="footer">
<button type="submit" class="btn btn-primary" >登陆</button>
<button type="submit" class="btn btn-secondary " formaction="{:url('index/Repassword/index')}" >忘记密码?</button>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
</div>
<script>
fieldTest();
</script>
</body>
</html>