Spring MVC

他是基于MVC的设计模式做出来的,他是Spring对Servlet的进一步的封装
  MVC:Model  View  Controller

如何使用Spring MVC?(Spring 和 Spring MVC整合)
    a. pom.xml 导入 SpringMVC.jar

<!-- Spring 5 与SpringMVC -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>

b. 配置(xml 标注):AppConfig类
        @Configurable
        @EnableWebMvc
        @ComponentScan({"day"})

package day;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.view.JstlView;
import org.springframework.web.servlet.view.UrlBasedViewResolver; /**
* 基于注解的配置类(JavaConfig配置)
* @author 张泽
*/ @Configuration
@EnableWebMvc
@ComponentScan({"day"})
public class AppConfig {
/**
* jsp的解析器
* 这个Bean的作用就是告诉Spring MVC 你写的JSP文件的位置
* @return
*/
@Bean
public UrlBasedViewResolver setupViewResolver() {
UrlBasedViewResolver resolver = new UrlBasedViewResolver();
resolver.setPrefix("/WEB-INF/");//-- 位置 受保护的,不可以直接访问
resolver.setSuffix(".jsp"); //-- jsp文件的后缀,你在写页面的时候就省略掉后缀
resolver.setViewClass(JstlView.class);
return resolver;
}
}
/**
换句话说:我们要先配置好那个Servlet,并且在服务器启动的时候把它实例化
(1)tomcat启动的时候,SpringMVC框架写了监听器ContextListener(ServletContextListener)
(2)在ServletContextListener中实例化这个核心的Servlet
(3)这个Serlet拦截一切请求
(4)拦截请求后,在获取请求的路径转发给对应的Controller
(5)Controller再进行相应的请求的处理 想法:所有的Bean要纳入到Spring容器来管理,才能实现面向接口的编程
Tomcat 启动后,会不会有Spring容器。
当Tomcat启动的时候,我们实例化一个Spring容器。然后把它放到ServletContext
SpringMVC:
(1)在Tomcat启动的时候,实例化一个Spring容器放入到ServletContext对象里
(2)并且在ServletContext中实例化那个核心的Servlet
(3)而且该Servlet拦截一切请求 */

  
        WebInitializer类:web容器启动得时候会调用该类得onStartup方法初始化工作:Spring容器与SpringMVC框架

package day;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletRegistration; import org.springframework.web.WebApplicationInitializer;
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
import org.springframework.web.servlet.DispatcherServlet; /**
* Tomcat 启动的时候会检测是否有WebApplicationInitializer接口的类
* 若检测到有这个类,就会实例化它,并调用他的onStartup方法
* @author 张泽
*/
public class WebInitializer implements WebApplicationInitializer { @Override
public void onStartup(ServletContext servletContext)
throws ServletException {
System.out.println("startup invoker the method"); //-- 1. 构造Spring容器
AnnotationConfigWebApplicationContext ctx =
new AnnotationConfigWebApplicationContext();
//-- 2. Spring容器加载配置
ctx.register(AppConfig.class);
//-- 3. Spring容器接管servletContext应用上下文对象
ctx.setServletContext(servletContext);
//-- 4. 添加Servlet(至少添加一个Servlet,SpringMVC框架实现的入口Servlet)
ServletRegistration.Dynamic servlet =
servletContext.addServlet("dispatcher",new DispatcherServlet(ctx));
servlet.addMapping("/");
servlet.setLoadOnStartup(1);
}
//-- 你想使用Spring,就得有Spring容器得实例,
//-- 你想使用SpringMVC就得配置DispatcherServlet得实例,
//-- 还要把这两个东西放到ServletContext 对象里,为什么呢?
//-- 因为他们两个都是重量级对象
}

调用类

package day;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.List; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView; import com.alibaba.fastjson.JSON; import day.entity.User; @Controller
public class HelloController {
@RequestMapping("/hello")
public void hello() {
System.out.println("hello");
} @RequestMapping("/hi")
public void hi() {
System.out.println("hi");
} @RequestMapping("/index") //-- 代表映射路径
public String index(HttpServletRequest request, HttpServletResponse response) { //-- 方法名
String name = request.getParameter("name");
System.out.println(name);
try {
PrintWriter out = response.getWriter();
out.write("adsfasdfasdf"+name);
out.close();
} catch (IOException e) {
e.printStackTrace();
} return "index";//-- 页面得名字
}
/**
* 返回字符串
* @return
*/
@RequestMapping("/data")
@ResponseBody
public String aaa() {
List<User> users = new ArrayList<User>();
users.add(new User("zz",15));
users.add(new User("zz",15));
users.add(new User("zz",15));
//-- 2. 用alibaba得fastJson工具
String jsonStr = JSON.toJSONString(users);
return jsonStr;
//return "[{'name':zz,'age':15}]";
}
/**
* 返回得是页面,并且可以给页面传递数据
* @return
*/
@RequestMapping("/test")
public ModelAndView bbb(HttpServletRequest request,HttpServletResponse response) { ModelAndView mv = new ModelAndView("test");
//-- do something query data
mv.addObject("message", "宝塔镇河妖");
return mv; //底层:
// request.setAttribute("message", "hello");
// try {
// request.getRequestDispatcher("/WEB-INF/test.jsp").forward(request, response);
// } catch (ServletException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// } catch (IOException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// }
}
}

其他小知识点:

之前的访问连接:URL: http://localhost:8080/hello?name=xxx&word=122
    RestFul形式接口:
        http://localhost:8080/hello/name/zhangsan/password/123456
    
    实现:hello/zhangsan/123456    
    @RequestMapping("/hello/{name}/{password}")
    public String getUser(
        @pathVariable("name") String name,
        @pathVariable("password") String password){}

