麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

SpringMVC 的配置

2019-11-14 22:36:22
字體:
供稿:網(wǎng)友
SPRingMVC 的配置

轉(zhuǎn)發(fā)自http://www.companysz.com/superjt/p/3309255.html

現(xiàn)在主流的Web MVC框架除了Struts這個(gè)主力 外,其次就是Spring MVC了,因此這也是作為一名程序員需要掌握的主流框架,框架選擇多了,應(yīng)對(duì)多變的需求和業(yè)務(wù)時(shí),可實(shí)行的方案自然就多了。不過要想靈活運(yùn)用Spring MVC來應(yīng)對(duì)大多數(shù)的Web開發(fā),就必須要掌握它的配置及原理。

  一、Spring MVC環(huán)境搭建:(Spring 2.5.6 + Hibernate 3.2.0)

  1. jar包引入

  Spring 2.5.6:spring.jar、spring-webmvc.jar、commons-logging.jar、cglib-nodep-2.1_3.jar

  Hibernate 3.6.8:hibernate3.jar、hibernate-jpa-2.0-api-1.0.1.Final.jar、antlr-2.7.6.jar、commons-collections-3.1、dom4j-1.6.1.jar、javassist-3.12.0.GA.jar、jta-1.1.jar、slf4j-api-1.6.1.jar、slf4j-nop-1.6.4.jar、相應(yīng)數(shù)據(jù)庫的驅(qū)動(dòng)jar包

SpringMVC是一個(gè)基于DispatcherServlet的MVC框架,每一個(gè)請(qǐng)求最先訪問的都是DispatcherServlet,DispatcherServlet負(fù)責(zé)轉(zhuǎn)發(fā)每一個(gè)Request請(qǐng)求給相應(yīng)的Handler,Handler處理以后再返回相應(yīng)的視圖(View)和模型(Model),返回的視圖和模型都可以不指定,即可以只返回Model或只返回View或都不返回。

DispatcherServlet是繼承自HttpServlet的,既然SpringMVC是基于DispatcherServlet的,那么我們先來配置一下DispatcherServlet,好讓它能夠管理我們希望它管理的內(nèi)容。HttpServlet是在web.xml文件中聲明的。

<!-- Spring MVC配置 --><!-- ====================================== --><servlet>    <servlet-name>spring</servlet-name>    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>    <!-- 可以自定義servlet.xml配置文件的位置和名稱,默認(rèn)為WEB-INF目錄下,名稱為[<servlet-name>]-servlet.xml,如spring-servlet.xml    <init-param>        <param-name>contextConfigLocation</param-name>        <param-value>/WEB-INF/spring-servlet.xml</param-value>    </init-param>    -->    <load-on-startup>1</load-on-startup></servlet><servlet-mapping>    <servlet-name>spring</servlet-name>    <url-pattern>*.do</url-pattern></servlet-mapping><!-- Spring配置 --><!-- ====================================== --><listener>   <listenerclass>     org.springframework.web.context.ContextLoaderListener   </listener-class></listener><!-- 指定Spring Bean的配置文件所在目錄。默認(rèn)配置在WEB-INF目錄下 --><context-param>    <param-name>contextConfigLocation</param-name>    <param-value>classpath:config/applicationContext.xml</param-value></context-param>

spring-servlet.xml配置

  spring-servlet這個(gè)名字是因?yàn)樯厦鎤eb.xml中<servlet-name>標(biāo)簽配的值為spring(<servlet-name>spring</servlet-name>),再加上“-servlet”后綴而形成的spring-servlet.xml文件名,如果改為springMVC,對(duì)應(yīng)的文件名則為springMVC-servlet.xml。

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"             xmlns:context="http://www.springframework.org/schema/context"        xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd          http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd          http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd          http://www.springframework.org/schema/context <a >    <!-- 啟用spring mvc 注解 -->    <context:annotation-config />    <!-- 設(shè)置使用注解的類所在的jar包 -->    <context:component-scan base-package="controller"></context:component-scan>    <!-- 完成請(qǐng)求和注解POJO的映射 -->    <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />      <!-- 對(duì)轉(zhuǎn)向頁面的路徑解析。prefix:前綴, suffix:后綴 -->    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:prefix="/jsp/" p:suffix=".jsp" /></beans>

