本人转载自: http://blog.csdn.net/feicongcong/article/details/54705933

return "redirect:/icProject/index"; 重定向到请求

model.addAttribute("page", page);

        return "icProject/index";跳转到页面

1.ajax提交,将数组封装成json,后台用List<Integer>接

2.form提交

方法一:

前台form

<form action="/sysUser/create" method="post">
<input name="roleId" >
<input name="roleId" >
<input name="roleId" >
</form>

后台

public String create(Model model,@Valid SysUserPojo sysUserPojo, BindingResult bindingResult, final RedirectAttributes
redirectAttributes,@RequestParam(value="roleId", required = false) List<Long> roleIds) { }

方法二:

前台form

<form action="/sysUser/create" method="post">
<input name="menuIds[0]" >
<input name="menuIds[1]" >
<input name="menuIds[2]" >
</form>

后台

@RequestMapping(value = "/create", method = RequestMethod.POST)  

    public String create(
@Valid SysRoleDto sysRoleDto, BindingResult bindingResult, final RedirectAttributes redirectAttributes) { }
public class SysRoleDto extends SysRolePojo {
@NotNull
private List<Long> menuIds; public SysRoleDto() {
}
public List<Long> getMenuIds() {
return menuIds;
} public void setMenuIds(List<Long> menuIds) {
this.menuIds = menuIds;
}
}

方法三

@ResponseBody
@RequestMapping(value = "/ajaxsortPriority")
public ResultDo ajaxsortPriority(@RequestParam("ids[]") Long[] ids) {
ResultDo resultDo=new ResultDo();
int size=cmsBannerService.sortPriority(ids);
if(size==ids.length){
resultDo.setSuccess(true);
}else{
resultDo.setSuccess(false);
}
return resultDo;
}

