问题描述
最近在尝试使用springboot做一个后台管理系统,由于目前还没有学会vue,所以前端页面采用的 thymeleaf+ajax的模式。前两天在开发登录页的时候遇到了一个问题,登录之后按照正常流程应该是要在控制器里跳转到首页的,但是我的登录页死活不跳转。 控制器的逻辑也是没有问题的
@Controller
class LoginController {
@Resource
lateinit var adminService: AdminService
@RequestMapping("/login",method = [RequestMethod.POST])
fun login(@RequestParam name:String,@RequestParam password:String):String?{
val admin=adminService.login(name,password)
return if (admin==null){
""
}else{
//一般情况下是可以直接渲染到main.html的,但是添加了Ajax之后跳转就会失效
"main"
}
}
}Ajax里边的逻辑
$.ajax({
method: 'POST',
url: 'http://localhost:8080/login',
data: {
name: $('[name="username"]').val(),
password: $('[name="password"]').val()
},
success:function (r) {
console.log(r)
},
error:function (result) {
alert(result)
}
})控制台返回的信息

解决方法
这里先给出解决方法,至于原因会在最后说明。在控制器中新增一个mainPage方法,与main.html相对应,可解决问题。
@RequestMapping("/main")
fun mainPage():String{
return "main"
}然后再在Ajax的success回调中调用这个控制器,完成跳转。
在整本书中我们所涉及许多的Flex框架源码,但为了简洁,我们不总是显示所指的代码。当你阅读这本书时,要求你打开Flex Builder,或能够访问Flex3框架的源码,跟随着我们所讨论源码是怎么工作及为什么这样做。 如果你跟着阅读源码,请注意,我们经常跳过功能或者具体的代码,以便我们可以对应当前的主题。这样能防止我们远离当前的主题,主要是讲解代码的微妙之处。这并不是说那些代码的作用不重要,而是那些代码处理特别的案例,防止潜在的错误或在生命周期的后面来处理,只是我们当前没有讨论它。有需要的朋友可以下载看看
success:function (r) {
window.location.href="http://localhost:8080/main" rel="external nofollow"
},原因梳理
一开始以为是控制器写的有问题,然后就各种修改控制器的配置,最后发现无论怎么修改都没有效果,并且发现如果在浏览器中直接调用main.html的控制器路径也是没有问题的,这种情况就想到了会不会是Ajax那的问题。为了验证是不是Ajax的问题,在Ajax回调成功的代码那里打了个断点,想看一下后台返回来的数据到底是个啥

看到没,控制器把整个main.html的页面都返回到Ajax里了,也就是说,在使用Ajax的时候,SpringBoot的控制器并没有进行页面渲染,而是把目标页面结构返回了,能跳转才怪了。