DispatcherServlet會(huì)利用一些特殊的bean來處理Request請(qǐng)求和生成相應(yīng)的視圖返回。

關(guān)于視圖的返回,Controller只負(fù)責(zé)傳回來一個(gè)值,然后到底返回的是什么視圖,是由視圖解析器控制的,在jsp中常用的視圖解析器是InternalResourceViewResovler,它會(huì)要求一個(gè)前綴和一個(gè)后綴

在上述視圖解析器中,如果Controller返回的是blog/index,那么通過視圖解析器解析之后的視圖就是/jsp/blog/index.jsp。

主要是說說Controller.

一個(gè)類使用了@Controller進(jìn)行標(biāo)記的都是Controller

package controller;import javax.servlet.http.HttpServletRequest;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestParam;import entity.User;@Controller  //類似Struts的Actionpublic class TestController {    @RequestMapping("test/login.do")  // 請(qǐng)求url地址映射,類似Struts的action-mapping    public String testLogin(@RequestParam(value="username")String username, String passWord, HttpServletRequest request) {        // @RequestParam是指請(qǐng)求url地址映射中必須含有的參數(shù)(除非屬性required=false)        // @RequestParam可簡寫為:@RequestParam("username")        if (!"admin".equals(username) || !"admin".equals(password)) {            return "loginError"; // 跳轉(zhuǎn)頁面路徑(默認(rèn)為轉(zhuǎn)發(fā)),該路徑不需要包含spring-servlet配置文件中配置的前綴和后綴        }        return "loginSuccess";    }    @RequestMapping("/test/login2.do")    public ModelAndView testLogin2(String username, String password, int age){        // request和response不必非要出現(xiàn)在方法中,如果用不上的話可以去掉        // 參數(shù)的名稱是與頁面控件的name相匹配,參數(shù)類型會(huì)自動(dòng)被轉(zhuǎn)換                if (!"admin".equals(username) || !"admin".equals(password) || age < 5) {            return new ModelAndView("loginError"); // 手動(dòng)實(shí)例化ModelAndView完成跳轉(zhuǎn)頁面(轉(zhuǎn)發(fā)),效果等同于上面的方法返回字符串        }        return new ModelAndView(new RedirectView("../index.jsp"));  // 采用重定向方式跳轉(zhuǎn)頁面        // 重定向還有一種簡單寫法        // return new ModelAndView("redirect:../index.jsp");    }    @RequestMapping("/test/login3.do")    public ModelAndView testLogin3(User user) {        // 同樣支持參數(shù)為表單對(duì)象,類似于Struts的ActionForm,User不需要任何配置,直接寫即可        String username = user.getUsername();        String password = user.getPassword();        int age = user.getAge();                if (!"admin".equals(username) || !"admin".equals(password) || age < 5) {            return new ModelAndView("loginError");        }        return new ModelAndView("loginSuccess");    }    @Resource(name = "loginService")  // 獲取applicationContext.xml中bean的id為loginService的,并注入    private LoginService loginService;  //等價(jià)于spring傳統(tǒng)注入方式寫get和set方法,這樣的好處是簡潔工整,省去了不必要得代碼    @RequestMapping("/test/login4.do")    public String testLogin4(User user) {        if (loginService.login(user) == false) {            return "loginError";        }        return "loginSuccess";    }}

以上4個(gè)方法示例,是一個(gè)Controller里含有不同的請(qǐng)求url,也可以采用一個(gè)url訪問,通過url參數(shù)來區(qū)分訪問不同的方法,代碼如下:

package controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestMethod;@Controller@RequestMapping("/test2/login.do")  // 指定唯一一個(gè)*.do請(qǐng)求關(guān)聯(lián)到該Controllerpublic class TestController2 {        @RequestMapping    public String testLogin(String username, String password, int age) {        // 如果不加任何參數(shù),則在請(qǐng)求/test2/login.do時(shí),便默認(rèn)執(zhí)行該方法                if (!"admin".equals(username) || !"admin".equals(password) || age < 5) {            return "loginError";        }        return "loginSuccess";    }    @RequestMapping(params = "method=1", method=RequestMethod.POST)    public String testLogin2(String username, String password) {        // 依據(jù)params的參數(shù)method的值來區(qū)分不同的調(diào)用方法        // 可以指定頁面請(qǐng)求方式的類型,默認(rèn)為get請(qǐng)求                if (!"admin".equals(username) || !"admin".equals(password)) {            return "loginError";        }        return "loginSuccess";    }        @RequestMapping(params = "method=2")    public String testLogin3(String username, String password, int age) {        if (!"admin".equals(username) || !"admin".equals(password) || age < 5) {            return "loginError";        }        return "loginSuccess";    }}

其實(shí)RequestMapping在Class上,可看做是父Request請(qǐng)求url,而RequestMapping在方法上的可看做是子Request請(qǐng)求url,父子請(qǐng)求url最終會(huì)拼起來與頁面請(qǐng)求url進(jìn)行匹配,因此RequestMapping也可以這么寫:

package controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;@Controller@RequestMapping("/test3/*")  // 父request請(qǐng)求urlpublic class TestController3 {    @RequestMapping("login.do")  // 子request請(qǐng)求url,拼接后等價(jià)于/test3/login.do    public String testLogin(String username, String password, int age) {        if (!"admin".equals(username) || !"admin".equals(password) || age < 5) {            return "loginError";        }        return "loginSuccess";    }}

在SpringMVC中常用的注解還有@PathVariable,@RequestParam,@PathVariable標(biāo)記在方法的參數(shù)上,利用它標(biāo)記的參數(shù)可以利用請(qǐng)求路徑傳值,看下面一個(gè)例子

@RequestMapping(value="/comment/{blogId}", method=RequestMethod.POST)public void comment(Comment comment,@PathVariable int blogId, Httpsession session, HttpServletResponse response) throws IOException {    }
在該例子中,blogId是被@PathVariable標(biāo)記為請(qǐng)求路徑變量的,如果請(qǐng)求的是/blog/comment/1.do的時(shí)候就表示blogId的值為1. 同樣@RequestParam也是用來給參數(shù)傳值的,但是它是從頭request的參數(shù)里面取值,相當(dāng)于request.getParameter("參數(shù)名")方法。在Controller的方法中,如果需要WEB元素HttpServletRequest,HttpServletResponse和HttpSession,只需要在給方法一個(gè)對(duì)應(yīng)的參數(shù),那么在訪問的時(shí)候SpringMVC就會(huì)自動(dòng)給其傳值,但是需要注意的是在傳入Session的時(shí)候如果是第一次訪問系統(tǒng)的時(shí)候就調(diào)用session會(huì)報(bào)錯(cuò),因?yàn)檫@個(gè)時(shí)候session還沒有生成。


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 午夜视频国产 | 久久久久久久久久综合 | 中文字幕涩涩久久乱小说 | 中文字幕涩涩久久乱小说 | 毛片免费在线观看 | 国产精品成人一区 | 国产精品久久久久久久久久久久午夜 | 国产一级免费片 | 伊人午夜 | 特一级黄色毛片 | 男女隐私免费视频 | 日本一区二区不卡在线观看 | 亚洲第一色婷婷 | 成人福利免费在线观看 | av播放在线 | 成人在线视频一区 | 蜜桃av网 | 免费国产之a视频 | 国产精品久久久久久久av三级 | 国产91av视频 | 日本在线播放一区二区 | 黑人一区二区三区四区五区 | 日韩欧美精品电影 | 激情久久精品 | 国产女同玩人妖 | 19禁国产精品福利视频 | 一级做a爱片性色毛片 | 免费看a级片 | 国产亚洲高清在线精品不卡 | 素人视频免费观看 | 日韩蜜桃视频 | 久久最新网址 | 一级爱爱 | chinesegv男男猛男无套 | 国产亚色| 精品一区二区三区在线观看国产 | 日本成人高清视频 | 海角在线观看91一区二区 | 91九色网 | 成人福利在线视频 | 免费一级a毛片免费观看 |