铺垫:三层架构和MVC
咱们开发服务器端程序,一般都基于两种形式,一种C/S架构程序,一种B/S架构程序
使用Java语言基本上都是开发B/S架构的程序,B/S架构又分成了三层架构
三层架构
表现层:WEB层,用来和客户端进行数据交互的。表现层一般会采用MVC的设计模型
业务层:处理公司具体的业务逻辑的
持久层:用来操作数据库的
MVC模型
MVC全名是Model View Controller 模型视图控制器,每个部分各司其职。
Model:数据模型,JavaBean的类,用来进行数据封装。
View:指JSP、HTML用来展示数据给用户
Controller:用来接收用户的请求,整个流程的控制器。用来进行数据校验等。
springmvc的概述
1.是一种基于Java实现的MVC设计模型的请求驱动类型的轻量级WEB框架,
2.Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里,Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块
3. 使用 Spring 可插入的 MVC 架构,从而在使用Spring进行WEB开发时,可以选择使用Spring的
4.SpringMVC框架或集成其他MVC开发框架,如Struts1(现在一般不用),Struts2等。
准备工作
首先建立一个maven工程,然后导入相对应的jar包所在的坐标
<!--编辑spring的版本锁定和修改maven的编译版本-->
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<spring.version>5.0.2.RELEASE</spring.version>
</properties>
<!--编辑该项目该有的依赖的坐标-->
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
1.首先配置配置核心的控制器DispatcherServlet
<web-app>
<display-name>Archetype Created Web Application</display-name>
<!--配置前端控制器-->
<servlet>
<servlet-name>dispatcherServlet</servlet-name> <!--DispatcherServlet控制作用,指挥中心的作用-->
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--在前端控制器中添加一个初始化参数,
让项目一启动的时候就加载该配置文件进行工作
服务器一启动,配置文件就加载了,由对springmvc.xml的中配置可以知道
配置文件一加载:实现注解的扫描,会利用ioc技术将类加载到容器中
并将类创建成对象,默认是单例的模式
-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!--最高级别,服务器一启动,就自动启动前端控制器,不加这句话就代表第一次发送请求的时候创建-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
2.配置springmvc.xml配置文件,实现其相关的数据的加载和配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!--开启注解的扫描-->
<context:component-scan base-package="cn.ujiuye"></context:component-scan>
<!--视图解析器 前缀的名称是以prefix开始,后缀的名称是以.jsp开始的-->
<!--视图解析器也会变成对象,自动加载视图的模式-->
<bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!--开启springmvc注解的支持-->
<mvc:annotation-driven></mvc:annotation-driven>
</beans>
3.对控制层的描写和编写,代码里注释很详细,需要可以参考
package cn.ujiuye.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
/**
* @author liugang
* @date 2019/10/7
* 控制器类
*/
@Controller //将该类交给ioc容器去管理
@RequestMapping(path = "/user")
public class HelloController {
/**
* 入门案例
* @return
*/
//用于建立请求url和处理请求方法之间的对应的关系
@RequestMapping(path = "/hello") //处理器映射器,让Controller类中的什么方法去执行
public String sayHello(){
System.out.println("Hello StringMVC");
return "success";
}
/**
* RequestMapping注解
* @return
*/
@RequestMapping(value = "/testRequestMapping",params = {"username=hehe"})
public String testRequestMapping(){
System.out.println("测试RequestMapping注解...");
return "success";
}
}