spring mvc注解搭建

spring mvc注解搭建


1、新建web项目

 

2、添加spring jar包支持,

如果手动添加jar包,需要添加如下jar包

commons-logging-1.1.3.jar

spring-aop-4.0.0.RELEASE.jar

spring-aspects-4.0.0.RELEASE.jar

spring-beans-4.0.0.RELEASE.jar

spring-context-4.0.0.RELEASE.jar

spring-core-4.0.0.RELEASE.jar

spring-expression-4.0.0.RELEASE.jar

spring-jdbc-4.0.0.RELEASE.jar

spring-orm-4.0.0.RELEASE.jar

spring-tx-4.0.0.RELEASE.jar

spring-web-4.0.0.RELEASE.jar

spring-webmvc-4.0.0.RELEASE.jar

 

         如果使用myeclipse工具选择库,那么只用选择core和web库,或者也可以使用maven方式来构建,这里有一个Spring4+ SpringMVC4 + Mybatis3的pom.xml参考案例

         <properties>

        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

        <!-- spring version -->

        <spring.version>4.2.5.RELEASE</spring.version>

        <mybatis.version>3.2.8</mybatis.version>

    </properties>

 

    <dependencies>

        <!-- spring-core -->

        <dependency>

            <groupId>org.springframework</groupId>

            <artifactId>spring-core</artifactId>

            <version>${spring.version}</version>

        </dependency>

 

        <!-- spring-context -->

        <dependency>

            <groupId>org.springframework</groupId>

            <artifactId>spring-context</artifactId>

            <version>${spring.version}</version>

        </dependency>

 

        <!-- Spring AOP -->

        <dependency>

            <groupId>org.springframework</groupId>

            <artifactId>spring-aop</artifactId>

            <version>${spring.version}</version>

        </dependency>

 

        <!-- AspectJ Runtime -->

        <dependency>

            <groupId>org.aspectj</groupId>

            <artifactId>aspectjrt</artifactId>

            <version>1.8.6</version>

        </dependency>

 

        <!-- AspectJ Weaver -->

        <dependency>

            <groupId>org.aspectj</groupId>

            <artifactId>aspectjweaver</artifactId>

            <version>1.8.6</version>

        </dependency>

 

        <!-- Spring Jdbc 的支持 -->

        <dependency>

            <groupId>org.springframework</groupId>

            <artifactId>spring-jdbc</artifactId>

            <version>4.2.5.RELEASE</version>

        </dependency>

 

        <!-- SpringMVC -->

        <dependency>

            <groupId>org.springframework</groupId>

            <artifactId>spring-webmvc</artifactId>

            <version>${spring.version}</version>

        </dependency>

 

        <!-- c3p0 datasource -->

        <dependency>

            <groupId>c3p0</groupId>

            <artifactId>c3p0</artifactId>

            <version>0.9.1</version>

        </dependency>

 

        <!-- mysql-connector -->

        <dependency>

            <groupId>mysql</groupId>

            <artifactId>mysql-connector-java</artifactId>

            <version>5.1.38</version>

        </dependency>

 

        <!-- mybatis -->

        <dependency>

            <groupId>org.mybatis</groupId>

            <artifactId>mybatis</artifactId>

            <version>${mybatis.version}</version>

        </dependency>

 

        <!-- cglib javassist -->

        <dependency>

            <groupId>cglib</groupId>

            <artifactId>cglib</artifactId>

            <version>3.1</version>

        </dependency>

        <dependency>

            <groupId>org.javassist</groupId>

            <artifactId>javassist</artifactId>

            <version>3.17.1-GA</version>

        </dependency>

 

        <!-- logger -->

        <dependency>

            <groupId>commons-logging</groupId>

            <artifactId>commons-logging</artifactId>

            <version>1.1.1</version>

        </dependency>

        <dependency>

            <groupId>log4j</groupId>

            <artifactId>log4j</artifactId>

            <version>1.2.17</version>

        </dependency>

        <dependency>

            <groupId>org.slf4j</groupId>

            <artifactId>slf4j-api</artifactId>

            <version>1.7.5</version>

        </dependency>

        <dependency>

            <groupId>org.apache.logging.log4j</groupId>

            <artifactId>log4j-core</artifactId>

            <version>2.0.2</version>

        </dependency>

        <dependency>

            <groupId>org.slf4j</groupId>

            <artifactId>slf4j-log4j12</artifactId>

            <version>1.7.5</version>

        </dependency>

 

        <!-- mybatis-spring 整合 -->

        <dependency>

            <groupId>org.mybatis</groupId>

            <artifactId>mybatis-spring</artifactId>

            <version>1.2.2</version>

        </dependency>

 

        <!-- jstl 标签库 -->

        <dependency>

            <groupId>jstl</groupId>

            <artifactId>jstl</artifactId>

            <version>1.2</version>

        </dependency>

 

        <!-- junit -->

        <dependency>

            <groupId>junit</groupId>

            <artifactId>junit</artifactId>

            <version>4.10</version>

            <scope>test</scope>

        </dependency>

    </dependencies>

 

