您的位置:首页 > 编程语言 > Java开发

(2019.7)能让springMVC跑起来的条件

2019-07-11 18:59 134 查看

   springMVC是用来负责管理页面和后台的交互的。他就像是一个管家一样。什么事先经过我,我我虽然不能处理,但是我能给你找人处理。这里我把springMVC称为是老管家。

    # # 老管家都干了什么事呢?

  首先是将前端的请求页面拦截下来,因为我们在前端URL地址栏输入请求地址,是希望后台给我们处理的。不使用框架的话,就直接处理,但是处理起来过程有点麻烦。

  • 1.  想要让老管家来管这件事,就要找老管家来:(引入springMVC的相关jar包,或者使用Maven的话,就引入相关的依赖)。于是老管家来了。

  老管家干的第一件事是拦截请求,这要怎么做呢?

  •  2. 在web.xml文件中加入配置,这样请求就可以给老管家管理了
[code] <!-- 配置springmvc的前端控制器 指向spring-mvc.xml 程序在启动的时候就加载springmvc 可以接受所有请求 load-on-startup:表示启动容器时初始化该Servlet; -->
<servlet>
<servlet-name>springServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 可以自定义servlet.xml配置文件的位置和名称, 默认为WEB-INF目录下,名称为[<servlet-name>]-servlet.xml,如spring-servlet.xml -->
<!-- 这个就是用来加载springMVC的配置文件的,在配置文件中开启包扫描,扫描可以发现控制器,发现请求映射-->
<init-param>
<param-name>contextConfigLocation</param-name>
<!-- 这个是SSM整合后的配置文件的路径,如果单独只是使用springMVC的话,就单独弄一个配置文件就可以了 -->
<param-value> classpath:spring/applicationContext.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<!-- 将前端URL请求和后台处理方法controller建立对应关系-->
<servlet-mapping>
<servlet-name>springServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
  • 上边的配置文件提到了springMVC的配置文件。这个配置文件是要加载进去的。

 

[code] <!-- ①:对com.angus包中的所有类进行扫描,以完成Bean创建和自动依赖注入的功能 -->
<context:component-scan base-package="com.angus"/>
<mvc:annotation-driven />

<!-- 静态资源访问 -->
<!--如果webapp下你新建了文件夹,想访问里面的静态资源,那么就要在这配置一下-->
<mvc:resources location="/images/" mapping="/images/**"/>
<mvc:resources location="/css/" mapping="/css/**"/>
<!-- <mvc:resources location="/styles/" mapping="/styles/**"/> -->
<mvc:resources location="/js/" mapping="/js/**"/>

<!-- ②:启动Spring MVC的注解功能,完成请求和注解POJO的映射 -->
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
<property name="messageConverters">
<list>
<ref bean="mappingJacksonHttpMessageConverter"/>
</list>
</property>
</bean>
<!-- 编码格式 -->
<bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>application/json;charset=UTF-8</value>
</list>
</property>
</bean>

<!-- 配置视图解析器,把控制器的逻辑视频映射为真正的视图 -->
<!-- /WEB-INF/jsp/start.jsp -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
<!-- 请求前缀 -->
<property name="prefix" value="/WEB-INF/views/" />
<!-- 请求后缀 -->
<property name="suffix" value=".jsp" />
</bean>

  下边再讲 视图解析器是干什么用的。

  

  以上工作做完,老管家能干活了。

  至于怎么干活,我举个栗子

  请求可以当做是上家,老管家是中间人,真正干活的服务器是下家。请求过来,被老管家发现,然后就要替上家找联系人。

  这个过程是通过 控制器完成的:也就是controller类

[code]import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

//这个@Controller相当于是暗号,有了这个暗号,才知道这是干什么的。而这个暗号就是说这是
//controller

@Controller

//下边的是明确自己是干什么活处理什么请求的 首先这是包路径

@RequestMapping("user")
public class LoginController {

//下边的是明确自己是干什么活处理什么请求的 首先这也会一个路径。
//到这里为止,可以和上边提到的视图解析器对应起来了
//比方说来了一个请求,老管家是怎么精准的找到下家又不犯错误的呢
// 请求是这样的http://localhost:8080/user/login
//
@RequestMapping("login")
public String login(){
System.out.println("000");
//这个会被老管家拼装起来,这就是视图解析器的作用了,/WEB-INF/views/success.jsp
//要找的就是这个返回页面,经过一些列的操作后,比方说数据的处理呀,完了将这个页面返回去。
//上边说的数据的处理是指一些复杂的服务层调用,服务层再调用数据访问层,最后将数据塞给页面
return "success";
}
}

 

最后再补充一下执行流程把。我觉得这个有帮助我们自己搭环境,也有助于帮助我们理解springMVC,有助于帮助我们排错。

 

OK我根据框来讲解一下,可以看到四个颜色不同的框,这四个框包括了整个springMVC的流程

  首先,绿色代表的是前端页面,前端请求,和这部分相关的就是返回页面。

  然后,红色代表的是控制器,这个是和web.xml配置有关系的,请求能被拦下来,完全是通过web.xml配置来做到的。这部分还和后边的蓝色框有关系,因为在web.xml文件里边加载了和蓝色框相关的配置文件。

  然后,蓝色框通过web.xml加载了自己配置文件,配置文件里边包括开启扫描。蓝色框里边完成的是让请求和处理形成以一个一个的映射。蓝色框处理完了将处理结果返回给前端控制器,也就是红色框,红色框知道请求处理完了。 

  最后,黄色框,里边是返回的页面,蓝色框处理完了以后,会告诉红色框,我处理完了,你去找哪个哪个页面把。这个是由视图解析器来完成的。最后红色框将最终绿色框想要的结果返回,然后由浏览器渲染结果页面。整个结果完成。

 

更加具体的执行流程,基于组件来讲解:

 

 

 

 

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