前台jsp页面和后台传值的几种方式:

                       不用SpringMVC自带的标签

前台---->后台,通过表单传递数据():

1.jsp页面代码如下,  modelattribute 有没有都行

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib prefix="sf" uri="http://www.springframework.org/tags/form"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
</head>
<body> <form method="post" enctype="multipart/form-data">
Username:<input type="text" name="username"/> <sf:errors path="username">
Password:<input type="password" name="password"/> <sf:errors path="password">
Nickname:<input type="text" name="nickname"/></br>
Email<input type="text" name="email"/> </form>
</body>
</html>

2.写Action,如下两种方式都可以:

  第一种,表单的name属性值必须和接受的参数同名。否则,接收到的参数为null,但不报错

  第二种,表单的name属性值必须和接收对象的属性同名。否则,接收到的参数为null,但不报错

@RequestMapping(value="/add",method=RequestMethod.POST)
public String userAdd(String username,String password,String nickname,String email){
User user = new User(username,password,nickname,email);
System.out.println(user.toString());
users.put(user.getNickname(), user);
//客户端跳转
return "redirect:/user/users";
}
@RequestMapping(value="/add",method=RequestMethod.POST)
public String userAdd(User user) {
System.out.println(user.toString());
users.put(user.getNickname(), user);
//客户端跳转
return "redirect:/user/users";
}

注意1:即使我们的Action使用第二种方式(选用User类对象作为参数),前台界面也不能写成user.username ,后台这样会接收失败,得到的值是null。这一点如果没记错的话,应该和Struts2是不一样的

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib prefix="sf" uri="http://www.springframework.org/tags/form"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
</head>
<body> <form method="post" enctype="multipart/form-data">
Username:<input type="text" name="user.username"/>
Password:<input type="password" name="user.password"/>
Nickname:<input type="text" name="user.nickname"/>
Email<input type="text" name="user.email"/>
<input type="submit" value="添加用户" /> </form>
</body>
</html>

注意2:我们的Action使用第二种方式(选用User类对象作为参数),我们可以在服务端使用@Validated注解来进行服务端验证。但是由于我们前台jsp页面没有使用SpringMVC自带的标签库,前台jsp页面无法显示错误信息,也就是<sf:errors path="username"></sf:errors> 不起作用(不报错)。

  ----如果只把<form></form>标签缓存<sf:form></sf:form>,并且添加modelAttribute="user"属性,不该其他内容,<sf:error>会起作用。但是我们不会这样做,没有任何意义,要用就统一用SpringMVC自带的标签库,要么就全部用,混着用容易出错。

后台---->前台  model.addAttribute("users",users):

后台Action代码

@RequestMapping(value={"/users","/",""},method=RequestMethod.GET)
public String userList(Model model){
//model.addAllAttributes(user);//key是map(类型名首字母小写)
model.addAttribute("users",users);
return "user/list";
}
@RequestMapping(value="/add",method=RequestMethod.GET)
public String userAdd(){
model.addAttribute("user", new User("newUser","newUserPwd","newUserNickname","newUser@126.com"));
return "user/add";
}

前台jap页面取值:使用jstl:<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>用户列表</title>
</head>
<body>
<a href="add" >添加</a>
<br/>
<c:forEach items="${users }" var="userMap">
${userMap.key }
<!-- 这里使用jstl取值,如果我们把User对象的字段,所对应的getter和setter方法去掉,页面会报错 -->
-----><a href="${userMap.value.username }">${userMap.value.username } </a>
----->${userMap.value.password }
----->${userMap.value.nickname }
----->${userMap.value.email }
-----><a href="${userMap.value.nickname }/update">修改用户</a>
-----><a href="${userMap.value.nickname }/delete">删除用户</a>
</br>
</c:forEach>
</body>
</html>

                        使用SpringMVC自带的标签

前台---->后台,通过表单传递数据():

前台jsp页面代码如下。

  1.需要添加一个taglib <%@taglib prefix="sf"  uri="http://www.springframework.org/tags/form"%>

  2.由于使用了SpringMVC自带的标签<sf:input path="username"/>,<sf:password path="password"/>,带有必须的path属性,所以必须要加上

  modelAttribute="user",否则会报错

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib prefix="sf" uri="http://www.springframework.org/tags/form"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
</head>
<body> <sf:form method="post" modelAttribute="user" enctype="multipart/form-data">
Username:<sf:input path="username"/> <sf:errors path="username"></sf:errors></br>
Password:<sf:password path="password"/> <sf:errors path="password"></sf:errors></br>
Nickname:<sf:input path="nickname"/></br>
Email:<sf:input path="email"/> <input type="submit" value="添加用户" /> </sf:form>
</body>
</html>

2.写Action,如下两种方式都可以:

  第一种,表单的path属性值必须和接受的参数同名。

  第二种,表单的path属性值必须和接收对象的属性同名,并且modelAttribute="user"的属性值,必须为Action参数的类型名小写,即User变user。

