srpingMVC基本使用

文章目录

  • 1. springMVC基本功能
    • (1) maven坐标导入
    • (2) 编写表现层
    • (3) springMVC配置类编写
    • (4) 部署tomcat访问
  • 2. 各种请求方法
    • get请求
    • post请求
    • put请求
    • delete请求
    • 请求参数提取
  • 3. 请求参数接收
    • (1) param参数接受
      • 封装到对象中
    • (2) 路劲参数接收
    • 集合接受
    • 时间类型接收
    • json参数接收
      • maven导包
      • 开启功能
      • 接收数据
  • 4. 响应数据
  • 5. 全局异常处理
  • 6. springMvc拦截器(Interceptor)

1. springMVC基本功能

与servlet技术功能相等,实现表现层开发:

(1) maven坐标导入

  <dependencies>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>6.0.11</version>
    </dependency>
    <dependency>
      <groupId>jakarta.servlet</groupId>
      <artifactId>jakarta.servlet-api</artifactId>
      <version>5.0.0</version>
    </dependency>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.13.2</version>
      <scope>test</scope>
    </dependency>
  </dependencies>

(2) 编写表现层

@Controller         // 使用controller定义bean
public class test {

    @GetMapping("/hello")
     @ResponseBody		// 直接返回给浏览器
    public String testMVC(){
        System.out.println("接收到请求");
        return "hello world!";
    }
}

(3) springMVC配置类编写

容器配置:

package com.xjy.config;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@ComponentScan({"com.xjy.controller"})
public class MvcConfig {
}

定义 Spring MVC应用程序的初始化器:

package com.xjy.config;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
import org.springframework.web.servlet.support.AbstractDispatcherServletInitializer;
public class MvcContainerInit extends AbstractDispatcherServletInitializer {
//创建DispatcherServlet的应用程序上下文(ApplicationContext)
    @Override
    protected WebApplicationContext createServletApplicationContext() {
        AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
        ctx.register(MvcConfig.class);
        return ctx;
    }
    //指定DispatcherServlet的映射路径
    @Override
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }
    @Override
    protected WebApplicationContext createRootApplicationContext() {
        return null;
    }
    public WebApplicationContext context(){
        return this.createServletApplicationContext();
    }
}

(4) 部署tomcat访问

注意对应的版本:
在这里插入图片描述

部署tomcat程序:
在这里插入图片描述
启动程序后浏览器访问:
在这里插入图片描述

2. 各种请求方法

get请求

    @GetMapping("/get") // 接受get请求
    @ResponseBody
    public String get(){
        System.out.println("接受到请求");
        return "get";
    }

post请求

        @PostMapping("/post")
    @ResponseBody
    public String post(){
        System.out.println("接受到请求");
        return "post";
    }

put请求

    @PutMapping("/put")
    @ResponseBody
    public String put(){
        System.out.println("接受到请求");
        return "put";
    }

delete请求

    @DeleteMapping("/delete")
    @ResponseBody
    public String delete(){
        System.out.println("接受到请求");
        return "delete";
    }

请求参数提取

@Controller
@RequestMapping("/user")
public class userController {
    @RequestMapping("/hello")
    @ResponseBody
    public String save(){
        System.out.println("接受到请求");
        return "hello word!";
    }
   }

访问:
在这里插入图片描述

3. 请求参数接收

(1) param参数接受

直接参数接收:

    @GetMapping("/get")
    @ResponseBody
    public String get(int id){
        System.out.println("接受到请求"+id);
        return "get";
    }

在这里插入图片描述

封装到对象中

    @GetMapping("/get")
    @ResponseBody
    public String get(student stu){
        System.out.println("接受到请求"+stu.getName()+stu.getAge());
        return "get";
    }

发送请求:
在这里插入图片描述
在这里插入图片描述

(2) 路劲参数接收

    @GetMapping("/get/{id}")
    @ResponseBody
    public String get(@PathVariable int id){
        System.out.println("接受到路劲参数:"+id);
        return "get";
    }

发送请求:
在这里插入图片描述
在这里插入图片描述

集合接受

    @PostMapping("/post")
    @ResponseBody
    public String post(@RequestParam List<Integer> list){
        System.out.println("接受到请求"+list.get(0));
        return "ok";
    }

发送请求:
在这里插入图片描述

时间类型接收

    @GetMapping("/get")
    @ResponseBody
    public String get(@DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate date){
        System.out.println("接受到时间参数:"+date);
        return "get";
    }

发送:
在这里插入图片描述

json参数接收

maven导包

    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.13.3</version>
    </dependency>

开启功能

@Configuration
@ComponentScan({"com.xjy.controller"})
@EnableWebMvc
public class MvcConfig {
}

接收数据

    @PostMapping("/post")
    @ResponseBody
    public String post(@RequestBody student stu){
        System.out.println("接受到请求"+ stu.getName());
        return "{'status','ok'}";
    }

