0
点赞
收藏
分享

微信扫一扫

初识SpringMVC

Gaaidou 2022-03-11 阅读 38

1、SpringMVC是什么

1、SpringMVC是表现层框架,它就相当于mvc模式中的c。
2、SpringMVC的功能就是之前Servlet的功能,可以理解为SpringMVC代替了Servlet。

2、SpringMVC运行流程图

在这里插入图片描述

3、SpringMVC入门案例

3.1、添加依赖(pom.xml):

<dependencies>
  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.11</version>
    <scope>test</scope>
  </dependency>

  <dependency>
    <groupId>jstl</groupId>
    <artifactId>jstl</artifactId>
    <version>1.2</version>
  </dependency>
  <dependency>
    <groupId>taglibs</groupId>
    <artifactId>standard</artifactId>
    <version>1.1.2</version>
  </dependency>
  <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
  <dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>javax.servlet-api</artifactId>
    <version>4.0.1</version>
  </dependency>
  <dependency>
    <groupId>javax.servlet.jsp</groupId>
    <artifactId>jsp-api</artifactId>
    <version>2.2.1-b03</version>
  </dependency>
  <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-webmvc</artifactId>
    <version>4.3.7.RELEASE</version>
  </dependency>

  <!-- 处理Json数据的依赖包-->
  <dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-core</artifactId>
    <version>2.13.0</version>
  </dependency>
  <dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.13.0</version>
  </dependency>
  <dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-annotations</artifactId>
    <version>2.13.0</version>
  </dependency>

</dependencies>

3.2、文件目录:

在这里插入图片描述

3.3、创建web.xml文件:

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
         http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">
  <display-name>Archetype Created Web Application</display-name>
  <!--
  1、添加DispatcherServlet类(中央调度器):
  		在SpringMVC中使用的是DispatcherServlet为					核心控制器. DispatcherServlet核心控制器会拦截	**匹配的请求,把拦截下来的请求**,依据相应的规则分	发到目标Controller来处理;
	  	 <init-param>
	      <param-name>contextConfigLocation</param-name>
	      <param-value>classpath:ApplicationConfig.xml</param-value>
	    </init-param>
	    当启动Tomcat时加载SpringMVC的配置文件
	    
	    <load-on-startup>1</load-on-startup>
	    )load-on-startup元素标记容器是否在启动的时候就加载这个servlet
    	
  -->
  <servlet>
    <servlet-name>Myservlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:ApplicationConfig.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Myservlet</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

<!--
	2、设置请求、响应时的字符编码(类:CharacterEncodingFilter)
	
-->
  <filter>
    <filter-name>Encoding</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
      <param-name>forceRequestEncoding</param-name>
      <param-value>true</param-value>
    </init-param>
    <init-param>
      <param-name>forceResponseEncoding</param-name>
      <param-value>true</param-value>
    </init-param>
  </filter>
  <!--
    "/*":可以拦截全部请求(除静态请求)
  -->
  <filter-mapping>
    <filter-name>Encoding</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
</web-app>```
## 3.4、创建主配置文件:(resource文件下的xxx.xml)

```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: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 http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!--1、注解解析器-->
    <context:component-scan base-package="com.dn" />
<!--2、视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/view/" />
        <property name="suffix" value=".jsp" />
    </bean>
<!--3、允许使用注解标签-->
    <mvc:annotation-driven />
    <!--可以在SpringMVC框架加载时创建DefaultServletHttpRequestHandler类(是加载静态资源的)
        例:<img src=".../路径"></img>
            因为"/"所以所有的请求(包括静态请求和动态请求)都会被DispatcherServlet拦截
            但是DispatcherServlet类只能加载动态请求,所以找不到请求的路径
            1、可以使用<mvc:default-servlet-handler />:它会在SpringMVC框架创建时自动加载DefaultServletHttpRequestHandler类
            2、可以使用<mvc:resources mapping="" location=""/>:它会在SpringMVC框架创建时自动加载ResourceHttpRequestHandler类
            DefaultServletHttpRequestHandler类:转给Tomcat中的default的DefaultServletHandler
    -->
    <!--访问静态资源有两种:1、<mvc:default-servlet-handler /> 2、<mvc:resources mapping="" location=""/>(一般使用这个)-->
    <!--
        <mvc:default-servlet-handler />与@RequestMapping()注解有冲突(动态资源无法访问)
            解决办法:添加<mvc:annotation-driven />注解___________________>??????????????????????
          缺点依赖Tomcat(服务器)
        <mvc:resources mapping="" location=""/>:与@RequestMapping()注解也有冲突(动态资源无法访问)
            解决办法:添加<mvc:annotation-driven />注解___________________>??????????????????????
            它会在SpringMVC框架创建时自动加载ResourceHttpRequestHandler类
          不依赖Tomcat(服务器)
    -->

    <!--
        一般将所有的静态资源放在一个文件夹下(在实际开发中放在一个服务器中)
        例:static文件夹存放html、img、js等文件夹(里面是静态资源)
        mapping:访问静态资源的uir地址,可以使用通配符(**)
                **:表示任意目录和资源名称
        location:静态资源在文件中的位置,不要使用/WEB-INF目录
    -->
    <!--    <mvc:default-servlet-handler />-->

    <mvc:resources mapping="/static/**" location="/static/"/>
</beans>

3.4、测试

创建Controller的类(普通类)
类中添加普通方法
//使用@Controller注解(创建对象的注解)
@Controller
@RequestMapping("/")
public class controller {

    //**请求**映射注解
    @RequestMapping("dosome")
    public String dosome(){
        return "index";
    }
}

4.1、注入注解:@Autowired 和**@Resource**区别

1、**@Autowired**:1、按类型装配依赖对象,默认情况下它要求依赖对象必须存在,
	                  如果允许null值,可以设置它required属性为false,
	               2、如果声明在字段上,那么就不需要再写setter方法。
	                  但是本质上,该对象还是作为set方法的实参,通过执行set方法注入,
	                  只是省略了setter方法罢了
	               3、@Qualifier的value属性用于指定要匹配的Bean的id值
2、**@Resource**:1、是J2EE本身提供的,通过byName(名称)注入,如果没有匹配则通过byType注入
举报

相关推荐

0 条评论