public String userAdd(String username,String password,String nickname,String email) {
User user = new User(username,password,nickname,email);
System.out.println(user.toString()); users.put(usera.getNickname(), user);
//客户端跳转
return "redirect:/user/users";
}
public String userAdd(User user) {
System.out.println(user.toString());
users.put(user.getNickname(), user);
//客户端跳转
return "redirect:/user/users";
}

  如果我们的Action使用第二种方式(选用User类对象作为参数),我们可以在服务端使用@Validated注解来进行服务端验证。那么前台jsp页面是能够通过<sf:error>来获取错误信息的。想下面的代码,如果我们填写的User信息有错误,那么我们就会返回到刚才填写信息的add页面,并且还会显示错误信息。

    @RequestMapping(value="/add",method=RequestMethod.POST)
public String userAdd(@Validated User user,BindingResult br,MultipartFile attach,HttpServletRequest re) throws IOException{//一定要紧跟validate写,验证结果类,中间如果有其他参数,就会报错
System.out.println(user.toString());
     //如果有错误,返回添加用户信息的页面。这里不用Model model和model.addAttribute()为什么不报错呢
if(br.hasErrors()){
return "user/add";
} users.put(user.getNickname(), user);
//客户端跳转
return "redirect:/user/users";
}

后台---->前台,传递数据:

后台Action,使用model.addAttribute():

注意:这里有一点需要强调一下,如果我们不适用SpringMVC自带的标签,那么如果我们不想往前台jsp页面传数据,那么我们可以不用添加Action的参数Model model 和 model.addAttribute()。但是如果使用SpringMVC自带的标签,我们必须要向前台页面传送数据,即使传一个空值,也要传,否则报错。

@RequestMapping(value="/add",method=RequestMethod.GET)
public String userAdd(Model model){
//public String userAdd(@ModelAttribute("user")User user){
//model.addAttribute(new User());
model.addAttribute("user", new User("newUser","newUserPwd","newUserNickname","newUser@126.com"));
return "user/add";
}

前台jsp页面取值方式

1.这里我们也可以使用jstl表达式,来获取传到前台jsp页面的值,和不适用SpringMVC自带标签是一样的,就不详述了。

2.但是,我们也可以不使用jstl这种方式来获取值。由于前台jsp页面中,是有SpringMVC自带标签的,<sf:input path="username"/>,<sf:password path="password"/>,这里就会直接把值赋给这个标签。

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib prefix="sf" uri="http://www.springframework.org/tags/form"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
</head>
<body>
<!-- 使用jstl取值 -->
${user.username }
<sf:form method="post" modelAttribute="user" enctype="multipart/form-data"> <!-- 也可以直接把值,自动放到标签里面显示,不需要人工操作 -->
Username:<sf:input path="username"/> <sf:errors path="username"></sf:errors></br>
Password:<sf:password path="password"/> <sf:errors path="password"></sf:errors></br>
Nickname:<sf:input path="nickname"/></br>
Email<sf:input path="email"/> <input type="submit" value="添加用户" /> </sf:form>
</body>
</html>

注意:很重要的一点,如果前台使用了SpringMVC自带的标签,我们用GET请求“添加页面”的时候,即使我们后端没有要传给前台jsp页面数据,我们的Action也必须要有Model model参数,并且函数体中,也必须要添加一个空,model.addAttribute(new User());,否则会报错。也就是说,如果选择了SpringMVC自带的标签:

1.负责GET请求的Action必须 要有Model model参数,并且函数体中,也必须要添加一个空,model.addAttribute(new User());

2.前台jsp页面 <sf:form>表单 一定要有modelAttribute="user"

3.如果在POST请求中,用了@validated,如果页面出错,我们还是会返回“添加页面”,但是奇怪的是为什么此时我不加Model model参数,和model.addAttribute(new User());是不会报错的呢?个人认为,系统为自动给你加的。当然如果报错了之后,你想自己传一些特殊的值给前台jsp页面,那么就需要用到。

。java.lang.IllegalStateException: Neither BindingResult nor plain target object for bean name 'command' available as request attribute  ,

如果我们要使用@Validate进行验证,并且需要在前台通过<sf:error></sf:error>来显示错误信息,那么我们一定要用<sf:form></sf:form>,并且设置modelAttribute="user",它的属性值,必须为小写的类型名 ,表单中的其他标签是否使用<sf:>都可以。

 

此时前台接收的方式

  1.可以使用el表达式,${userMap.value.username }

  2.如果我们想让传过来的值直接放到某个控件上(不使用js),我们可以使用SpringMVC自己带的标签(需要设置taglib)

   比如下面的<sf:input path="username"/>,path属性是必须要设置的。modelAttribute="user"也是必须要设置的。而且如果使用了这种方式,那么后台

  代码必须要有Model model,并且model需要add一个东西

  我们这样理解这个东西,由于<sf:input path="">的path属性是必须的,所以这个属性对应着对象的某一个字段,而对象是什么呢,就需要modelAttribute="user",来确定。这也就说明,只要使用<sf:>,就必须要有modelAttribute=""的原因了。而且后台一定要传东西过来,如果没有

