昨天一直纠结这么一个问题,应用场景是这样的:

这里登陆是通过jquery的ajax传输数据到后台controller类相应的映射mapping接收。本来是想,在后台验证成功之后返回一个视图modelAndView。但是却不曾想到有这么一个问题,就是不管你怎么返回,前台就是不跳转页面。这里牵扯到一个很重要的问题。先来看看我前端ajax发送登陆请求的代码:

<script type="text/javascript">
$(function() {
$('#submitLogin').click(function() {
$.ajax({
type:"POST",
url:"/user/checkLogin",
dataType: "json",
data: $("#loginform").serialize(),
success:function(data,status){
alert("成功"+data);
},
error:function () {
alert("失败");
}
});
});
});
</script>

再来看一个不推荐的后台示例:(错误的原因)

@RequestMapping(value = "/checkLogin",method = RequestMethod.POST)
public @ResponseBody ModelAndView userLogin(TUserLoginVo tUserLoginVo, HttpServletRequest request,HttpServletResponse response){
HttpSession session=request.getSession();
String code= (String) session.getAttribute("code");
System.out.println("---"+session.getAttribute("code"));
ModelAndView mv=new ModelAndView();
if(code.equals(tUserLoginVo.getCheckcode())){
TUser tUser=staffService.finUser(tUserLoginVo.getUsername(),tUserLoginVo.getPassword());
if(tUser!=null){
mv.setViewName("redirect:/pages/test.html");
System.out.println("---"+tUser.getUsername());
return mv;
}
}
mv.setViewName("redirect:/pages/LoginPage.html");
return mv; }

上面直接返回一个视图,但是前台就是没看到跳转,而且直接执行了error的方法,问题是明明后台代码已经执行了啊。

下面先来解释一下jquery ajax代码里面都扮演了什么角色!

type:"POST",表示通过post请求。
url:"/user/checkLogin",表示请求映射在controller里面的方法前的地址(例如: @RequestMapping(value = "/checkLogin",method = RequestMethod.POST))
dataType: "json",这个很重要,这是直接表面我期望的后台给我返回一个json类型的数据,如果不是,则会直接执行error的方法。
下面在分析一个通常不设置的属性:
contentType:"application/json",这是表明我们前台传过去的是json类型的数据,因此需要将我们的数据提前通过 JSON.stringify(a);将数据a变成json类型,当然并不是什么都能变成json类型的,希望记住!
接下来
data: $("#loginform").serialize(),这是一个非常快捷的方法,可以将表单中的值直接取出来,拿上面的例子,生成的格式是这样的:
通过这种方式,后台也可以直接用对象来接收,至于它内部怎么组装成对象的,与表单中的name属性有关,一定要切记,表单中,没有后台需要的数据的标签中千万别嵌套name属性。同时name属性的值一定要对应我们PO对象中的字段值!
例如我的一个PO类:
    private String username;
private String password;
private String checkcode;

那些getter和setter方法我就不摆出来了

它必须对应html表单中:

如果发生不一致,后台接收就会报不支持的错误!

为了迎合 dataType: "json",这一要求,后台一定要在方法返回值前面加上 @ResponseBody  :

public @ResponseBody  Object userLogin(){
*****
}

以上是一个注意点,现在来另外一个!

也是之前提到的,json数据类型,后台返回的json数据类型,虽然我们加了@ResponseBody,但这个千万记住,这个是可以将对象、集合等类型转换为json类型,但是有时候我们需要返回一个字符串怎么办,那对不起,@ResponseBody无法帮助我们转换成json类型,而且也不会报错,只是前台会只执行error的方法,因为我们设置了dataType: "json"

通常情况下,是这样设置成json的,所以我们要返回一个字符串最好是另辟蹊径(当然dataType: "json"里面的json也可以改成text等,但是没这个必要)

我是这一解决的,直接对比代码的返回值吧(自己组装的一个json格式的字符串)

@RequestMapping(value = "/checkLogin",method = RequestMethod.POST)
public @ResponseBody Object userLogin(TUserLoginVo tUserLoginVo, HttpServletRequest request,HttpServletResponse response){
HttpSession session=request.getSession();
String code= (String) session.getAttribute("code");
System.out.println("---"+session.getAttribute("code"));
if(code.equals(tUserLoginVo.getCheckcode())){
TUser tUser=staffService.finUser(tUserLoginVo.getUsername(),tUserLoginVo.getPassword());
if(tUser!=null){
System.out.println("---"+tUser.getUsername());
return "{\"LoginOK\":\"LoginOK\"}";
}
}
return "{\"LoginError\":\"LoginError\"}"; }

问题解决了,前台执行了success的方法!

当然,上面的方法也不好,那怎么办,我们需要的是json,但又无法转得了。

可以这一,给一个通用方法:

package com.liyong.bos.utils;

import java.io.Serializable;
import java.util.List; public class JsonResult<T, K> implements Serializable {
private boolean result;
private String msg;
private List<T> dataList;
private K data;
private T dataObje;
public K getData() {
return data;
} public void setData(K data) {
this.data = data;
} public List<T> getDataList() {
return dataList;
} public void setDataList(List<T> dataList) {
this.dataList = dataList;
} public String getMsg() {
return msg;
} public void setMsg(String msg) {
this.msg = msg;
}
public boolean isResult() {
return result;
} public void setResult(boolean result) {
this.result = result;
} public T getDataObje() {
return dataObje;
} public void setDataObje(T dataObje) {
this.dataObje = dataObje;
}
}

