Web项目:基于HTTP协议,当一个用户从浏览器上面输入URL地址之后,URL能够和我们的程序映射起来,可以让用户的请求触达到后端程序里面,并且根据程序的处理,把结果返回浏览器;
Spring MVC要进行学习的内容:
1)连接的功能:将用户浏览器和Java程序进行连接起来,也就是说访问一个url地址可以调用到我们的Spring程序,能够匹配到相应的方法,实现用户到程序的映射;
2)获取参数:用户访问的时候会带一些参数,要想办法在程序中获取到这些参数,表单文件,Header里面的参数,服务器端要获取到用户的请求参数;
3)输出数据的功能:执行了业务逻辑之后,服务器端要把程序执行的结果返回给用户前端
Spring框架是一个大的体系,SpringWebMVC只是Spring体系中的一个WEB模块,之前在去学习Spring的时候,是没有通过浏览器来访问我们的Spring程序的,而是通过Application中的main方法去执行Spring框架的,因为之前创建的是一个SpringCore项目,不是一个SpringWEBMVC项目,就不可以通过浏览器访问;
SpringWebMVC
Spring和SpringMVC诞生的历史比较久远,在他们之后才有SpringBoot
1)SpringMVC框架是基于ServletAPI和MVC设计思想构建的原始Web框架,但是从一开始就包含在Spring框架里面,Spring框架是一个大的体系,Spring MVC只是属于Spring这个体系的Web框架模块,SpringMVC其实就是Spring中的一个模块,主要处理Web开发的路径映射和视图渲染,属于Spring框架中Web层开发的一部分;
2)SpringBoot脚手架是为了快速开发Spring框架而诞生的一种框架一种技术,就是为了让大家用Spring用的比较爽的一个框架,就是一个壳,核心还是开发Spring,SpringBoot是spring提供的一个快速开发工具包,让程序员能更方便、更快速的开发spring和springmvc应用,简化了配置约定了默认配置,是最后诞生的,出生比较晚,有单独创建框架的一种模式;
3)我们既可以根据Spring创建一个Spring Core项目,也是可以根据Spring创建一个Spring Web项目;
4)他的全称为Spring Web MVC是基于Servlet API构建的原始Web框架,但是他一开始就包含在Spring框架里面,是SpringBoot的一个WEB模块,Spring MVC是一个Web框架,Spring MVC是基于Servlet API进行实现的,MVC和SpringMVC的关系就类似于IOC和DI的关系;
5)我们在进行创建SpringBoot项目的时候,我们进行勾选的Spring Web选项其实就是Spring MVC框架,我们可以看到从pom.xml里面就可以看到spring-boot-starter-web
我们加上Spring Boot DevTools是为了可以完成热部署的;
1)SpringMVC是一个基于MVC设计模式思想和ServletAPI接口实现的一个web框架,同时SpringMVC又是Spring框架中的一个web模块,是随着Spring的诞生而存在的一个Web框架
2)现在市面上面的绝大多数Spring项目都是基于SpringBoot,通过自己创建的main方法启动一个Spring框架或者是SpringCore项目,而Spring的核心就是SpringMVC,所以说SpringMVC的项目是基于SpringBoot来进行更简便的开发的,我们基于Spring Boot框架添加一个Spring Web依赖,此时的项目就变成了Spring MVC项目;
3)MVC架构分层的主要作用是解耦,采用分层架构的好处,普遍接受的是系统分层有利于系统的维护,系统的扩展,就是增强系统的可维护性和可扩展性;
MVC通常是Model View Controller,它是软件工程中的一种常见的设计模式,他把软件项目分为模型,视图和控制器三个部分
1)控制器(Controller):通常是应用程序中用来处理用户交互的部分,并向数据模型层发送数据,类似于保安,验证用户合法性和用户传递参数合法性,因为模型层把结果数据传输给Controller层之后,Controller层是不可以直接把从数据库查询出的数据传输给用户的,因为浏览器看不懂,要把数据传输给服务器端的视图层;
2)模型(Model):是应用程序中用于处理应用程序数据逻辑的部分,通常模型对象负责在数据库中存储数据和拉取数据,调用数据库;
3)视图(View):是应用程序中用于处理数据显示的部分,当Controller把数据传送到视图层的时候,这里面是服务器端的视图,会将数据和服务器端的模板,叫做显示层,主要是显示数据,把浏览器能够解析的html返回给客户端;
服务器端的模板:模板引擎和JSP;
4)Controller在收到模型层处理完的用户数据之后,会直接将数据发送给视图层,咱们的视图层会将数据和服务器端的模板(JSP,摸板引擎,HTML)结合,会将数据加上服务器端的模板,就比如说v-for,循环渲染之后,再把最终整合成的标签,比如说三个h1返回给客户端的视图,客户端的视图在进行拼接v-for分解之后和渲染然后展示在浏览器上面,这样就可以保证用户拿到看到的数据是经过服务器端执行和渲染之后的一个结果了
视图分为两种:一种是服务器端的视图(v-for),一种是客户端的视图(浏览器直接解析)
1)MVC是一种思想,Spring MVC是一个专门的技术实现手段框架和是对MVC思想的实现,是一种MVC模式,并继承了Servlet API的WEB框架,既然是WEB框架,那么用户在浏览器上面输入了url之后,我们的SpringMVC框架就可以进行感知用户的请求;
在application.properties写上这段代码:debug=true;
2)路由映射:就是当用户访问一个url的时候,将用户的某个请求对应到程序中的某个类的某个方法的过程中就叫做路由映射;
3)现在绝大多数的项目都是基于Spring项目的,而Spring的核心就是SpringMVC,也就是说SpringMVC框架是Spring框架的核心模块,而SpringBoot又是Spring的脚手架,因此现在市面上面的JAVA项目就等同于SpringMVC项目;
4)SpringMVC项目可以是基于SpringBoot创建,也就是创建一个SpringBoot项目,勾选上SpringWEB项目,这时就从一个普通的SpringBoot项目变成了WEB项目,就是类似于maven项目变成了Servlet项目;
5)SpringMVC项目创建:基于SpringBoot框架加上一个SpringWEB也就是SpringMVC依赖,此时项目就变成了SpringMVC项目;
一)实现程序到用户之间的映射:
输入一个127.0.0.1:8080/Java200就可以访问这个页面
我们在Main目录下的resorces的static里面创建了一个html文件下面我们来改一下后端代码:
在浏览器上面输入:http://localhost:8080/java200这个地址就可以访问到Text.html这个页面了
1)@RequestMappering的作用就是用来注册一个URL路由,通过这个路由,就可以进行实现前端的请求和后端程序的交互了但是@RequestMappering这个注解实际可以修饰方法也是可以修饰类的@RequestMapping和@ResponseBody注解既是可以修饰类也是可以修饰方法的
2)我们在默认情况下使用@RequestMappering会返回一个html静态界面,但是加上
@RsponseBody就会返回一个非页面的数据了,而不是返回的是一个页面地址
3)当我们使用@RequestBody来进行修饰一个类的时候,这就表示当前类中的所有方法会返回一个非页面的数据
4)同样我们还可以进行指定发送请求的类型:
@RequestMapping(value="/Java200",method= RequestMethod.GET) 如果说我们在Postman上面发送了一个POST请求,就会出现405的报错信息
Controller public class UserController { @RequestMapping(value="/Java",method=RequestMethod.GET) @ResponseBody public String start(String name) { return name+"要你管"; } }
5)@RequestMappering在不进行指定任何参数的情况下,只进行设置路由地址,那么此方法是即支持GET请求又是支持POST请求的,但是当我们给@RequestMapping设置了Method属性之后,那么它只能支持设置的请求类型,其他类型时会报错的(405)
6)我们可以通过更详细的注解比如说@GetMapping(指定路由地址)和@PostMapping(指定路由地址)来进行决定访问那一个方法;
为什么RequestMapping默认情况下会返回一个静态页面呢?
这还是历史的原因,因为SpringMVC是和Spring一起创建起来的,Spring,2002年创建的,20年前开发是前后端部分里的时间段,JAVA程序员既要写后端代码也要写前端的一个页面,模板引擎用的非常多,返回的一定是静态页面;但是在今天,格局已经变了,我们是可以返回一个数据了,@ResponseBody返回的是一个非静态页面的数据了;
1)@RequestMapping:支持任意一种请求类型(get/post),既能修饰方法又是可以修饰类的
2)@GetMapping:只是支持get方式的请求(不能修饰类)
3)@PostMapping:只是支持post方式的请求(不能修饰类)
下面的这两种方法只能修饰方法,是不可以进行修饰类的
SpringBoot热加载进行配置,每一次修改Idea代码的时候不需要进行重启运行,每一次我进行修改源代码的时候,都会实时编译.class文件,会自动重启SpringBoot项目;
1)在SpringBoot项目的POM.XML里面引入Spring dev-Tools框架,引入框架,检测当前项目有没有修改原代码
2)在Setting里面开启项目自动编译,众所周知咱们的Idea是由两个Settings,一个就是叫做Settings,一个就是叫做new ProjectSettings,一个是针对当前项目,一个是针对以后new出来的新项目
打开settings,点击Bulid里面的Compiler进行选中
3)点击选择按钮:Build project automatically,选中项目自动编译
开启程序运行的热部署:
4)点击全局搜索,按两下shift就可以了,然后在搜索框里面进行搜索reg,得到选项Registry,然后进行双击下面这个东西,就可以了
compiler.automake.allow.when.app.running
进行选中
5)点击程序运行debug按钮就可以开启热部署;