3、在web.xml中进行配置

 <servlet>

         <servlet-name>springMVC</servlet-name>

         <!--org.springframework.web.servlet-3.0.1.RELEASE-A.jar/org.springframework.web.servlet/DispatcherServlet.class-->

         <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

 </servlet>

 <servlet-mapping>

         <servlet-name>springMVC</servlet-name>

         <url-pattern>*.spring</url-pattern>

 </servlet-mapping>

 

4、需要在WEB-INF中,新建一个XML文件,本文件的名称要求

         web.xml中servlet-name的名称-servlet.xml

         4.1)配置controller的实例(必须)

                   如:<beanid="myController"class="controller.MyController"></bean>

但是本案例使用的是注解,所以上面的bean配置可以使用注解自动扫描来完成,

所以使用注解,上面bean的配置就不用了,只需要用如下配置进行扫描:

<context:component-scanbase-package="com.lhc"></context:component-scan>这句话即可

         4.2)配置视图解析器(可选)

                   如:

                   <beanid="view"class="org.springframework.web.servlet.view.InternalResourceViewResolver">

                            <propertyname="prefix" value="/jsp/"></property>

                            <propertyname="suffix" value=".jsp"></property>

                   </bean>

 

5、新建一个Controller的包,并新建Controller类组件(类似于struts的action组件)

MyController.java

 

@Controller //通过@Controller注明当前类是一个@Controller组件

public class MyController {

 

}

这样一个基本的Controller组件就写好了,但是里面没有方法,无法从视图层请求到controller,也无法从controller跳转到下一个视图界面,也不能传递参数到controller或从controller传值到下个视图,下面就来讲解下如何实现这些操作

 

6、请求controller

         1)

定义一个方法,使用@RequestMapping注解配置请求当前方法的路径,如:

@RequestMapping("/test1")//这里的名称可以随意,当需要请求时就需要通过此名称路径进行请求此方法

public void test1(){

}

 

2)

@RequestMapping({"/test1","/t"})//可以为一个方法配置多个请求的路径

 

3)

如果在类上添加了@RequestMapping("/dept"),那么在请求的路径上,需要添加dept这个路径,如dept/test1.spring

 

 

7、传参到controller

         1)

         //如果使用了@RequestParam,如果在请求中不传值的话,会报400错误,因为默认把参数作为了地址的一部分

//      publicvoid test1(@RequestParam("username") String uname) {//把页面中传递的参数名称为username的值取出来,赋给后面的uname变量

         //可以通过加上required=false,设置参数不是必须传递,这样在请求此方法时,就可以不用传递这个参数值了,或者使用test2那种方法写

         publicvoid test1(@RequestParam(value="username",required=false,defaultValue="默认值")String uname)

 

         2)

//如果有些使用需要传递username,有些时候不想传递,那么就不能加@RequestParam

         publicvoid test2(String username)

 

         3)

         使用REST风格传参

         @RequestMapping("/fun3/{uname}/{pwd}")//请求时的URL如:fun3/admin/123.spring

         publicvoid fun3(@PathVariable("uname") Stringuname,@PathVariable("pwd") String pwd) {

                   //这里@PathVariable注解,会把上面请求路径上的值赋给后面的变量,PathVariable注解中的名称,可以不与后面变量的名称相同,但是需要与请求路径中的名称相同

}

 