把我们需要的数据封装到jsonResult对象中即可,然后返回值是JsonResult就行。具体功能请看代码。

然后前台就可以用这种方式接收:

<script type="text/javascript">
$(function() {
$('#submitLogin').click(function() { $.ajax({
type:"POST",
url:"/user/checkLogin",
dataType: "json",
data: $("#loginform").serialize(),
success:function(data,status){
if(data.msg=="success"){
location.href="/pages/test.html";
}else if(data.msg=="error"){
location.href="/pages/LoginPage.html";
}
},
error:function () {
alert("失败");
}
});
});
});
</script>

jquery的ajax与spring mvc对接注意事项的更多相关文章

  1. Ajax分页 Spring MVC + Hibernate

    效果图: 1.  添加公共类.方法.代码 1.    分页类:Page.java package cn.com.aperfect.sso.base.dao; import java.util.Arra ...

  2. Ajax请求Spring Mvc 时总是返回 302 Moved Temporarily

    功能上主要是实现在前台点击保存按钮,单元格变成文本框,修改值后请求后台保存数据.但在做的过程中,ajax 请求总是不能请求到后.打开浏览器调试,查看到http状态码总是返回 http/1.1  302 ...

  3. [Java Web – 3A] – Spring MVC开发注意事项

    1.使用Maven构建项目 2.SpringMVC 绝对路径的问题 首先要明确一点,在html中,资源文件也是有自己的URL,即href中是支持绝对路径.如下代码: <link href=&qu ...

  4. Spring MVC+ajax进行信息验证

    本文是一个ajax结合Spring MVC使用的入门,首先我们来了解一下什么是Ajax AJAX 不是新的编程语言,而是一种使用现有标准的新方法.AJAX 最大的优点是在不重新加载整个页面的情况下,可 ...

  5. spring mvc 与 jquery ajax

    在 Spring mvc3中,响应.接受 JSON都十分方便. 使用注解@ResponseBody可以将结果(一个包含字符串和JavaBean的Map),转换成JSON. 使用 @RequestBod ...

  6. Spring MVC Controller与jquery ajax请求处理json

    在用 spring mvc 写应用的时候发现jquery传递的[json数组对象]参数后台接收不到,多订单的处理,ajax请求: "}]}]} $.ajax({ url : url, typ ...

  7. Spring MVC与jQuery结合使用Ajax技术

    gradle配置 group 'org.zln.webDemo' version '1.0-SNAPSHOT' apply plugin: 'java' apply plugin: 'jetty' s ...

  8. Sping MVC不使用任何注解处理(jQuery)Ajax请求(基于XML配置)

    1. Spring Spring框架是一个轻量级的解决方案,是一个潜在的一站式商店,用于构建企业就绪的应用程序.Spring框架是一个Java平台,为开发Java应用程序提供全面的基础架构支持.Spr ...

  9. spring mvc实现ajax 分页

    使用到的技术: ·spring 3 mvc ·json ·jquery ·java ·mysql 首先,要了解如何在spring mvc中使用json. 以下主要从Dao和View及Controlle ...

随机推荐

  1. C++数据

    const :常量 ~x == -++x == -(x+1)   二进制数,1变为0,0变为1 ^                               相同为0,不同为1 &      ...

  2. MyBatis快速入门(1):搭建环境和单表映射

    一.MyBatis简介    一说起对象关系映射框架,大家第一时间想到的肯定是Hibernate.Hibernate作为一个著名的框架,功能十分强大.我们只需要配置好实体类和数据表之间的关系,Hibe ...

  3. iOS 文本转语音(TTS)详解:Swift

    上一篇博客讲解了iOS的speech FrameWork语音识别的功能:http://www.cnblogs.com/qian-gu-ling/p/6599670.html,对应的这篇博客就写一下文本 ...

  4. JDK中日期和时间的几个常用类浅析(四)

    java.time.Instant   java.time.Instant类对应的是时间线上的一个时间点.该类通过保存着从格林威治的起始时间(1970年一月一日零点零分)开始计算所经过的纳妙数来表示时 ...

  5. 01.PHP5.x编译详解

    ##PHP5.5编译安装 ``` wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo yum i ...

  6. 深入学习 DUBBO

    1.什么是 RPC 协议? RPC 的全称是 Remote Procedure Call 是一种进程间通信方式.它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过程或函数,而不用程序员显 ...

  7. ZEROC ICE 跨平台间程序调用 java版

    前言: 本来建博客是为了和大家分享一些前端的开发经验和心得呢,但是阴差阳错,第一篇技术博客确实关于跨平台,跨语言服务端调用的解决方案---ZEROC ICE. 最近一个项目涉及到java.python ...

  8. MySQL学习笔记(四)—存储过程

    一.概述      存储过程是数据库定义的一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句.存储过程可以避免开发人员重复的编写相同的SQL语句,而且存储过程是在MySq ...

  9. net.sz.framework 框架 登录服务器架构 单服2 万 TPS(QPS)

    前言 无论我们做什么系统,95%的系统都离不开注册,登录: 而游戏更加关键,频繁登录,并发登录,导量登录:如果登录承载不起来,那么游戏做的再好,都是徒然,进不去啊: 序言 登录所需要的承载,包含程序和 ...

  10. 爬虫入门系列(二):优雅的HTTP库requests

    在系列文章的第一篇中介绍了 HTTP 协议,Python 提供了很多模块来基于 HTTP 协议的网络编程,urllib.urllib2.urllib3.httplib.httplib2,都是和 HTT ...