首页 > 学院 > 开发设计 > 正文

@ModelAttribute运用详解

2019-11-06 06:49:01
字体:
来源:转载
供稿:网友
@ModelAttribute运用详解-布布扣-bubuko.com [首页] [新闻] [文章] 布布扣,bubuko.com   首页 Web开发 Windows开发 编程语言 数据库技术 移动平台 系统服务 微信 设计 布布扣 其他 数据分析   <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注释返回具体类的方法

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

也可以指定属性名称

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

 

对象合并:

@Controllerpublic 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属性。

 

对象合并指定对象名称:

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

@Controllerpublic 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)  
上一篇:15正则表达式()

下一篇:ubuntu更新源

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表