4)

//可以从JSP向controller传值,也可以从controller向JSP传值

publicModelAndView fun5(@ModelAttribute("user") UserInfo user)

 

5)

publicModelAndView fun5(UserInfo user)

但是这种写法需注意,页面传递的参数名称不能试用user.username这种写法,而是直接写username(username是user对象中的一个属性)

 

6)

//从@CookieValue中取出sessionId;@RequestHeader获取客户端请求头的信息

publicModelAndView test13(@CookieValue("JSESSIONID") String sessionId,@RequestHeader("Accept-Language") String accpetLanguage){

 

7)

获取request、response、session对象

publicModelAndView test14(HttpServletRequest request,HttpServletResponseresponse,HttpSession session,String pp){

         String u=request.getParameter("u");

}

 

 

8、controller传值到下个视图

         1)

定义方法的返回类型是ModelAndView

         returnnew ModelAndView("next", "uname", "aaa");//参数:视图的名称,要传递的参数名称,参数值

 

         2)

ModelAndViewmav=new ModelAndView();

         mav.addObject("uname","aaa");

         mav.addObject("pwd","123");

         mav.setViewName("next");

         returnmav;

 

3)

//可以从JSP向controller传值,也可以从controller向JSP传值

public voidfun5(@ModelAttribute("user") UserInfo user)

 

 

4)

//可以向map集合中put一个值,那么就可以在下一个页面中,根据map集合的key得到value值

publicModelAndView test3(Map<String, Object> map) {

         map.put("uname", "张三");

         return newModelAndView("next.jsp");

}

 

5)

//使用Model来存值,然后在页面中进行获取

public ModelAndViewtest4(Model model) {

         model.addAttribute("uname","李四");

         model.addAttribute("王五");//相当于model.addAttribute("String","王五");

         model.addAttribute(new UserBean("小白","555"));//相当于model.addAttribute("userBean", new UserBean("小白","555"));

         return newModelAndView("next.jsp");

         }

 

9、其他:

         1)

//在一个方法上面使用了@ModelAttribute,那么在请求这个controller类中所有的方法时,都会先经过此方法

         @ModelAttribute

         publicvoid populateModel(Model model) {

                   model.addAttribute("uname","小红");

         }

 

         2)

//如果从页面中提交过来的数据类型与参数的类型不一致,那么就会出现400的错误,值如:""、null、英文中文字符

         //一般在一个方法中,不用使用类似int这种基本数据类型接收数值,一般可以定义包装类类型或者定义一个字符串类型

         publicModelAndView test7(String num) {

 

 

         3)@ResponseBody

         在方法上添加@ResponseBody注解,可以自动把返回的对象或者集合转换成json

 

         4)@RestController

         可以让所有的方法返回都自动转换成json

         @RestController= @Controller + @ResponseBody

 

 

10、rest请求,springmvc对rest有很好的支持

         如一个controller中,有如下几个方法:

         //查询

@RequestMapping(value="/emp",method=RequestMethod.GET)

public String query(Map<String,Object> map){

    return "input";

}

 

//添加

@RequestMapping(value="/emp",method=RequestMethod. PUT)

public String add(Map<String,Object> map){

    return "input";

}

 

//修改

@RequestMapping(value="/emp",method=RequestMethod. POST)

public String update(Map<String,Object> map){

    return "input";

}

 

//删除

@RequestMapping(value="/emp",method=RequestMethod. DELETE)

public String delete(Map<String,Object> map){

    return "input";

}

 

那么可以看到,上面四个方法,请求的路径都是emp,但是后面的method不同,如果客户端发送的请求路径都是emp,但是发送的请求方式不同,那么就会请求不同的方法

 

         并且rest风格,传递参数可以使用上面提到类似@RequestMapping("/fun3/{uname}/{pwd}")这种方式传递参数

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值