@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)







 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章