springmvc-02-注解开发

使用注解开发需要修改之前的配置:

首先就是maven的包和之前的一样:

<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.19.RELEASE</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.2</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
</dependencies>

第二步就是在web.xml中配置DispatcherServlet:

<!--配置DispatcherServlet-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--DispatcherServlet要绑定Spring的配置文件-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-annotation.xml</param-value>
</init-param>
<!--启动级别:1-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>

第三步配置DispatcherServlet绑定的Spring文件:

<?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:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 自动扫描包,让指定包下的注解生效,由IOC容器统一管理 -->
<context:component-scan base-package="com.wyw.contorller"/>
<!-- 让SpringMVC不处理静态资源 .css .js等-->
<mvc:default-servlet-handler/>
<!-- 支持mvc注解驱动
在spring中一般采用@RequestMapping注解来完成映射关系
要想使@RequestMapping注解生效
必须向上下文中注册HandleMapping和HandleAdapter实例
而annotation-driver配置会帮我们完成注入-->
<mvc:annotation-driven/>
<!--视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
<!--前缀-->
<property name="prefix" value="/jsp/"/>
<!--后缀-->
<property name="suffix" value=".jsp"/>
</bean>


</beans>

配置完之后就可以开始写Controller类,这次这个类不需要实现Controller接口,可以直接使用@Controller的注解来实现,在这个类中我们不重写handleRequest方法,我们直接写一个返回值为String的方法,传递的参数为Model类型的model(随意起名字),通过调用model中的addAttribute方法来添加要传递的数据,最后return返回你要跳转的jsp页面的名称,通过@RequestMapping注解来完成映射关系也就是在导航栏你要输入的地址:

@Controller
public class HelloController {
@RequestMapping("/hello")
public String hello(Model model){
String result="Hello,SpringMVCAnnotation";
model.addAttribute("msg",result);
return "hello";
}
}

最后在项目发布时一定要查看Artifacts下的WEB-INF下是否由lib目录,目录中是否有maven的包!


 

上一篇:SpringMVC源码(一):SpringMVC介绍使用


下一篇:SpringMVC学习笔记06--------乱码问题处理