前端请求没错,后端拦截没错,就是报404

使用环境

maven + mysql + springboot + springmvc + mybatis + bootstrap3 + vue

前端界面如下(使用 bootstrap3 + vue):

<html>
<head>
    <title>用户登录</title>
    <meta charset="UTF-8">
    <style>
        .error {
            color: red;
        }
    </style>
    <link rel="stylesheet" href="/static/bootstrap-3.3.7-dist/css/bootstrap.min.css">
    <script src="/static/bootstrap-3.3.7-dist/js/jquery.min.js"></script>
    <script src="/static/bootstrap-3.3.7-dist/js/bootstrap.min.js"></script>
    <script src="/static/bootstrap-3.3.7-dist/js/vue.min.js"></script>
    <script src="/static/bootstrap-3.3.7-dist/js/axios.min.js"></script>
</head>
<body>
<div class="container" style="width:500px;margin-top:30px">
    <div class="panel panel-primary">
        <div class="panel-heading">
            <h3 class="panel-title">
                用户登录
            </h3>
        </div>
        <div class="panel-body">
            <form class="form-signin">
                <h2 class="form-signin-heading">请登录</h2>
                <label class="sr-only">用户名</label>
                <input type="text" class="form-control" v-model="usercode" placeholder="输入用户名" required autofocus>
                <label class="sr-only">密码</label>
                <input type="password" v-model="password" class="form-control" placeholder="输入密码" required>
                <div class="checkbox">
                    <label>
                        <input type="checkbox" value="remember-me"> 记住我
                    </label><br>
                    <span class="error">{{message}}</span>
                </div>
                <button class="btn btn-lg btn-primary btn-block" type="button" @click="login()">登录</button>
            </form>
        </div>
    </div>
</div>
</body>
</html>

<script>
    let vs = new Vue({
        el: '.container',
        data: {
            usercode: '',
            password: '',
            message: ''
        },
        methods: {
            //用户登录
            login() {
                axios.get("/login?usercode=" + this.usercode + "&password=" + this.password).then(resp => {
                    if (resp.data.success) {
                        location.href = "/users/listmenus.html";
                    } else {
                        alert(resp.data.message);
                    }
                })
            }
        }
    })
</script>

控制层代码如下:

@RestController
public class LoginController {
    @Autowired
    private UserService userService;
    /**
     * 1.用户登录
     * @param usercode
     * @param password
     * @return
     */
    @RequestMapping("login")
    public Result login(@RequestParam("usercode") String usercode, @RequestParam("password") String password,  HttpSession session){
        //1.1)根据 usercode 查询用户并用设置用户关联的菜单及权限列表
        SysUser user = userService.findUserByUserCode(usercode,password);
        //1.2)如果存在此用户就放到session中
        if(user != null){
            session.setAttribute("user",user);
            return new Result(true,"登录成功!");
        }
        return new Result(false,"登录失败!");
    }
}

如果,maven、tomcat、springboot配置都没有问题,的情况下。

因为上面的前端页面的代码有一些格式不正确,导致后端进不去,前端又报404错误。

我的个人的解决方式是:——————重新创建login.html

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>用户登录</title>
    <style>
        .error {
            color: red;
        }
    </style>
    <link rel="stylesheet" href="/bootstrap-3.3.7-dist/css/bootstrap.min.css">
    <script src="/bootstrap-3.3.7-dist/js/jquery.min.js"></script>
    <script src="/bootstrap-3.3.7-dist/js/bootstrap.min.js"></script>
    <script src="/bootstrap-3.3.7-dist/js/vue.min.js"></script>
    <script src="/bootstrap-3.3.7-dist/js/axios.min.js"></script>
</head>
<body>
<div class="container" style="width:500px;margin-top:30px">
    <div class="panel panel-primary">
        <div class="panel-heading">
            <h3 class="panel-title">
                用户登录
            </h3>
        </div>
        <div class="panel-body">
            <form class="form-signin">
                <h2 class="form-signin-heading">请登录</h2>
                <label class="sr-only">用户名</label>
                <input type="text" class="form-control" v-model="usercode" placeholder="输入用户名" required autofocus>
                <label class="sr-only">密码</label>
                <input type="password" v-model="password" class="form-control" placeholder="输入密码" required>
                <div class="checkbox">
                    <label>
                        <input type="checkbox" value="remember-me"> 记住我
                    </label><br>
                    <span class="error">{{message}}</span>
                </div>
                <button class="btn btn-lg btn-primary btn-block" type="button" @click="login()">登录</button>
            </form>
        </div>
    </div>
</div>
</body>
</html>
<script>
    let vs = new Vue({
        el: '.container',
        data: {
            usercode: '',
            password: '',
            message: ''
        },
        methods: {
            login() {        //用户登录
                axios.get("/login?usercode=" + this.usercode + "&password=" + this.password).then(resp => {
                    if (resp.data.success) {
                        location.href = "/users/listmenus.html";
                    } else {
                        alert(resp.data.message);
                    }
                })
            }
        }
    })
</script>

仅限我个人所遇问题解决方案,仅参考,如有不足之处请多指教!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值