JAVA springmvc参数
一、简单参数:
package jd.com.contronller; import jd.com.projo.goods;
import org.springframework.stereotype.Controller;
import jd.com.service.goodsService ;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping; import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.util.List; @Controller
public class goodsController {
@Resource(name="goodsServiceImpl")
private goodsService goodsService; @RequestMapping("/items")
public String findAll(HttpServletRequest request, HttpServletResponse response, HttpSession session, Model model){
List<goods> list=this.goodsService.findAllGoods();
model.addAttribute("items",list);
return "items"; }
}
其中:public String findAll(HttpServletRequest request, HttpServletResponse response, HttpSession session, Model model)controller类中的方法,自动重载,其中参数HttpServletRequest request, HttpServletResponse response, HttpSession session, Model model根据实际情况进行加减。
当方法返回的是字符串的时候,返回值是页面的名称。其中Modle我们定义在其中定义数据。
springmvc可以自动接收一些简单的参数比如基本类型参数加上String。
controller类:
@RequestMapping("/update")
public String updateByid(String goodsname, String detail, Integer id, Integer money){
System.out.println(goodsname+detail+id+money);
goods goods =new goods();
goods.setDetail(detail);
goods.setGoodsname(goodsname);
goods.setId(id);
goods.setMoney(money);
this.goodsService.updateById(goods);
return "success";
}
需要前端传递过来的参数的key和我们上面的方法的参数的名称需要保持一致。
因为传递传递过来的参数都是字符串类型,我们可以直接在方法中修改我们想接收的参数类型,springmvc帮我们自动转换类型。比如上 面的例子中id,就是spring帮我们转换的。
上面的方法有点麻烦如果前端传递过来很多参数的话 我们需要一一set这些值。spring为我们提供projo类的方法。
二、projo类的参数传递
条件:
传递过来的参数需要key和projo类的属性一一对应。否则接收不到。
我们使用projo类goods来替换我们上面的简单类型的参数
@RequestMapping("/update")
public String upddateById(goods goods){
this.goodsService.updateById(goods);
return "success";
}
解决post中文乱码:
在web.xml加入 :
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>utf-</param-value>
</init-param>
</filter>
三、vo参数类型
前端传递过来的参数有可能是多个表的字段,所以我们projo类不可能是都满足需求。这时候需要几个projo类组成我们需要的实体类。
需要注意前端页面需要写属性.属性 这样才能对应上vo类中引用其他的类的数据

vo类:
package jd.com.vo;
import jd.com.projo.goods;
import java.util.Date;
public class vo {
private goods goods;
public jd.com.projo.goods getGoods() {
return goods;
}
public void setGoods(jd.com.projo.goods goods) {
this.goods = goods;
}
}
controller类:
@RequestMapping("/vo")
public String searchBydateAndNmae(vo vo){
goods goods =this.goodsService.findByTime(vo);
System.out.println(goods.getMoney());
return null;
}
前端页面:需要注意前端页面想显示日期格式需要使用<fmt:formatDate value="${n.create_time}" pattern="yyyy-MM-dd HH:mm:ss" />
<%--
Created by IntelliJ IDEA.
User: liumeide
Date: //
Time: :
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" pageEncoding="utf-8" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<html>
<head>
<title>Title</title>
<script type="text/javascript" src="<c:url value='/resources/bootstrap.min.js'/>"></script>
<link rel="stylesheet" type="text/css" href="<c:url value='/resources/bootstrap.min.css'/>"/>
</head>
<body style="text-align: center">
<div class="col-md-5" style="text-align: center">
<h1> 商品详情</h1>
<table class="table table-bordered table-responsive">
<tbody>
<form method="post" action="/vo.action">
<tr>
<td>查询条件</td>
<td>商品日期</td>
<td><input type="text" name="goods.goodsname" value="${items[0].goodsname}"></td>
<td>商品名称</td>
<td><input type="text" name="goods.create_time" value="<fmt:formatDate value="${items[].create_time}" pattern="yyyy-MM-dd HH:mm:ss" /> "></td>
<td><input type="submit"></td>
</tr>
</form> <c:forEach items="${items}" var="n">
<tr>
<td>${n.id}</td>
<td>${n.goodsname}</td>
<td>${n.money}</td>
<td>${n.detail}</td>
<td><fmt:formatDate value="${n.create_time}" pattern="yyyy-MM-dd HH:mm:ss" /> </td>
<td><a href="/edit.action?id=${n.id}">修改</a></td>
</tr>
</c:forEach>
</tbody> </table>
</div> </body>
</html>
四、参数类型为数组
解决方法:
1、使用vo类中的设置属性,比如:private Integer[] ids;使用该字段接收数组。
比如批量删除根据id值。通过vo类来接收删除的id数组。前端页面需要将name改成ids。
package jd.com.vo;
import jd.com.projo.goods;
import java.util.Date;
public class vo {
private Integer[] ids;
private goods goods;
public jd.com.projo.goods getGoods() {
return goods;
}
public void setGoods(jd.com.projo.goods goods) {
this.goods = goods;
}
public Integer[] getIds() {
return ids;
}
public void setIds(Integer[] ids) {
this.ids = ids;
}
}
2、可以用Integer[] ids 进行接收。
controller类:
@RequestMapping("/deleteids")
public String deleteByIds(Integer[] ids){
System.out.println(Arrays.toString(ids));
return "";
}
@RequestMapping("/deleteids")
public String deleteByIds(vo vo){
System.out.println(Arrays.toString(vo.getIds()));
return "";
}
五、接收参数为List<E>
一般我们进行更新或者批量更新的时候,需要使用泛型来进行处理。
在vo类中添加属性:private List<goods> goodsList;
private List<goods> goodsList;
前端页面:name属性为后端定义属性.下标.属性名字
<c:forEach items="${items}" var="n" varStatus="status">
<tr>
<td><input type="checkbox"></td>
<td><input type="text" name="ids" hidden="hidden" value="${n.id}"></td>
<td><input type="text" name="goodsList[${status.index}].goodsname" id="" value="${n.goodsname}"></td>
<td><input type="text" value="${n.money}" name="goodsList[${status.index}].money" ></td>
<td><input type="text" value="${n.detail}" name="goodsList[${status.index}].detail" ></td>
<td><input type="text" disabled="disabled" value="<fmt:formatDate value="${n.create_time}" pattern="yyyy-MM-dd HH:mm:ss" />" name="goodList[status.index].create_time" ></td>
<td><a href="/edit.action?id=${n.id}">修改</a></td>
</tr>
</c:forEach>
通过foreach标签的varStatus属性。来确定在后端接收参数goodList的位置。
controller类:
@RequestMapping("/updateObjs")
public String updateObjs(vo vo){
System.out.println(vo.getGoodsList().get().getGoodsname());
return null;
}
JAVA springmvc参数的更多相关文章
- spring参数类型异常输出(二), SpringMvc参数类型转换错误输出(二)
spring参数类型异常输出(二), SpringMvc参数类型转换错误输出(二) >>>>>>>>>>>>>>&g ...
- spring参数类型异常输出,SpringMvc参数类型转换错误输出
spring参数类型异常输出, SpringMvc参数类型转换错误输出 >>>>>>>>>>>>>>>> ...
- 一篇文章搞定SpringMVC参数绑定
SpringMVC参数绑定,简单来说就是将客户端请求的key/value数据绑定到controller方法的形参上,然后就可以在controller中使用该参数了 下面通过5个常用的注解演示下如何进行 ...
- [Java] SpringMVC工作原理之一:DispatcherServlet
一.DispatcherServlet 处理流程 在整个 Spring MVC 框架中,DispatcherServlet 处于核心位置,它负责协调和组织不同组件完成请求处理并返回响应工作.在看 Di ...
- [转载]SpringBoot系列: SpringMVC 参数绑定注解解析
本文转载自 https://www.cnblogs.com/morethink/p/8028664.html, 作者写得非常好, 致谢! SpringMVC 参数绑定注解解析 本文介绍了用于参数绑 ...
- SpringMVC参数绑定,这篇就够了!
SpringMVC参数绑定,简单来说就是将客户端请求的key/value数据绑定到controller方法的形参上,然后就可以在controller中使用该参数了 下面通过5个常用的注解演示下如何进行 ...
- springmvc 参数解析绑定原理
handlerMethodArgumentResolver:方法参数解析器接口,这个接口是springmvc参数解析绑定的核心接口.不同的参数类型绑定都是通过实行这个接口来实现.也可以通过实现这个接口 ...
- SpringMVC参数绑定(未完待续)
1. Strut2与SpringMVC接收请求参数的区别 Struts2通过action类的成员变量接收SpringMVC通过controller方法的形参接收 2. SpringMVC参数绑定流程 ...
- java函数参数默认值
java函数参数默认值 今天,需要设定java函数参数的默认值,发现按照其它语言中的方法行不通 java中似乎只能通过函数的重载来实现 函数参数默认代码
随机推荐
- 几个常用T_SQL语句比较
UNION ALL VS UNION : union all 对两个结果进行并集操作,包括重复行,即所有的结果全部显示,不管是不是重复:union 对两个结果集进行并集操作,不包括重复行,相当于 di ...
- Jquery动态设置下拉框selected --(2018 08/12-08/26周总结)
1.Jquery动态根据内容设置下拉框selected 需求就是根据下拉框的值动态的设置为selected,本以为很简单,网上一大推的方法,挨着尝试了之后却发现没有一个是有用的.网上的做法如下: &l ...
- Python 进阶必备函数
1. lambda 表达式 匿名函数(英语:anonymous function)是指一类无需定义标识符(函数名)的函数.通俗来说呢,就是它可以让我们的函数,可以不需要函数名. 正常情况下,我们定义一 ...
- python正则表达式贪婪与非贪婪模式
之前做程序的时候看到过正则表达式的贪婪与非贪婪模式,今天用的时候就想不起来了,现在这里总结一下,以备自己以后用到注意. 1.什么是正则表达式的贪婪与非贪婪匹配 如:String str="a ...
- python学习笔记之——操作mysql数据库
Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口. Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: ...
- 对WebSocket技术的学习与探索(二)
近日重新开始学习WebSocket技术,什么是WebSocket,在<对WebSocket技术的学习与探索(一)>文章中已经说明白了,还没理解可以看看这篇文章http://www.ruan ...
- centos安装pip3
安装pip3 1:安装依赖 yum install openssl-devel -y yum install zlib-devel -y 2:安装setuptools wget --no-check- ...
- windows 远程连接
* 方法1:windows自带的远程工具 缺点:如果操作系统是家庭版,会一致连接不上:尽管想办法把这个功能打开: 步骤: * 打开允许远程连接: 点进去自己设置就行,没有什么好说的 设置完之后,需要允 ...
- Oracle 数据库 简单查询
select DISTINCT dept_id from s_emp; desc s_emp; ; --给入职3年以上员工发10万元年终奖 ; --列出职位是仓库管理员的名字和工资 select la ...
- MySQL出现Waiting for table metadata lock的场景浅析
MySQL版本为5.6.12. 在进行alter table操作时,有时会出现Waiting for table metadata lock的等待场景.而且,一旦alter table TableA的 ...