Get与Post请求:

  方法一:
      @RequestMapping(value="",method=RequestMethod.GET)

    @RequestMapping(value="",method=RequestMethod.Post)
    方法二:
      Get请求:@GetMapping("")   相等于: @RequestMapping(value="",method=RequestMethod.GET)
      Post请求:@PostMappping("")

基于Maven 的 Spring MVC的更多相关文章

  1. 基于maven来Spring MVC的环境搭建遇到“坑”

    1.注解配置路径问题: 在web.xml中配置spring mvc 路径时, 应该配置如下:classpath:classpath:spring-* 2.jdk版本和Spring MVC版本不一致问题 ...

  2. 基于Maven的Spring + Spring MVC + Mybatis的环境搭建

    基于Maven的Spring + Spring MVC + Mybatis的环境搭建项目开发,先将环境先搭建起来.上次做了一个Spring + Spring MVC + Mybatis + Log4J ...

  3. 基于maven进行spring 和mybatis的整合(Myeclpise)

    学习日记:基于maven进行spring和mybatis的整合,进行分页查询 什么是maven:maven是一个项目管理工具,使用maven可以自动管理java项目的整个生命周期,包括编译.构建.测试 ...

  4. Spring7:基于注解的Spring MVC(下篇)

    Model 上一篇文章<Spring6:基于注解的Spring MVC(上篇)>,讲了Spring MVC环境搭建.@RequestMapping以及参数绑定,这是Spring MVC中最 ...

  5. Spring:基于注解的Spring MVC

    什么是Spring MVC Spring MVC框架是一个MVC框架,通过实现Model-View-Controller模式来很好地将数据.业务与展现进行分离.从这样一个角度来说,Spring MVC ...

  6. 用maven创建Spring MVC项目

    用maven创建Spring MVC项目 mvn archetype:generate -DgroupId=fry-arthur -DartifactId=spring-mvc-study -Darc ...

  7. [Java] Maven 建立 Spring MVC 工程

    GIT: https://github.com/yangyxd/Maven.SpringMVC.Web 1. 建立 WebApp 工程 下一步: 下一步: 选择 maven-archetype-web ...

  8. Eclipse Maven构建Spring MVC项目

    工作中项目开发使用Maven管理项目的构建.打包.编译,框架採用的是Spring MVC框架,而且实现了多模块.多项目的管理.自己也简单的參与了架构的设计.对于刚開始学习的人来说,使用Maven构建项 ...

  9. IDEA 通过Maven创建Spring MVC项目搭建

    概述 本篇随笔主要记录内容如下: 1.通过Maven创建基于Spring Framework类库的MVC项目,免去了繁琐的XML配置: 2.在Idea里面配置Tomcat的测试启动项: Maven创建 ...

随机推荐

  1. 【nodejs原理&源码赏析(6)】深度剖析cluster模块源码与node.js多进程(下)

    [摘要] cluster模块详解 示例代码托管在:http://www.github.com/dashnowords/blogs 阅读本章需要先阅读本系列前两章内容预热一下. 一. 引言 前两篇博文中 ...

  2. Python元组tuple(不可变)

    Python元组Tuple(不可变): 元组的特点: 1.元组的初始化: tuple = (1, )  #元组只有一个元素的话,初始化时要加,否则当做元素的普通变量类型处理 tuple = (1, 2 ...

  3. UVA11324 The Lagest Lique(SCC缩点+DP)

    Given a directed graph G, con- sider the following transformation. First, create a new graph T(G) to ...

  4. 【Vuejs】397- Vue 3最值得期待的五项重大更新

    作者|Filip Rakowski 译者|王强 编辑|王文婧 最近关于即将发布的 Vue.js 的第 3 个大版本的消息越来越密集.虽然本文所讨论的内容还没有完全确定下来,但作者已经可以肯定它将是对当 ...

  5. 快速排序 C&&C++

    快排算法 快排和冒泡都是基于交换的思想,但是进行了改进,更为高效.   流程: (1)首先设定一个分界值,通过分界值将数组分成左右两部分. (2)将大于或等于分界值的数据集中到数组右边,小于分界值的数 ...

  6. 日地拉格朗日L2点轨道的卫星运行

    看了嫦娥四号通信的中继卫星,不明白是怎么运行的,下面的演示解除了我的疑问. https://lt.cjdby.net/thread-2479933-1-2.html

  7. 一段简单的关于字符串的 Java 代码竟考察了这么多东西

    下面的代码运行结果是什么?解释一下为什么会有这些差异. String s1 = "hello";String s2 = s1 + ",world";String ...

  8. 解决zabbix监控因php问题导致图形界面中文乱码方法

    解决因编译php中添加了-enable-gd-jis-conv选项导致Zabbix监控系统图形界面中文乱码问题 现象: php编译参数: 说明: 如果PHP编译时启用–enable-gd-jis-co ...

  9. VS2019 开发Django(一)------环境配置

    导航:VS2019开发Django系列 缘起:学习是我一直在做的一件事情,但是,可怕的是不知道学习什么,然后止步不前,安于现状,曾经很长的一段时间,我是不知道学习什么,工作上的事情,其实是相对固定的, ...

  10. rabbitmq~消息失败后重试达到 TTL放到死信队列(事务型消息补偿机制)

    这是一个基于消息的分布式事务的一部分,主要通过消息来实现,生产者把消息发到队列后,由消费方去执行剩下的逻辑,而当消费方处理失败后,我们需要进行重试,即为了最现数据的最终一致性,在rabbitmq里,它 ...