验证用户名是否正确

1==》// 引入qs               import qs from 'qs';

2===》收集用户账号后, 发送请求 把参数发给后端(把用户名和密码发给后端 验证是否存在这个账号)

3===》

<template>
<div>
<el-form
:model="ruleForm"
status-icon
:rules="rules"
ref="ruleForm"
label-width="100px"
class="demo-ruleForm"
>
<el-form-item label="用户名" prop="user">
<el-input v-model.number="ruleForm.user"></el-input>
</el-form-item> <el-form-item label="密码" prop="pass">
<el-input type="password" v-model="ruleForm.pass" autocomplete="off"></el-input>
</el-form-item> <el-form-item label="确认密码" prop="checkPass">
<el-input type="password" v-model="ruleForm.checkPass" autocomplete="off"></el-input>
</el-form-item> <el-form-item>
<el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>
<el-button @click="resetForm('ruleForm')">重置</el-button>
</el-form-item>
</el-form>
</div>
</template>

  

<script>
// 引入qs
import qs from "qs"; export default {
data() {
var checkAge = (rule, value, callback) => {
if (!value) {
return callback(new Error("用户名不能为空"));
} //它的意思是 当符合要求的条件的时候,就触发回调函数。这个回调的函数是显示成功的标识
setTimeout(() => {
callback();
}, 500);
}; var validatePass = (rule, value, callback) => {
if (value === "") {
callback(new Error("请输入密码"));
} else {
if (this.ruleForm.checkPass !== "") {
this.$refs.ruleForm.validateField("checkPass");
}
callback();
}
}; var validatePass2 = (rule, value, callback) => {
if (value === "") {
callback(new Error("请再次输入密码"));
} else if (value !== this.ruleForm.pass) {
callback(new Error("两次输入密码不一致!"));
} else {
callback();
}
};
return {
// 存放用户的数据是 ruleForm 而不是data
ruleForm: {
pass: "",
checkPass: "",
user: ""
},
rules: {
pass: [{ validator: validatePass, trigger: "blur" }], checkPass: [{ validator: validatePass2, trigger: "blur" }], user: [{ validator: checkAge, trigger: "blur" }]
}
};
}, methods: {
submitForm(formName) {
this.$refs[formName].validate(valid => {
if (valid) {
alert("submit!");
//获取用户的数据哦
//console.log(this.ruleForm.user, this.ruleForm.pass ) //用一个对象 username是存放的名字哦 用的是一个爹对象将他们存起来
let params = {
username: this.ruleForm.user,
password: this.ruleForm.pass
};
console.log(params);
// 发送请求 把参数发给后端(把用户名和密码发给后端 验证是否存在这个账号)
this.axios
.post("http://127.0.0.1:666/login/checklogin", qs.stringify(params))
.then(response => {
// 接收后端返回的数据
let { error_code, reason } = response.data;
// 判断
if (error_code === 0) {
// 弹成功提示
this.$message({
type: "success",
message: reason
});
// 跳转到后端首页
this.$router.push("/");
} else {
// 弹失败提示
this.$message.error(reason);
}
})
.catch(err => {
console.log(err);
});
} else {
// 否则就是false
alert("前端验证失败 不能提交给后端!");
return false;
}
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
}
}
};
</script>

  

  

后端node.js代码
const express = require("express");
const router = express.Router(); // 引入连接数据库的模块
const connection = require("./connect"); // 统一设置响应头 解决跨域问题
router.all("*", (req, res, next) => {
// 设置响应头 解决跨域(目前最主流的方式)
res.header("Access-Control-Allow-Origin", "*");
next();
}); /*
验证用户名和密码是否正确的路由
*/
router.post("/checklogin", (req, res) => {
// 接收用户名和密码
let { username, password } = req.body;
// 构造sql(查询用户名和密码是否存在)
const sqlStr = `select * from account where username='${username}' and password='${password}'`;
// 执行sql语句
connection.query(sqlStr, (err, data) => {
if (err) throw err;
// 判断
if (!data.length) {
// 如果不存在
res.send({ error_code: 1, reason: "请检查用户名或密码!" });
} else {
res.send({ error_code: 0, reason: "欢迎您!登录成功!" });
}
});
}); module.exports = router;

最新文章

  1. CentOS下安装使用start-stop-daemon
  2. PHP打印测试,PHP调试技巧
  3. GPS部标平台的架构设计(四)-百度地图设计
  4. Android.mk的用法和基础【转】
  5. GIT之二 基础篇(2)
  6. CXF自动生成客户端
  7. Eclipse vim插件安装使用
  8. Landsat8数据不同波段组合的用途
  9. .NET并行计算和并发3-Invoke
  10. FTP下载时连接正常获取不到数据
  11. ztree使用font-awesome字体的问题,
  12. 信用评分及模型原理解析(以P2P网贷为例)
  13. PythonStudy——数据类型转化 Data type conversion
  14. [SCOI2015] 情报传递
  15. 内联扩展 inline expansion
  16. [转]Jboss基础
  17. Attr的visitNewClass()方法解读
  18. Runway for Mac(UML 流程图绘图工具)破解版安装
  19. 【嵌入式】——makefiles
  20. c# mvc 获取 HtmlHelper 表达式值和时间格式化 去边框

热门文章

  1. [20191108]内核参数tcp_keepalive与sqlnet.ora expire_time的一些总结.txt
  2. 如何为 Automatic Undo Management 调整 UNDO Tablespace 的大小 (Doc ID 262066.1)
  3. [Go] go连接influxdb的库
  4. Centos7下的zabbix安装与部署
  5. AtCoder Regular Contest 99
  6. shell基础、变量、相关脚本
  7. WinCC的画面使用技巧
  8. CF1254D Tree Queries(树链剖分)
  9. 简单的Python GUI界面框架
  10. 2019年9月Github上最热门的JavaScript开源项目