SpringMVC:前台jsp页面和后台传值

 

前台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>

 

转载于:https://www.cnblogs.com/mrxiaohe/p/5893708.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值