model.addAttribute(),那么<sf:>标签就获取不到对应的值,就会报错

<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@taglib prefix="sf" uri="http://www.springframework.org/tags/form"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
</head>
<body> <sf:form method="post" modelAttribute="user" enctype="multipart/form-data">
Username:<sf:input path="username"/> <sf:errors path="username"></sf:errors></br>
Password:<sf:password path="password"/> <sf:errors path="password"></sf:errors></br>
Nickname:<sf:input path="nickname"/></br>
Email<input type="text" name="email"/> <input type="submit" value="添加用户" /> </sf:form>
</body>
</html>

SpringMVC:前台jsp页面和后台传值的更多相关文章

  1. jsp页面向后台传值出现乱码的问题

    1.采用decode()方法 页面: Url: '<%=path%>/sfyh/infodata.jsp?type='+encodeURI(ss) , 后台: String result  ...

  2. 【数据库_Mysql】JAVA-数据库Date格式在前台JSP页面的获取

    问题: 数据库保存的为date格式的日期 在前台JSP页面显示的为一串数字1487897     解决办法: 数据库表中字段对应的实体对象属性的get方法上添加一行代码 页面即可正常显示      

  3. java分页的实现(后台工具类和前台jsp页面)

    1.首先,新建一个类Page.java public class Page implements Serializable { private static final long serialVers ...

  4. springMVC之一(页面<--->控制器 互相传值,转发和重定向)

    #页面--->控制器1.request:不建议使用2.使用属性传值(建议使用)@RequestParam("name") String username3.使用Bean对象传 ...

  5. jsp页面间的传值

    很多的时候我们只是把我们需要的数据,查询出来,然后用request.setAttribute("" ,"" )方法保存这个数据集合.再在我们能跳转到的下一个js ...

  6. 从jsp页面到servlet传值的不同方式

    1.利用超链接<a></a>来传递参数 例如: <td><a href="/month811/Servlet?id=${student.id}&am ...

  7. JSP页面间的传值方法总结

    JSP 页面间传递参数是项目中经常需要的,这应该算是 web 基本功吧.试着将各种方式总结下来,需要时可以进行权衡利弊选择最合适的方式.下面来一起看看详细的介绍: 1. URL 链接后追加参数 ? 1 ...

  8. jsp页面获取后台传过来的list集合的长度

    在jsp页面导入函数标签库: <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"% ...

  9. springMVC在JSP页面取map值

    在springmMVC中.jsp页面取得map值. 在controller层: Map<String, Object> map = new HashMap<String, Objec ...

随机推荐

  1. 【bzoj1336/1337/2823】[Balkan2002]Alien最小圆覆盖 随机增量法

    题目描述 给出N个点,让你画一个最小的包含所有点的圆. 输入 先给出点的个数N,2<=N<=100000,再给出坐标Xi,Yi.(-10000.0<=xi,yi<=10000. ...

  2. Start state is missing. Add at least one state to the flow

    springmvc配置过程中,会配置数据库文件,比如说如下文件:这个时候可能会出现“Start state is missing. Add at least one state to the flow ...

  3. 如何通过IP地址分辨公网、私网、内网、外网

    如何通过IP地址分辨公网.私网.内网.外网   内.外网是相对于防火墙而言的,在防火墙内部叫做内网,反之就是外网.   在一定程度上外网等同于公网,内网等同于私网.   地址为如下3个区域就是处于私网 ...

  4. Codeforces Round #363 (Div. 2) C dp或贪心 两种方法

    Description Vasya has n days of vacations! So he decided to improve his IT skills and do sport. Vasy ...

  5. Cookies设置,获取,删除

    之前的博客,整理了下Session的存储方式和原理http://www.cnblogs.com/chinaagan/p/3200456.html. 本篇再次整理下Cookies的使用和原理. 参考博客 ...

  6. [bzoj 1782] [Usaco2010 Feb]slowdown慢慢游

    [bzoj 1782] [Usaco2010 Feb]slowdown慢慢游 Description 每天Farmer John的N头奶牛(1 <= N <= 100000,编号1-N)从 ...

  7. SQLite-FMDatabase用法

    FMDatabase用法 转载 http://blog.sina.com.cn/s/blog_94d94f1a01015gcr.html 以下是FMDB的一些基本使用,FMDB框架其实只是一层很薄的封 ...

  8. EF4.2预览版出来了

    原文发布时间为:2011-09-21 -- 来源于本人的百度文章 [由搬家工具导入] http://blogs.msdn.com/b/adonet/archive/2011/08/22/ef-4-2- ...

  9. Html.AntiForgeryToken 防止伪造提交

    原文发布时间为:2011-05-03 -- 来源于本人的百度文章 [由搬家工具导入] In this tutorial, I am not going to discuss the concept i ...

  10. 《Linux命令行与shell脚本编程大全 第3版》Linux命令行---24

    以下为阅读<Linux命令行与shell脚本编程大全 第3版>的读书笔记,为了方便记录,特地与书的内容保持同步,特意做成一节一次随笔,特记录如下: