@ModelAttribute运用详解

@ModelAttribute运用详解-布布扣-bubuko.com
<div class="divdaohang">
    <div class="divtitlefont">
        <a href="/info.html" title="文章首页">首页</a>
        <span id="lbltitle"> > <a href='/infolist-11-1.html'>其他</a> > 详细</span>
    </div>
</div>

<div class="divmain">
    <div class="width70bi divfloatleft">
        <div class="marginright20">
            <div>
<div class="divfloatleft">
    <script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
    <!-- bubuko-infodetail-336x280-1 -->
    <ins class="adsbygoogle" style="display: inline-block; width: 336px; height: 280px"
        data-ad-client="ca-pub-8616102841876629" data-ad-slot="8276669881"></ins>
    <script>
        (adsbygoogle = window.adsbygoogle || []).push({});
    </script>
</div>
<div class="divfloatright">
    <script type="text/javascript">
        /*bu-336x280-1*/
        var cpro_id = "u2910309";
    </script>
    <script type="text/javascript" src="http://cpro.baidustatic.com/cpro/ui/c.js"></script>
</div>
<div class="divfloatclear">
</div>

            <div class="detailtitle divtextaligncenter divborderbottomdotted">
                <h1 id="Htitle" class="detailtitle">@ModelAttribute运用详解</h1>
            </div>
            <div class="detail1 divtextaligncenter">
                时间:<span id="Label2" class="colorlv">2015-03-02 12:39:09</span>
                &nbsp;&nbsp;&nbsp;&nbsp; 阅读:<span id="Label1" class="colorCheng">12659</span>
                &nbsp;&nbsp;&nbsp;&nbsp; 评论:<span id="lblcommentcount" class="colorCheng">0</span>
                &nbsp;&nbsp;&nbsp;&nbsp; 收藏:<span id="lblfavorite" class="colorCheng">0</span>
                &nbsp;&nbsp;&nbsp;&nbsp; <a id="infofavorite" class="acursorpointer">[点我收藏+]</a>
            </div>

            <div class="detailcontennt">
                <span id="Label3"><p>标签:<a href='http://www.bubuko.com/so/1/class' title='class'>class</a>&nbsp;&nbsp;&nbsp;<a href='http://www.bubuko.com/so/1/style' title='style'>style</a>&nbsp;&nbsp;&nbsp;<a href='http://www.bubuko.com/so/1/%e4%bb%a3%e7%a0%81' title='代码'>代码</a>&nbsp;&nbsp;&nbsp;<a href='http://www.bubuko.com/so/1/com' title='com'>com</a>&nbsp;&nbsp;&nbsp;<a href='http://www.bubuko.com/so/1/log' title='log'>log</a>&nbsp;&nbsp;&nbsp;<a href='http://www.bubuko.com/so/1/%e4%bd%bf%e7%94%a8' title='使用'>使用</a>&nbsp;&nbsp;&nbsp;<a href='http://www.bubuko.com/so/1/java' title='java'>java</a>&nbsp;&nbsp;&nbsp;<a href='http://www.bubuko.com/so/1/html' title='html'>html</a>&nbsp;&nbsp;&nbsp;<a href='http://www.bubuko.com/so/1/http' title='http'>http</a>&nbsp;&nbsp;&nbsp;</p><p><a class="__cf_email__" href="/cdn-cgi/l/email-protection" data-cfemail="b75f151cf7fad8d3d2dbf6c3c3c5ded5c2c3d251041f5e303d502d3351210e510422530b2d522b1f511a13d4d8d9c3c5d8dbdbd2c5511838530f1d51210e51042251">[email&#160;protected]</a><script data-cfhash='f9e31' type="text/javascript">/* <![CDATA[ */!function(t,e,r,n,c,a,p){try{t=document.currentScript||function(){for(t=document.getElementsByTagName('script'),e=t.length;e--;)if(t[e].getAttribute('data-cfhash'))return t[e]}();if(t&&(c=t.previousSibling)){p=t.parentNode;if(a=c.getAttribute('data-cfemail')){for(e='',r='0x'+a.substr(0,2)|0,n=2;a.length-n;n+=2)e+='%'+('0'+('0x'+a.substr(n,2)^r).toString(16)).slice(-2);p.replaceChild(document.createTextNode(decodeURIComponent(e)),c)}p.removeChild(t)}}catch(u){}}()/* ]]> */</script>��行前被执行,因此对于一个controller映射多个URL的用法来说,要谨慎使用。</p>  <p>我们编写控制器代码时,会将保存方法独立成一个控制器也是如此。</p>  <p>&#160;</p>  <p><a href="/cdn-cgi/l/email-protection#21100f616c4e45444d605555534843545544">1.@ModelAttribute</a>注释void返回值的方法</p>  <div class="cnblogs_code" style="border-top: #cccccc 1px solid; border-right: #cccccc 1px solid; border-bottom: #cccccc 1px solid; padding-bottom: 5px; padding-top: 5px; padding-left: 5px; border-left: #cccccc 1px solid; padding-right: 5px; background-color: #f5f5f5">   <pre><span style="color: #000000">@Controller

public class HelloModelController {

@ModelAttribute 
</span><span style="color: #0000ff">public</span> <span style="color: #0000ff">void</span><span style="color: #000000"> populateModel(@RequestParam String abc, Model model) {  
   model.addAttribute(</span>&quot;attributeName&quot;<span style="color: #000000">, abc);  
}  

@RequestMapping(value </span>= &quot;/helloWorld&quot;<span style="color: #000000">)  
</span><span style="color: #0000ff">public</span><span style="color: #000000"> String helloWorld() {  
   </span><span style="color: #0000ff">return</span> &quot;helloWorld.jsp&quot;<span style="color: #000000">;  
}  

}

在这个代码中,访问控制器方法helloWorld时,会首先调用populateModel方法,将页面参数abc(/helloWorld.ht?abc=text)放到model的attributeName属性中,在视图中可以直接访问。

jsp页面页面如下。

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<html>
<head>
</head>
<body>
<c:out value="${attributeName}"></c:out>
</body>
</html>

 

2.@ModelAttribute注释返回具体类的方法

@Controller
public class Hello2ModelController {

    @ModelAttribute 
    public User populateModel() {  
       User user=new User();
       user.setAccount("ray");
       return user;
    }  
    @RequestMapping(value = "/helloWorld2")  
    public String helloWorld() {  
       return "helloWorld.jsp";  
    }  
}

当用户请求 http://localhost:8080/test/helloWorld2.ht时,首先访问populateModel方法,返回User对象,model属性的名称没有指定,

它由返回类型隐含表示,如这个方法返回User类型,那么这个model属性的名称是user。
这个例子中model属性名称有返回对象类型隐含表示,model属性对象就是方法的返回值。它无须要特定的参数。

jsp 中如下访问:

<c:out value="${user.account}"></c:out>

也可以指定属性名称

@Controller
public class Hello2ModelController {

    @ModelAttribute(value="myUser")
    public User populateModel() {  
       User user=new User();
       user.setAccount("ray");
       return user;
    }  
    @RequestMapping(value = "/helloWorld2")  
    public String helloWorld(Model map) {  
       return "helloWorld.jsp";  
    }  
}

jsp中如下访问:

<c:out value="${myUser.account}"></c:out>

 

对象合并:

@Controller
public class Hello2ModelController {

    @ModelAttribute
    public User populateModel() {  
       User user=new User();
       user.setAccount("ray");
       return user;
    }  

    @RequestMapping(value = "/helloWorld2")  
    public String helloWorld(User user) {
        user.setName("老王");
       return "helloWorld.jsp";  
    }  
}

这个在编写代码的时候很有用处,比如在更新的时候,我们可以现在populateModel方法中根据ID获取对象,然后使用spring mvc的自动组装功能,组装

User对象,这样在客户端提交了值的属性才会被组装到对象中。

比如:User对象,首先从数据库中获取此对象,客户端表单只有account属性,提交时就只会改变account属性。

 

对象合并指定对象名称:

@Controller
public class Hello2ModelController {

    @ModelAttribute("myUser")
    public User populateModel() {  
       User user=new User();
       user.setAccount("ray");
       return user;
    }  

    @RequestMapping(value = "/helloWorld2")  
    public String helloWorld(@ModelAttribute("myUser") User user) {
        user.setName("老王");
       return "helloWorld.jsp";  
    }  
}

这样在jsp中可以使用如下方式访问

<c:out value="${myUser.name}"></c:out>
<c:out value="${myUser.account}"></c:out>

 

3.通过此特性控制权限.

我们可以在基类方法中控制写此注解,需要控制权限的控制器,继承控制器就可以了。

public class BaseController {

    @ModelAttribute
    public void populateModel() throws Exception {  
       SysUser user=ContextUtil.getCurrentUser();
       if(user.getAccount().equals("admin")){
           throw new Exception("没有权限");
       }
    }  
}

需要控制权限的类继承BaseController

@Controller
public class Hello2ModelController extends BaseController {

    @RequestMapping(value = "/helloWorld2")  
    public String helloWorld(@ModelAttribute("myUser") User user) {
        user.setName("老王");
       return "helloWorld.jsp";  
    }  
}

这样就可以控制权限了,当然控制权限的方法有很多,比如通过过滤器等。这里只是提供一种思路。

@ModelAttribute运用详解

标签:http://www.bubuko.com/so/1/class’ title=’class’>class   http://www.bubuko.com/so/1/style’ title=’style’>style   http://www.bubuko.com/so/1/%e4%bb%a3%e7%a0%81’ title=’代码’>代码   http://www.bubuko.com/so/1/com’ title=’com’>com   http://www.bubuko.com/so/1/log’ title=’log’>log   http://www.bubuko.com/so/1/%e4%bd%bf%e7%94%a8’ title=’使用’>使用   http://www.bubuko.com/so/1/java’ title=’java’>java   http://www.bubuko.com/so/1/html’ title=’html’>html   http://www.bubuko.com/so/1/http’ title=’http’>http   

原文:http://www.cnblogs.com/yg_zhang/p/4308271.html










( 2)






( 6)







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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值