var param=[];
$("#tb_order").find("td[name='id']").each(function(){
param.push($(this).text());
})
var ids={ids:param};
$.ajax({
cache: true,
type: "GET",
url: "/cmsBanner/ajaxsortPriority",
dataType:"json",
data:ids,
async: false,
success: function (data) {

方法4

@RequestMapping(value = "/cfgRepayRemind", method = RequestMethod.POST)
@ResponseBody
public ResultDo<?> cfgRepayRemind(
@RequestBody List<SysDictPojo> sysDictPojos //@RequestBody 前台请求的数据格式必须为json ) {
ResultDo<?> resultDo = ResultDo.build();
try {
icProjectRepayService.cfgRepayRemind(sysDictPojos);
} catch (Exception e) {
resultDo.setSuccess(false);
} return resultDo;
}
function cfgRepayRemind(ele) {
var url = $(ele).attr("value");
var params = [];
$("#repayRemindMobile").find("ul").each(function () {
var id = $(this).find("input[name='id']").eq(0).val();
var value = $(this).find("input[name='value']").eq(0).val(); params.push({id: id, value: value});//id,value 为java bean里的属性,名字一致
}) $.ajax({
cache: true,
type: "POST",
url: url,
data: JSON.stringify(params),// 指定请求的数据格式为json,实际上传的是json字符串
contentType: 'application/json;charset=utf-8',//指定请求的数据格式为json,这样后台才能用@RequestBody 接受java bean
dataType: "json",
async: false,
success: function (data) {
if (data.success) {
toastr.success("操作成功");
setTimeout(function () {
location.reload();
}, 1000)
}
}
});
}
public class SysDictPojo extends AbstractBasePojo {
private Long id;
private String key;
private String value;
private String description; }

PS

场景一

$.ajax({
type:"post",
<span style="white-space:pre"> </span> data:{total:'100'},
dataType:'json', url:"http://127.0.0.1:8089/icProject/test",
success:function () { }
})
@RequestMapping(value = "/test", method = RequestMethod.POST)
@ResponseBody
public String test(@RequestParam("total") String total ) {
return null;
}

后台可以取到total=100,发现默认是以 application/x-www-form-urlencoded 格式提交请求数据的

场景二

function testpost1() {
$.ajax({
type:"post",
data:{total:'100',icProjectPojo:{totalAmount:10000}}, dataType:'json',
url:"http://127.0.0.1:8089/icProject/test",
success:function () { }
})
}

icProjectPojo[totalAmount]:
10000 是以这样的key-value 形式提交数据的 ,而不是json对象的方式
@RequestMapping(value = "/test", method = RequestMethod.POST)
@ResponseBody
public String test(HttpServletRequest request, @RequestParam("total") String total, IcProjectPojo icProjectPojo ) {
return null;
}

后台接收时,IcProjectPojo这个bean里的totalAmount明显是就收不到数据的,如果有一个属性叫 icProjectPojo[totalAmount] ,那他会接受到数据

所以传对象要用@RequestBody (方法里只有一个,即必须是一整个对象)和

data:JSON.stringify(params),//此处也不用给对象取key,因为后台的方法里@RequestBody 只允许注解一个对象

 contentType: "application/json",

不使用contentType: “application/json”则data可以是对象

使用contentType: “application/json”则data只能是json字符串

方法五:表单数据序列化,ajax提交

var params = $("#sysUserFrm").serialize();
var url = "/sysUser/settingSave"
$.ajax({
cache: true,
type: "POST",
url: url,
data: params,
dataType: "json",
async: false,
success: function (data) {}
})

@RequestMapping(value = "/settingSave", method = RequestMethod.POST)
@ResponseBody
public ResultDo<?> settingSave(SysUserPojo sysUserPojo) {}

这样sysUserPojo也能接收到Bean,其实这里的$("#sysUserFrm").serialize()  就相当于组装的  json对象 { }

ps:

var formData = new Object();
$("input").each(function () {
if ($(this).val() == "") {
return;
}
formData[$(this).attr("name")] = $(this).val();
});

总结:

get请求

一、url?key1=value1&key2=value2

二、form表单 (浏览器network里可看到实际上可是参数加url后面)

java:

<span style="color:#000000">@GetMapping("/logined")
public String logined(@RequestParam(value="userName",required = false) String userName,
EpSystemUserPo po,
MyUeerPo userPo) {//不采用@RequestBody入参可有多个,可与@RequestParam混用
//前台传来userName参数,后台的userName,po中的userName属性,userPo中的userName属性都会接收到值
return "index";
}</span>

js

<form   action="/backend/logined" method="GET" enctype="">
<div class="form-group">
<input name="userName" placeholder="用户名" >
</div>
<div class="form-group">
<input type="password" class="form-control" name="password" placeholder="密码" required="">
</div>
<button type="submit" >登 录</button>
</form>

发起请求后,后台未响应时(比如下了断点),因为get请求实际就是url后加参数故没有content-type这个参数

后台响应后,响应了会有status
code

post请求
一、form表单 (同get的区别在于content-type)

后台controller入参同样可以 @RequestParam(value="userName",required = false) String userName,

                          EpSystemUserPo po, 这样混用

后台未响应时

二、ajax的post方式提交请求

1.不用@RequestBody

后台java

@PostMapping("/logined")
public String logined(
@RequestParam(value="userName",required = false) String userName,
EpSystemUserPo po,
MyUeerPo userPo
) {//不采用@RequestBody入参可有多个,可与@RequestParam混用
//前台传来userName参数,后台的userName,po中的userName属性,userPo中的userName属性都会接收到值
return "login";
}

前台js

function logined() {
$.ajax({
type: "POST",
url: "/backend/logined",
data: $("#userFrm").serialize(),
success: function (data) {}
})
}

2.使用@RequestBody(实际上接受的是json的字符串)

@PostMapping("/logined")
public String logined(
// @RequestParam(value="userName",required = false) String userName,
@RequestBody EpSystemUserPo epSystemUserPo
// MyUeerPo userPo
) {//采用@RequestBody入参只有一个
return "login";
}
function logined() {
$.ajax({
type: "POST",
url: "/backend/logined",
data:JSON.stringify({userName:"cater",password:"123456"}) ,//转成字符串
contentType: "application/json;charset=utf-8",//不使用contentType: “application/json”则data可以是对象,使用contentType: “application/json”则data只能是json字符串
success: function (data) {}
})
}

这里使用时必须先组装json对象{username:"carter" },我的习惯是用 @RequestBody接受带List对象的对象或者List对象,因为js中有个push方法组list比较简单,二在页面上通过name="id[0]",这种方式很繁琐,而且动态化[]的索引很难搞

Springmvc后台接前台数组,集合,复杂对象的更多相关文章

  1. AJAX 向后台发送带 List 集合的对象

    现有基类: public class School { int name; int address; List<Student> students = new ArrayList<S ...

  2. SpringMVC后台接受前台传值的方法

    1.HttpRequestServlet 接收前台传值 @RequestMapping("/go5") public String hello5(HttpServletReques ...

  3. AJAX 向后台发送带 List 集合的对象(转)

    var school = {};school.name = '清华大学';school.address = "北京";//此处使用的是 easyui 插件来获取数据var rows ...

  4. springmvc后台接前端的参数,数组,集合,复杂对象等

    springmvc后台接前端的参数,数组,集合,复杂对象等 参考地址:https://blog.csdn.net/feicongcong/article/details/54705933  常用的几种 ...

  5. 分享知识-快乐自己:SpringMvc整合遇到-前台传JSON参数,后台实体类对象接收

    前台数据转JSON对象: /** * * @param $myFrom:from表单 * @returns {{}} */ function from($myFrom) { var ebookEntr ...

  6. spring MVC 如何接收前台传入的JSON对象数组并处理

    spring MVC 如何接收前台传入的JSON对象数组 主要方法: (主要用到的包是 net.sf.json  即:json-lib-2.3-jdk15.jar 完整相关jar包: commons- ...

  7. spring MVC 如何接收前台传入的JSON对象数组

    spring MVC 如何接收前台传入的JSON对象数组 主要方法: (主要用到的包是 net.sf.json  即:json-lib-2.3-jdk15.jar 完整相关jar包: commons- ...

  8. SpringMVC Get请求传集合,前端"异步"下载excel 附SpringMVC 后台接受集合

    最近项目上管理后台需要自己做一部分js部分,之前都是前端来弄...碰到了下载excel,刚开始使用ajax,搞了好久发现不合适..下载不了,网上说ajax返回类型不支持二进制流.. 因此采用 wind ...

  9. 【springMVC 后台跳转前台】1.使用ajax访问的后台,后台正常执行,返回数据,但是不能进入前台的ajax回调函数中 ----2.前后台都没有报错,不能进入ajax回调函数

    问题1: 使用ajax访问的后台,后台正常执行,并且正常返回数据,但是不能进入前台的ajax回调函数中 问题展示:  问题解决: 最后发现是因为后台的方法并未加注解:@ResponseBody,导致方 ...

随机推荐

  1. 警告(alert)、确认(confirm)

    我们在访问网站的时候,有时会突然弹出一个小窗口,上面写着一段提示信息文字.如果你不点击“确定”,就不能对网页做任何操作,这个小窗口就是使用alert实现的. 语法: alert(字符串或变量);注:a ...

  2. Oracle 性能之 Enq: CF - contention

    Oracle 性能之 Enq: CF - contention Table of Contents 1. 原因 2. 解决问题 2.1. 针对持有锁进程类型处理 2.1.1. 查看持有锁会话的进程类型 ...

  3. [Python]切换工作目录|python将目录切换为脚本所在目录

    Python使用os.chdir命令切换python工作目录 代码示例: In []: import os In []: os.system("pwd") /home/wangju ...

  4. MySQL 按照数据库表字段动态排序 查询列表信息

    MySQL 按照数据库表字段动态排序 查询列表信息 背景描述 项目中数据列表分页展示的时候,前端使用的Table组件,每列自带对当前页的数据进行升序或者降序的排序. 但是客户期望:随机点击某一列的时候 ...

  5. Oracle数据库提高sql查询效率总结

    我们要做到不但会写SQL,还要做到写出性能优良的SQL语句. (1)选择最有效率的表名顺序(只在基于规则的优化器中有效): Oracle的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句 ...

  6. 安装好oracle11gR2之后在相应路径下却没有生成tnsnames.ora和listener.ora

    oracle安装帖子:https://blog.csdn.net/wjb123sw99/article/details/80780277 oracle安装过程中检查失败:需开启C盘共享,或者勾选忽略, ...

  7. Android逆向——破解水果大战

    最近公司需要测试安卓app安全,但安卓基本上0基础,决定开始学习下安卓逆向根据吾爱破解上教程 <教我兄弟学Android逆向系列课程+附件导航帖> https://www.52pojie. ...

  8. 数据库中TOP—N查询

    1)查询1-4的数据 SELECT rownum, sno, cno, score FROM (SELECT * FROM sc order by score desc) WHERE rownum & ...

  9. 给Date的构造函数添加属性和方法

    let d = Date.prototype; Object.defineProperties(d, { 'year': { get: function () { return this.getFul ...

  10. 在phpStrom中安装php代码格式化插件Php-cs-fixer

    由于phpStrom原来的插件不再开源,现在转为使用Php-cs-fixer格式化代码.以下为在phpStrom中安装Php-cs-fixer的具体步骤. 安装安装很简单,下载php-cs-fixer ...