Spring Boot | SpringBoot 对 SpringMVC的 “整合支持“

目录:

    • SpringMVC 的 “整合支持” ( 引入"Web依赖启动器",几乎可以在无任何额外的配置的情况下进行"Web开发")
      • 1.SpringMVC "自动配置" 介绍 ( 引入Web依赖启动器"后,SpringBoot会自动进行一些“自动配置”,自动把相关的类加入到IOC容器中 )
      • 2.Spring MVC功能扩展实现 ( 实际开发中,SpringBoot提供了很多自动化配置,但还要进行一些”功能拓展“ )
        • 2.1 项目基础环境搭建
        • 2.2 功能拓展实现 ( MVC拓展功能 ):
          • ① 创建"视图管理器" ( 属于MVC拓展功能,要自行在SpringBoot进行"相关配置" )
          • ② 创建"自定义拦截器" ( 将该 "自定义的拦截器" 用于在SpringBoot的MVC开发中添加“拦截器”,默认情况下,SpringBoot不会自动为项目配置一个“拦截器” )

在这里插入图片描述

作者简介 :一只大皮卡丘,计算机专业学生,正在努力学习、努力敲代码中! 让我们一起继续努力学习!

该文章参考学习教材为:
《Spring Boot企业级开发教程》 黑马程序员 / 编著
文章以课本知识点 + 代码为主线,结合自己看书学习过程中的理解和感悟 ,最终成就了该文章

文章用于本人学习使用 , 同时希望能帮助大家。
欢迎大家点赞👍 收藏⭐ 关注💖哦!!!

(侵权可联系我,进行删除,如果雷同,纯属巧合)


  • 通常在 Web 开发中,会涉及 静态资源访问支持视图解析器配置转换器格式化器定制文件上传下载 等功能,甚至还需要考虑到与Web服务器关联Servlet相关组件定制
  • Spring Boot框架 支持整合一些 常用Web框架,从而实现Web开发,并 默认支持Web开发中的一些通用功能

SpringMVC 的 “整合支持” ( 引入"Web依赖启动器",几乎可以在无任何额外的配置的情况下进行"Web开发")

  • 为了在SpringBoot实现并简化Web开发SpringBoot为一些**常用的Web开发框架**提供了 整合支持,例如 Spring MVCSpring WebFlux 等框架 ,使用 SpringBoot进行Web开发时,只需要在 项目引入 对应 Web开发框架依赖启动器 即可。

1.SpringMVC “自动配置” 介绍 ( 引入Web依赖启动器"后,SpringBoot会自动进行一些“自动配置”,自动把相关的类加入到IOC容器中 )

  • Spring Boot项目中,一旦引入Web依赖启动器 : spring-boot-starter-web ,那么SpringBoot 整合Spring MVC框架

    默认实现的一些 xxxAutoConfiguration 自动配置类 就会自动生效 ( 通过配置类相关的类加入到IOC容器中 ) ,几乎 可以在无任何额外配置 的情况下 进行Web 开发

  • SpringBoot为整合SpringMVC框架实现Web开发,主要提供了以下 自动化配置功能特性

    (1)内置两个视图解析器 : ContentNegotiatingViewResolverBeanNameViewResolver
    (2) 支持静态资源以及 WebJars
    (3)自动注册
    转换器格式化器

    (4)支持 Http消息转换器
    (5)自动注册了**消息代码解析器
    (6)支持静态项目首页 index.html
    (7)支持
    定制应用图标 favicon.ico
    (8)自动
    初始化** Web数据绑定器ConfigurableWebBindingInitializer

  • Spring Boot 整合Spring MVC进行 Web开发提供了很多默认配置,而且 大多数时候 使用 默认配置可满足开发需求
    例如,Spring Boot整合Spring MVC进行Web开发时,不需要额外配置视图解析器

2.Spring MVC功能扩展实现 ( 实际开发中,SpringBoot提供了很多自动化配置,但还要进行一些”功能拓展“ )

  • 导入web场景依赖启动器后Spring Boot会为MVC开发进行很多“自动化配置”,但在 实际开发中 还需要进行关于MVC开发功能拓展,下面将通过一个具体的案例讲解Spring Boot整合Spring MVC框架中的 MVC功能拓展
    对一些 功能进行扩展实现
2.1 项目基础环境搭建
  • 基础环境搭建

    在这里插入图片描述


    在这里插入图片描述

    MyLocalResolver.java :

    package com.myh.chapter_10.config;import jakarta.servlet.http.HttpServletRequest;
    import jakarta.servlet.http.HttpServletResponse;
    import org.springframework.context.annotation.Bean;
    import org.springframework.web.servlet.LocaleResolver;
    import org.thymeleaf.util.StringUtils;import java.util.Locale;@Configuration
    public class MyLocalResolver implements LocaleResolver {@Overridepublic Locale resolveLocale(HttpServletRequest httpServletRequest) {String l = httpServletRequest.getParameter("l");String header = httpServletRequest.getHeader("Accept-Language");Locale locale = null;if (!StringUtils.isEmpty(l)) {String[] split = l.split("_");//根据-进行字符串拆分locale = new Locale(split[0], split[1]);} else {String[] splits = header.split(",");String[] split = splits[0].split("-");locale = new Locale(split[0], split[1]);}return locale;}@Overridepublic void setLocale(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Locale locale) {}@Bean //将该方法的返回值对象交给IOC容器管理public LocaleResolver localeResolver() {return new MyLocalResolver();}
    }
    

    LoginController.java :

    package com.myh.chapter_10.controller;import org.springframework.stereotype.Controller;
    import org.springframework.ui.Model;
    import org.springframework.web.bind.annotation.GetMapping;import java.util.Calendar;@Controller
    public class LoginController {@GetMapping("/toLoginPage")public String toLoginPage(Model model) { //参数类型为Model类型,该类型可以返回文本给前端model.addAttribute("currentYear", Calendar.getInstance().get(Calendar.YEAR));return "login"; //String的返回值类型可以返回一个视图}
    }
    

    login.properties :

    login.tip=请登录
    login.username=用户名
    login.password=密码
    login.rememberme=记住我
    login.button=登录
    

    login_en_US.properties :

    login.tip=Please sign in
    login.username=Username
    login.password=Password
    login.rememberme=Remember me
    login.button=Login
    

    login_zh_CN.properties :

    login.tip=请登录
    login.username=用户名
    login.password=密码
    login.rememberme=记住我
    login.button=登录
    

    css 和 img ( 百度网盘 )


    login.html :

    <!DOCTYPE html>
    <!-- 让该页面支持 -->
    <html lang="en" xmlns:th="http://www.thymeleaf.org">
    <head><meta charset="UTF-8"><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1,shrink-to-fit=no"><title>用户登录页面</title><link th:href="@{/login/css/bootstrap.min.css}" rel="stylesheet"><link th:href="@{/login/css/signin.css}" rel="stylesheet">
    </head>
    <body class="text-center">
    <form class="form-signin"><img class="mb-4" th:src="@{/login/img/login.jpg}" width="72" height="72"/><h1 class="h3 mb-3 font-weight-normal" th:text="#{login.tip}">请登录</h1><input type="text" class="form-control" th:placeholder="#{login.username}" required="" autofocus=""><input type="password" class="form-control" th:placeholder="#{login.password}" required=""><div class="checkbox mb-3"><label> <input type="checkbox" value="remember-me"/>[[#{login.rememberme}]]</label></div><button class="btn btn-lg btn-primary btn-block" type="submit" th:test="#{login.button}">登录</button><p class="mt-5 mb-3 text-muted">@<span th:text="${currentYear}">2018</span>-<span th:text="${currentYear}+1">2019</span></p><a class="btn btn-sm" th:href="@{/toLoginPage(l='zh_CN')}">中文</a><a class="btn btn-sm" th:href="@{/toLoginPage(l='en_US')}">English</a>
    </form>
    </body>
    </html>
    

    pom.xml :

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.2.4</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.myh</groupId><artifactId>chapter_10</artifactId><version>0.0.1-SNAPSHOT</version><name>chapter_10</name><description>chapter_10</description><properties><java.version>17</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><!--    <build>-->
    <!--        <plugins>-->
    <!--            <plugin>-->
    <!--                <groupId>org.springframework.boot</groupId>-->
    <!--                <artifactId>spring-boot-maven-plugin</artifactId>-->
    <!--            </plugin>-->
    <!--        </plugins>-->
    <!--    </build>--></project>
    

    运行项目后,访问 http://localhost:8080/toLoginPage 能查看到项目的登录页面login.html如下所示
    在这里插入图片描述

2.2 功能拓展实现 ( MVC拓展功能 ):
  • SpringBoot提供了很多关于 MVC 的 “自动化配置”,很多 MVC对象默认配置好 / 大部分MVC内容SpringBoot 都给你 自动默认配置 好了,很多的 MVC功能 / MVC效果都是可以免配置直接使用的 ( 如: 实现的页面跳转 ) ,但此时如果想要使用一些 拓展功能 / 实现功能的拓展 :可以通过 WebMvcConfigurer 这个 接口来实现,WebMvcConfigurer 接口有很多 方法该接口 中的 方法 可用于 “MVC功能拓展”

    • MVC功能拓展功能① ” : 注册 “视图管理器” :

      视图管理器” 可以 将“多个url”自动映射指定的“视图页面”上 , 通过 WebMvcConfigurer接口addViewController( ViewControllerRegistry registry )方法 即可创建“视图管理器” ,达到想要的需求效果。

    • MVC功能拓展功能② ” :自定义 “拦截器” :
      自定义一个拦截器 ( 用于拦截url请求 ) ,在SpringBoot的MVC中用这个 自定义“拦截器” 替代 SpringBoot中 “默认的拦截器

    • MVC功能拓展功能③ ” :注册 “格式化器” :

    • ( 其他MVC拓展功能 )
      ( WebMvcConfigurer接口 中的每一个方法可用于拓展MVC功能 )

① 创建"视图管理器" ( 属于MVC拓展功能,要自行在SpringBoot进行"相关配置" )
  • “视图管理器” 能解决的需求 : 可以 将“多个url”自动映射指定的“视图页面”上 ,例如 : 通过配置“视图管理器” 可以让 /toLoginPage请求/login.html请求都"自动映射"到login.html这个页面中。

  • 创建 视图管理器操作步骤/流程为 :

    首先 创建一个类实现WebMvcConfigurer接口
    中重写该 接口addViewController( ViewControllerRegistry registry)方法
    方法体中通过ViewControllerRegistry对象中的 setViewName( )方法决定哪些url能访问指定的“视图页面”。

  • 视图管理器例子如

    在"项目基础环境搭建"代码基础上添加如下代码

    MyMVCconfig.java :

    package com.myh.chapter_10.config;import org.springframework.context.annotation.Configuration;
    import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;/*** 在SpringBoot中提供了很多关于MNC的“自动化配置”,很多MVC对象都默认配置好/大部分MVC内容SpringBoot都给你自动默认配置好了,很多的* MNC功能/MVC效果都是可以免配置直接使用的(如:实现的页面跳转),但此时如果想要使用一些拓展功能/实现功能的拓展:可以通过* WebMvcConfigurer这个接口来实现,WebMvcConfigurer接口有很多方法,该接口中的方法可用于"MVc功能拓展。**     MVC拓展功能① : 视图管理器 :*     现在你想要实现无论用户访问/toLoginPage 还是 访问/login.html 还是其他ulr 都能跳转到 login.html这个页面,这时候就可以调用*     WebMvcConfigurer接口 的 addViewControllers(ViewControllerRegistry registry) 方法来来创建“视图管理器”的方式来实现“上面要求的效果”*     ( 通过"视图管理器"可以实现多个url访问到同一个"视图页面",但通过这种方式是无法在后端中传递“参数”给“视图页面的”,这时可用拓展功能中的  "过滤器": 来赋值/传递之给“指定的视图页面” )**/
    @Configuration //比较给类为“配置类”,同时将给类加入到IOC容器中
    public class MyMVCconfig implements WebMvcConfigurer { //该类实现了用于MVC功能拓展的“WebMvcConfigurer接口”/*** SpringBoot中的关于MVC的拓展功能一 : 视图管理器*   具体的操作为:*   ①首先创建一个类实现WebMvcConfigurer接口(改接口的作用: 通过该接口中的方法来拓展MVC功能)*   ②在类中重写WebMvc中关于能实现“视图管理器”效果的addViewController(ViewControllerRegistry registry)方法*   ③在方法体中通过ViewControllerRegistry对象中的方法来决定哪些url能访问指定的“视图页面”*///添加“视图管理器” (属于SpringBoot中的MVC的“拓展功能”)@Overridepublic void addViewControllers(ViewControllerRegistry registry) {//让 /toLoginPage 这个请求自动映射到 login.html这个页面中registry.addViewController("/toLoginPage222").setViewName("login");//让 /login.html 这个请求自动映射到 login.html这个页面registry.addViewController("/login222.html").setViewName("login");}
    }
    

    MyMVCconfig实现了接口 WebMvcConfigureraddViewControllers( ViewControllerRegistry registry ) 方法。在addViewControllers( )方法内部,使用ViewControllerRegistryaddViewControlle( )方法分别定义了 /toLoginPage222/login222.htm 的请求控制,并使用setViewName("login’)方法 将路径映射login.html页面。定制完MVC视图管理器功能后,就可以进行效果测试了,项目启动成功后,在浏览器上分别访问http://localhost:8080/toLoginPage222http://localhost:8080/login222.html 效果如下图所示 :

    在这里插入图片描述

    从上图的运行效果可以看出,使用 WebMvConfigurer接口定义的用户请求控制方法也实现了用户请求控制跳转效果相比于传统的请求处理方法而言,这种方法 更加简洁直观方便。同时也可以看出,使用这种方式无法获取后台处理的数据例如登录页面中的年份。

    需要说明的是,使用WebMveConfigurer接口中的addViewControllers(ViewControllerRegistry registry)方法定制视图控制只适合较为简单无参数视图Get方式请求跳转,对于 有参数 或需要 业务处理跳转需求最好还是采用传统方式处理请求


    注意点 :
    使用“视图管理器”的方式来通过多url路径访问到“指定视图页面” , 有 如上图所示问题 ,这时可用 MVC拓展功能中的 : 创建拦截器,在拦截器给“指定视图传递数据

② 创建"自定义拦截器" ( 将该 “自定义的拦截器” 用于在SpringBoot的MVC开发中添加“拦截器”,默认情况下,SpringBoot不会自动为项目配置一个“拦截器” )
  • 注册自定义拦截器WebMvcConfigurer接口提供了许多MVC开发相关方法,例如,添加 “拦截器” 方法addInterceptors( )方法添加 “格式化器” 方法 addFormatters( ) 等。

  • 注册自定义拦截器 代码例子如 :

    项目基础环境搭建 代码的基础上 添加如下代码

    MyInterceptor.java : ( 自定义的"拦截器")

    package com.myh.chapter_10.config;import jakarta.servlet.http.HttpServletRequest;
    import jakarta.servlet.http.HttpServletResponse;
    import org.springframework.stereotype.Component;
    import org.springframework.web.servlet.HandlerInterceptor;
    import org.springframework.web.servlet.ModelAndView;import java.util.Calendar;/**自定义的拦截器,用于替代SpringBoot中MVC的默认的“拦截器” ,可通过实现HandlerInterceptor接口来自定义一个拦截器 :用于拦截“指定的请求” 和 对“指定的请求”放行*/
    @Component //将该类加入到IOC容器中
    public class MyInterceptor implements HandlerInterceptor { //实现HandlerInterceptor接口/*** preHandle : 预处理方法 :* url请求发出后,先执行"拦截器"中的preHandle()方法,再执行controller中的方法*/@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {/***   request.getRequestURI() : 获取并返回"发送请求"的客户端请求的 “URI字符串”。**   URI(统一资源标识符) : uri为url的一部分,但不包括协议和 主机名(域名或IP地址)*   例如,如果请求的完整 URL 是 http://www.example.com/some/info.html 那么 request.getRequestURI()方法*   将返回 /some/info.html*    ---上面的内容即为uri(统一资源标识符)*/String uri = request.getRequestURI(); //获得请求中的"统一资源标识符/uri"Object loginUser = request.getSession().getAttribute("LoginUser");//如果已登录,会在session中的添加一个LoginUser属性/*用户请求/admin开头路径时,判断用户是否登录*///判断uri是否以/admin开头if (uri.startsWith("/admin") && null == loginUser) {//进入这里面表明用户还未登录,拦截器将不对该url放行,同时重定向到login.html页面(同时跳转到login.html页面)response.sendRedirect("/toLoginPage");return false;}//没进if语句中,表明其要么不是/admin请求开头,要么是没登录的用户,对其放行return true;}/*** postHandle : 	该方法会在执行“控制器方法”之后执行,但在“渲染视图页面”之前执行。可以通过此方法对请求域中的“模型和视图”做出进一步的修改* url请求发出后,先执行"拦截器"中的preHandle()方法,再执行controller中的方法,然后就是执行postHandle()方法, 然后就是"渲染视图页面",最后执行afterCompletion()方法*/@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {//想request域中存放当前年份用于"前端页面"动态展示request.setAttribute("currentYear", Calendar.getInstance().get(Calendar.YEAR));}/*** afterCompletion : 该方法在 “整个请求完成” 后执行,即“视图渲染”结束之后执行。可以通过此方法实现一些资源清理、记录日志信息等。*/@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {}//接下来将该自定义的“拦截器”添加到SpringBoot中,通过WebMvcConfigurer接口中的 addInterceptors()方法为将该拦截器加入到SpringBoot中 }
    

    WebMvcConfigurer.java : ( 自定义的"拦截器")

    package com.myh.chapter_10.config;import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
    import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
    import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;/*** 在SpringBoot中提供了很多关于MNC的“自动化配置”,很多MVC对象都默认配置好/大部分MVC内容SpringBoot都给你自动默认配置好了,很多的* MNC功能/MVC效果都是可以免配置直接使用的(如:实现的页面跳转),但此时如果想要使用一些拓展功能/实现功能的拓展:可以通过* WebMvcConfigurer这个接口来实现,WebMvcConfigurer接口有很多方法,该接口中的方法可用于"MVc功能拓展。**     MVC拓展功能 (其中之一) : 自定义"拦截器"*/
    @Configuration //比较给类为“配置类”,同时将给类加入到IOC容器中
    public class MyMVCconfig implements WebMvcConfigurer { //该类实现了用于MVC功能拓展的“WebMvcConfigurer接口”/*** 使用 addInterceptors(InterceptorRegistry registry) 方法将“自定义拦截器” 加入到 SpringBoot中*/@Autowiredprivate MyInterceptor myInterceptor;@Overridepublic void addInterceptors(InterceptorRegistry registry) {/*addPathPatterns() : 要拦截的url路径excludePathPatterns() : 不进行拦截的url路径*/registry.addInterceptor(myInterceptor).addPathPatterns("/**").excludePathPatterns("/login.html");}
    }
    

项目启动成功后,在浏览器上分别访问http://localhost:8080/admin 自动跳转到了 用户登录页面,同时在 页面中动态显示 出了 当前年份,这就说明了定制的“自定义拦截器生效


  • 需要说明的是Spring Boot整合Spring MVC过程中提供了许多默认自动化配置特性,开发者可以通过Spring Boot提供的 WebMvcConfigurer接口MVC功能 进行 定制和扩展

    如果开发者不想使用Spring Boot整合MVC时提供的一些 默认配置,而是想要 绝对自定义管理,那么可以编写一个 @Configuration注解配置类,同时添加 @EnableWebMvc注解 来 关闭Spring Boot提供所有关于MVC功能的默认配置

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux下mysql的彻底卸载

Linux下mysql的彻底卸载 1、查看mysql的安装情况2、删除上图安装的软件3、都删除成功之后&#xff0c;查找相关的mysql的文件4、删除全部文件5、再次执行命令 1、查看mysql的安装情况 rpm -qa | grep -i mysql2、删除上图安装的软件 rpm -ev mysql-community-libs-5.7.27-1.e…

蓝桥杯 前一晚总结 模板 新手版

《准备实足&#xff0c;冲冲冲 省一》https://www.yuque.com/lenyan-svokd/hi7hp2/hfka297matrtsxy2?singleDoc# 《准备实足&#xff0c;冲冲冲 省一》 #include<bits/stdc.h> // 包含标准库头文件using namespace std; using ll long long; // 定义 long long 数据类…

【opencv】示例-opencv_version.cpp 输出OpenCV的版本和构建配置的示例

#include <opencv2/core/utility.hpp> // 引入OpenCV核心工具库 #include <iostream> // 引入标准输入输出流库// 定义一个包含命令行参数的字符串 static const std::string keys "{ b build | | print complete build info }" // 定义参数b&#xff…

【数据结构】06图

图 1. 定义1.1 无向图和有向图1.2 度、入度和出度1.3 图的若干定义1.4 几种特殊的图 2. 图的存储2.1 邻接矩阵-顺序存储&#xff08;数组&#xff09;2.2 邻接表-顺序存储链式存储&#xff08;数组链表&#xff09;2.3 十字链表-适用于有向图2.4 邻接多重表-适用于无向图 3. 图…

设计模式代码实战-建造者模式

1、问题描述 小明家新开了一家自行车工厂&#xff0c;用于使用自行车配件&#xff08;车架 frame 和车轮 tires &#xff09;进行组装定制不同的自行车&#xff0c;包括山地车和公路车。 山地车使用的是Aluminum Frame&#xff08;铝制车架&#xff09;和 Knobby Tires&#x…

【随笔】Git 高级篇 -- 管理多分支 git rebase(二十二)

&#x1f48c; 所属专栏&#xff1a;【Git】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &#x1f496; 欢迎大…

PyTorch环境配置问题

为什么深度学习都是用英伟达的显卡&#xff1f; 首先我们需要了解什么是CUDA&#xff1f; CUDA&#xff08;Compute Unified Device Architecture&#xff09;&#xff0c;是显卡厂商 NVIDIA 推出的运算平台。 CUDA就类似于编程语言&#xff0c;开发者和显卡通过CUDA进行交流…

Android网络抓包--Charles

一、Android抓包方式 对Https降级进行抓包&#xff0c;降级成Http使用抓包工具对Https进行抓包 二、常用的抓包工具 wireshark&#xff1a;侧重于TCP、UDP传输层&#xff0c;HTTP/HTTPS也能抓包&#xff0c;但不能解密HTTPS报文。比较复杂fiddler&#xff1a;支持HTTP/HTTPS…

【SpringBoot】mybatis-plus实现增删改查

mapper继承BaseMapper service 继承ServiceImpl 使用方法新增 save,updateById新增和修改方法返回boolean值,或者使用saveOrUpdate方法有id执行修改操作,没有id 执行新增操作 案例 Service public class UserService extends ServiceImpl<UserMapper,User> {// Au…

用于大规模数据集(大于1TB)的并行运算的MapReduce是怎么实现的?

MapReduce 是一种编程模型&#xff0c;用于处理和生成大数据集。MapReduce 分为两个阶段&#xff1a;Map 阶段和 Reduce 阶段。 Map 阶段&#xff1a;在这个阶段&#xff0c;输入数据被拆分成不同的数据块&#xff0c;这些数据块被分发到各个 Map 任务上。每个 Map 任务对输入的…

Golang | Leetcode Golang题解之第24题两两交换链表中的节点

题目&#xff1a; 题解&#xff1a; func swapPairs(head *ListNode) *ListNode {dummyHead : &ListNode{0, head}temp : dummyHeadfor temp.Next ! nil && temp.Next.Next ! nil {node1 : temp.Nextnode2 : temp.Next.Nexttemp.Next node2node1.Next node2.Nex…

数据结构(算法)

总结&#xff0c;建议看EXCEL的《算法》页签&#xff0c;不然感觉有点乱 备注原理/步骤时间复杂度空间复杂度串的应用模式匹配简单/暴力O(mn) KMP  O(mn) 树的应用树哈夫曼树1、带权路径长度WPL 2、外部排序-最佳归并树1、哈夫曼树的度&#xff0c;只有0和m&#xff08;m叉…

Linux上下载部署zentao v15.5及具体的使用

1.先查询一下Linux的操作系统的位数&#xff0c;确保下载的文件位数与os的一致 [rootlocalhost xiaoming]# uname -m x86_64 [rootlocalhost xiaoming]# getconf LONG_BIT 64 2.下载zentao的Linux压缩包 wget https://www.zentao.net/dl/zentao/15.5/ZenTaoPMS.15.5.zbox…

【opencv】示例-inpaint.cpp 图像修复是通过填充损坏图像部分从而修复这些损坏的过程...

原始图像 这段代码展示了一个使用OpenCV库进行图像修复的例子。它首先包含了处理图像编码、解码、显示、处理和照片处理所必要的OpenCV模块的头文件。然后利用cv和std命名空间下的类和方法。通过定义一个鼠标回调函数onMouse来处理图像上的绘图操作&#xff0c;并通过主函数mai…

基于大数据的全国热门景点数据可视化分析系统

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长 QQ 名片 :) 1. 项目简介 本文将介绍如何使用Python中的Pandas库进行数据挖掘&#xff0c;并结合Flask Web框架实现一个旅游景点数据分析系统。该系统将包括以下功能模块&#xff1a;热门景点概况、景点星级与评分分析、景…

如何使用 Grafana 监控文件系统状态

当 JuiceFS 文件系统部署完成并投入生产环境&#xff0c;接下来就需要着手解决一个非常重要的问题 —— 如何实时监控它的运行状态&#xff1f;毕竟&#xff0c;它可能正在为关键的业务应用或容器工作负载提供持久化存储支持&#xff0c;任何小小的故障或性能下降都可能造成不利…

HCIP-Datacom(H12-821)题库补充(4月12日)

最新 HCIP-Datacom&#xff08;H12-821&#xff09;完整题库请扫描上方二维码访问&#xff0c;持续更新中。 在BGP进程下&#xff0c;Aggregate命令中的detail&#xff3f;suppressed关键字的作用是以下哪一项&#xff1f; A&#xff1a;抑制生成的聚合路由下发IP路由表 B&…

vueRouter动态路由(实现菜单权限控制)

一、权限控制管理&#xff1a; 对于企业级的项目, 我们可能需要对项目做权限控制管理, 实现不同角色的用户登录项目根据所拥有的权限访问不同的页面内容&#xff0c;此时就需要使用到动态路由来对权限页面做限制。 【使用vue-router实现动态路由&#xff0c;达到实现菜单权限…

React + three.js 实现人脸动捕与3D模型表情同步

系列文章目录 React 使用 three.js 加载 gltf 3D模型 | three.js 入门React three.js 3D模型骨骼绑定React three.js 3D模型面部表情控制React three.js 实现人脸动捕与3D模型表情同步 示例项目(github)&#xff1a;https://github.com/couchette/simple-react-three-facia…

BI数据分析软件:行业趋势与功能特点剖析

随着数据量的爆炸性增长&#xff0c;企业对于数据的需求也日益迫切。BI数据分析软件作为帮助企业实现数据驱动决策的关键工具&#xff0c;在当前的商业环境中扮演着不可或缺的角色。本文将从行业趋势、功能特点以及适用场景等方面&#xff0c;深入剖析BI数据分析软件&#xff0…