Web 第十次作业

mapper

@Select("select * from emp where username =#{username} and password =#{password}")
 public Emp getByUsernameAndPassword(Emp emp);

service

@Override
    public Emp Login(Emp emp) {
        Emp e = supermarketMapper.getByUsernameAndPassword(emp);
        return e;
 
    }

logController

@Slf4j
@RestController
public class LoginController {
    private SupermarketFenyeService supermarketFenyeService;
    @PostMapping("/login")
    public Result login(HttpServletRequest request, @RequestBody Emp emp){
        Emp e = supermarketFenyeService.Login(emp);
       if(e != null){
           request.getSession().setAttribute("emp",emp.getName());
           String username=(String) request.getSession().getAttribute("uesrname");
           System.out.println("查询不为空。"+username);
           return Result.success();
       }
       else{
           String username=(String) request.getSession().getAttribute("uesrname");
           System.out.println("查询为空。"+username);
           return Result.erro(username);
       }
    }
}

html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
    <script src="./js/axios-0.18.0.js"></script>
    <link rel="stylesheet" href="element-ui/index.css">
    <script src="./element-ui/index.js"></script>
</head>
<body style="background-color: #8c939d;margin-top: 0">
<div id="app" style="width: 600px;
    text-align: center;
    margin: auto;
    margin-top: 7%;
    background-color: white;
    height: 400px;
    border-radius: 5%;
    ">
    <div style="width: 50px;float: left;display: inline-block;margin-top: 40px">
        <img src="1.jpg" alt="商品信息管理系统">
    </div>
    <div style="width: 300px;float: right;display: inline-block;margin-top: 100px;margin-right: 40px">
        <el-form :model="ruleForm" status-icon :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm">
            <el-form-item label="账号" prop="username">
                <el-input v-model="ruleForm.username" autocomplete="off"></el-input>
            </el-form-item>
            <el-form-item label="密码" prop="password">
                <el-input type="password" v-model="ruleForm.password" 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>
</div>
 
<script>
    new Vue({
        el: "#app",
        data() {
            const validateAccount = (rule, value, callback) => {
                if (value === '') {
                    callback(new Error('请输入账号'));
                }
                if (value.length = null) {
                    callback(new Error('账号不能为空!'));
                } else {
                    callback();
                }
            };
            const validatePassword = (rule, value, callback) => {
                if (value === '') {
                    callback(new Error('请输入密码'));
                }
                if (value.length != 6) {
                    callback(new Error('密码应该是六位数!'));
                } else {
                    callback();
                }
            }
            return {
                ruleForm: {
                    username: '',
                    password: ''
                },
                rules: {
                    username: [
                        {
                            validator: validateAccount, trigger: 'blur'
                        }
                    ],
                    password: [{
                        validator: validatePassword, trigger: 'blur'
                    }]
                }
            }
        },
        methods: {
            submitForm(formName) {
                this.$refs[formName].validate((valid) => {
                    if (valid) {
                        axios.post("/login", this.ruleForm,
                            {
                                headers: {
                                    'Content-Type': 'application/json'
                                }
                            }).then(r => {
                            if (r.data.statusCode == 1) {
                                window.location.href = '商品信息管理.html'
                            } else {
                                window.alert("账号或者密码错误!!!")
                                this.resetForm(formName)
                            }
                        }).catch(error => {
                            console.error(error);
                        })
                    } else {
                        console.log('提交失败!!!!');
                        return false;
                    }
 
                });
            },
            resetForm(formName) {
                this.$refs[formName].resetFields();
            }
        },
        mounted() {
 
        }
    })
</script>
 
 
</body>
</html>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值