发送数据:
在这里插入图片描述

4. 响应数据

方法中直接return

返回json: @ResponseBody 加上注解
@RestController -> @controller + @ResponseBody
在这里插入图片描述

5. 全局异常处理

注解需要配包扫描:

@RestControllerAdvice
public class GlobalExceptionHandler {
    @ExceptionHandler(Exception.class)
    public String exceptionHandler(Exception ex){
        System.out.println("处理到异常");
        return "err";
    }
}

模拟异常:
在这里插入图片描述

6. springMvc拦截器(Interceptor)

自定义拦截:


public class interceptorDo implements HandlerInterceptor {
    @Override // 拦截方法
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("拦截到请求");
        return true;//返回true放行,返回不放行;
    }
    @Override  //资源运行后执行
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        HandlerInterceptor.super.postHandle(request, response, handler, modelAndView);
    }
    @Override  //视图渲染完毕后执行
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        HandlerInterceptor.super.afterCompletion(request, response, handler, ex);
    }
}

配置拦截器:


@Configuration
@ComponentScan({"com.xjy.controller"})
@EnableWebMvc       
public class MvcConfig implements WebMvcConfigurer {
    @Bean
    public interceptorDo getInteceptor(){
        return new interceptorDo();
    }
    @Autowired
    private interceptorDo interceptor;
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
       registry.addInterceptor(interceptor)
               .excludePathPatterns("/long");//过滤登录拦截
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/576998.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Jenkins】持续集成与交付 (一):深入理解什么是持续集成?

【Jenkins】持续集成与交付 (一):深入理解什么是持续集成? 1、软件开发生命周期与持续集成2、 持续集成的流程3、持续集成的好处4、Jenkins的应用实践5、结语💖The Begin💖点点关注,收藏不迷路💖 1、软件开发生命周期与持续集成 软件开发生命周期(SDLC)是指软件从…

【uniapp/ucharts】采用 uniapp 框架的 h5 应用使用 ucharts(没有 uni_modules)

这种情况无法直接从 dcloud 平台上一键下载导入&#xff0c;所以应该在官网推荐的 git 仓库去单独下载&#xff1a; https://gitee.com/uCharts/uCharts/tree/master/uni-app/uCharts-%E7%BB%84%E4%BB%B6/qiun-data-charts(%E9%9D%9Euni_modules) 下载的文件是如图所示的路径&…

clickhouse安装部署

虚拟机&#xff1a;virtualbox7.0 操作系统&#xff1a;ubuntu server 22.04.3 虚拟机硬件&#xff1a;cpu 1&#xff0c;内存 2G&#xff0c; 硬盘 100G 采用默认安装 参照 https://clickhouse.com/docs/en/install#quick-install 安装部署 对于Debian、Ubuntu&#xff0c…

Web前端一套全部清晰 ② day2 HTML 标签之文字排版,图片、链接、音视频链接

虽然辛苦&#xff0c;我还是会选择那种滚烫的人生 —— 24.4.25 HTML初体验 1.HTML定义 HTML 超文本标记语言 超文本 —— 链接 标记 —— 标记也叫标签&#xff0c;带尖括号的文本 标签语法 开始标签 需要加粗的文字 结束标签 标签成对出现&#xff0c;中间包裹内容 <>里…

Django连接数据库

数据库登录命令 mysql -u root -p show databases; Django连接数据库 在settings.py文件中进行配置和修改 DATABASES {default: {ENGINE: django.db.backends.mysql,HOST: 127.0.0.1, # 数据库主机PORT: 3306, # 数据库端口USER: root, # 数据库用户名PASSWORD: 12345…

2024年钉钉直播回放怎么下载

又到了2024年,最近钉钉迎来了一波更新,经过我的研究,总算研究出来了一个方法,并且做成了工具 首先&#xff0c;让我们了解一下钉钉直播回放的下载方法。 钉钉直播回放工具链接&#xff1a;https://pan.baidu.com/s/1oPWJOp8L2SBDlklt_t5WQQ?pwd1234 提取码&#xff1a;1234 -…

[Algorithm][模拟][替换所有问号][提莫攻击][N字形变换][外观数列][数青蛙] + 模拟原理详细讲解

目录 0.原理讲解1.替换所有的问号1.题目链接2.代码实现 2.提莫攻击1.题目链接2.算法原理详解3.代码实现 3.N 字形变换1.题目链接2.算法原理详解3.代码实现 4.外观数列1.题目链接2.算法原理详解3.代码实现 5.数青蛙1.题目链接2.算法原理详解3.代码实现 0.原理讲解 模拟&#xf…

Unreal Engine动态添加Button实例

在控件蓝图中添加容器&#xff0c;注意命名不要有中文 C代码中找到容器实例 1 2 3 4 5 6 7 8 UVerticalBox* verticalBox Cast<UVerticalBox>(CurrentWidget->GetWidgetFromName(TEXT("VerticalBox_0"))); if (verticalBox ! nullptr) { UScrollBox* …

【Linux】:文件查看 stat、cat、more、less、head、tail、uniq、wc

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; Linux深造日志 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一、stat&#xff08;查看文件详细属性信息&#xff09;1.1 内容解析&#xff1a;1.2…

外贸自动化操作脚本的编写!

随着信息技术的飞速发展&#xff0c;外贸行业也迎来了自动化的浪潮&#xff0c;自动化操作脚本的编写&#xff0c;成为了外贸从业者提高工作效率、减少重复性劳动的重要手段。 本文将介绍外贸自动化操作脚本的编写基础&#xff0c;并通过4段源代码的实例&#xff0c;带领读者深…

【工具】-根源上解决VScode打印输出乱码的问题

目录 1 第一步&#xff1a; 改编译命令&#xff0c;保持一致2 第二步&#xff1a; 更改VScode的编码格式-保持一致 1 第一步&#xff1a; 改编译命令&#xff0c;保持一致 看一下你的控制台的编译的命名后缀&#xff0c;有两个关键的参数&#xff0c;如下图&#xff1a; “-f…

thinkphp5.0.23漏洞复现以及脚本编写

1 thinkphp5.0.23远程代码执行漏洞简介 ThinkPHP5.0.23漏洞主要涉及远程代码执行(RCE)的安全隐患。这一漏洞的存在是因为ThinkPHP框架在底层对控制器名的过滤不够严格,导致攻击者有可能通过特定的URL构造,调用到框架内部的敏感函数,进而执行任意命令。 2 thinphp5.0.23漏…

普通屏幕已过时?裸眼3D屏幕显示效果更胜一筹!

随着多媒体技术的迅猛进步&#xff0c;我们日常生活中的内容展现方式&#xff0c;已经经历了前所未有的变革。在这其中&#xff0c;裸眼3D屏幕的应用&#xff0c;无疑是最为引人注目的亮点&#xff0c;它相较于传统屏幕&#xff0c;在显示效果上展现出了鲜明的优势&#xff0c;…

[iOS]使用CocoaPods发布私有库

1.创建私有 Spec 仓库 首先&#xff0c;需要一个私有的 Git 仓库来存放你的 Podspec 文件&#xff0c;这个仓库用于索引你所有的私有 Pods。 在 GitHub 或其他 Git 服务上创建一个新的私有仓库&#xff0c;例如&#xff0c;名为 PrivatePodSpecs。克隆这个仓库到本地&#xf…

电商API数据采集接口||大数据的发展,带动电子商务产业链,促进了社会的进步

最近几年计算机技术在诸多领域得到了有效的应用&#xff0c;同时在多方面深刻影响着我国经济水平的发展。除此之外&#xff0c;人民群众的日常生活水平也受大数据技术的影响。 主流电商API数据采集接口||在这其中电子商务领域也在大数据技术的支持下&#xff0c;得到了明显的进…

关于我在 uniapp 开发过程中遇到的问题(更新中...)

目录 uniapp 勾选自带的隐私政策 出现的问题 是否忽略版本兼容检查提示 勾选了uniapp的消息推送 打包后弹出 push module was not added when packaging, please refertohttps://ask.dcloud.net.cn /article/283 关于uniapp的真机调试 一直等待问题 或者 正在建立链接 在…

机器人前馈控制MATLAB实现

在机器人控制中&#xff0c;前馈控制是一种常用的方法&#xff0c;用于补偿系统中的已知动态。前馈控制通常与反馈控制结合使用&#xff0c;以提高系统的跟踪性能和响应速度。在MATLAB中实现机器人前馈控制涉及几个步骤&#xff0c;包括系统建模、设计前馈控制器、实现控制算法…

【前后端】django与vue的结合使用

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、前后端分离的简介二、django与vue的结合使用三、总结 前言 随着开发语言及人工智能工具的普及&#xff0c;使得越来越多的人会主动学习使用一些开发工具&a…

一、Django 初识

简介 Django 是一个用于构建 Web 应用程序的高级 Python Web 框架。 版本对应 不同版本的django框架是基于特定的不同的python版本开发的&#xff0c;所以不同版本的django框架要正常执行功能只能安装特定的python版本 Django安装 安装 Django # 全局安装 pip install dj…

金融案例:统一查询方案助力数据治理与分析应用更高效、更安全

随着企业数据规模的增长和业务多元化发展&#xff0c;海量数据实时、多维地灵活查询变成业务常见诉求。同时多套数据库系统成为常态&#xff0c;这既带来了数据管理的复杂性&#xff0c;又加大了数据使用的难度&#xff0c;面对日益复杂的数据环境和严格的数据安全要求&#xf…