2.The DispatcherServlet

The DispatcherServlet

Spring的Web MVC框架与许多其他Web MVC框架一样,是请求驱动的,围绕一个中央Servlet(即DispatcherServlet)设计,该Servlet将请求分派给控制器,并提供其他功能以促进Web应用程序的开发。然而,Spring的DispatcherServlet不仅仅是请求分派器,它与Spring的IoC容器完全集成,因此可以使用Spring的所有其他特性。

请求处理工作流

Spring Web MVC的DispatcherServlet的请求处理工作流如下图所示:

  1. 客户端发送请求:用户通过浏览器发送一个HTTP请求。
  2. DispatcherServlet接收请求:请求到达中央的DispatcherServlet,它是整个请求处理的核心。
  3. HandlerMapping:DispatcherServlet使用HandlerMapping确定请求应该发送到哪个处理器(Controller)。
  4. HandlerAdapter:找到合适的Handler后,DispatcherServlet使用HandlerAdapter来执行处理器。
  5. 处理请求:处理器(Controller)处理请求,执行相应的业务逻辑,并返回一个ModelAndView对象,包含模型数据和视图名称。
  6. 视图解析:DispatcherServlet使用ViewResolver将逻辑视图名解析为实际的视图对象(例如JSP页面)。
  7. 生成响应:视图对象负责渲染页面,将模型数据填充到视图中,并生成最终的HTTP响应返回给客户端。

The request processing workflow in Spring Web MVC (high level)

在这里插入图片描述

DispatcherServlet的设计模式

熟悉设计模式的读者会认识到,DispatcherServlet是"前端控制器"(Front Controller)设计模式的一种表达方式。这个模式在许多领先的Web框架中都很常见。

前端控制器(Front Controller)设计模式

前端控制器设计模式的核心思想是使用一个中央控制器来处理所有的请求,然后根据请求的不同,将其分派给适当的处理器。这种模式的优势在于:

  • 集中控制:所有请求通过一个入口点进行处理,方便进行统一的安全检查、日志记录和异常处理。
  • 模块化设计:请求处理逻辑被分散到不同的控制器中,使得代码更加模块化和可维护。
  • 灵活性:可以根据不同的请求类型或URL模式灵活地选择合适的处理器进行处理。

配置DispatcherServlet

在Java EE Servlet 3.0+环境中配置Spring的DispatcherServlet,可以通过标准的Java EE Servlet配置来实现。DispatcherServlet是一个实际的Servlet(它继承自HttpServlet基类),因此需要在Web应用程序中声明,并通过URL映射来处理特定的请求。

1. 使用代码配置DispatcherServlet

首先,实现WebApplicationInitializer接口,以便在Servlet容器启动时进行配置。

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletRegistration;
import org.springframework.web.WebApplicationInitializer;
import org.springframework.web.servlet.DispatcherServlet;public class MyWebApplicationInitializer implements WebApplicationInitializer {@Overridepublic void onStartup(ServletContext container) throws ServletException {// 创建并注册DispatcherServletServletRegistration.Dynamic registration = container.addServlet("example", new DispatcherServlet());registration.setLoadOnStartup(1);registration.addMapping("/example/*");}
}

在上述代码中,所有以/example开头的请求将由名为example的DispatcherServlet实例处理。

2. 使用AbstractAnnotationConfigDispatcherServletInitializer配置DispatcherServlet

这是Spring MVC推荐的设置方式,简化了DispatcherServlet的注册过程,只需指定其Servlet映射和配置类。

import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;public class MyWebAppInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {@Overrideprotected Class<?>[] getRootConfigClasses() {return new Class[] { RootConfig.class };}@Overrideprotected Class<?>[] getServletConfigClasses() {return new Class[] { WebConfig.class };}@Overrideprotected String[] getServletMappings() {return new String[] { "/example/*" };}
}
3. 使用web.xml配置DispatcherServlet

如果更喜欢使用传统的web.xml文件,可以如下配置DispatcherServlet:

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaeehttp://xmlns.jcp.org/xml/ns/javaee/web-app_3_0.xsd"version="3.0"><servlet><servlet-name>example</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>example</servlet-name><url-pattern>/example/*</url-pattern></servlet-mapping>
</web-app>

ApplicationContext和WebApplicationContext

在Spring Web MVC框架中,每个DispatcherServlet都有其自己的WebApplicationContext,它继承了根WebApplicationContext中已经定义的所有bean。

  • 根WebApplicationContext:包含所有需要在整个应用程序中共享的基础设施bean,如数据源、事务管理器等。
  • WebApplicationContext:特定于每个DispatcherServlet,可以在此范围内覆盖根上下文中的bean,并定义新的特定于Servlet实例的bean。

例如:

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class RootConfig {@Beanpublic DataSource dataSource() {// 配置数据源}
}@Configuration
@EnableWebMvc
@ComponentScan("com.example.myapp")
public class WebConfig {@Beanpublic ViewResolver viewResolver() {// 配置视图解析器}
}

在上述配置中,RootConfig类中的bean将在根WebApplicationContext中共享,而WebConfig类中的bean仅在特定的WebApplicationContext中可用。

总结

通过以上方法,可以在Servlet 3.0+环境中配置Spring的DispatcherServlet。推荐使用代码配置方式,尤其是通过AbstractAnnotationConfigDispatcherServletInitializer,因为它更加简洁和灵活。同时,理解根WebApplicationContext与每个DispatcherServlet的WebApplicationContext之间的关系,有助于更好地组织和管理Spring应用程序中的bean。

Typical context hierarchy in Spring Web MVC(Spring Web MVC的典型上下文层次结构)

在这里插入图片描述

在初始化 DispatcherServlet 时,Spring MVC 会在您的 Web 应用程序的 WEB-INF 目录中寻找一个名为 [servlet-name]-servlet.xml 的文件,并创建其中定义的 bean。如果某个 bean 在全局范围内已经定义过了,那么在这个 servlet 特定的上下文中的定义会覆盖全局范围内的定义。这种机制允许每个 DispatcherServlet 都可以拥有自己独立的配置和 bean 定义,以满足特定于 DispatcherServlet 的需求。

请考虑以下 Servlet 配置(在文件中):DispatcherServlet``web.xml

<web-app><servlet><servlet-name>golfing</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>golfing</servlet-name><url-pattern>/golfing/*</url-pattern></servlet-mapping>
</web-app>

根据上述Servlet配置,需要在应用程序中拥有一个名为 /WEB-INF/golfing-servlet.xml 的文件。这个文件将包含所有Spring Web MVC特定的组件(bean),例如控制器、视图解析器等等。

对于单个DispatcherServlet场景,也可以只有一个根上下文。根上下文中的bean可以被多个DispatcherServlet实例共享使用,这在应用程序需要多个DispatcherServlet处理不同URL模式时很有用。

Single root context in Spring Web MVC

在这里插入图片描述

这可以通过设置一个空的 contextConfigLocation servlet init 参数来配置, 如下所示:

<web-app><context-param><param-name>contextConfigLocation</param-name><param-value>/WEB-INF/root-context.xml</param-value></context-param><servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value></param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/*</url-pattern></servlet-mapping><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener>
</web-app>

配置解释

  1. 全局上下文 (Root Context)
    • <context-param> 元素配置了全局上下文的配置文件路径:/WEB-INF/root-context.xml。这是通过 ContextLoaderListener 加载的,它创建了一个全局的 Spring 应用上下文(根上下文),这个上下文在整个 Web 应用程序中共享。
  2. DispatcherServlet 专用上下文 (Dispatcher Context)
    • <servlet> 元素配置了 DispatcherServlet,它通常会有自己的专用 Spring 应用上下文,通常被称为子上下文。
    • <init-param> 中的 contextConfigLocation 参数为空(即:<param-value></param-value>),这表示 DispatcherServlet 将不使用单独的配置文件,而是继承全局上下文(根上下文)的配置。

具体作用

  • contextConfigLocation 参数为空时,DispatcherServlet 会默认查找名为 [servlet-name]-servlet.xml 的配置文件。对于此配置,它会查找 dispatcher-servlet.xml
  • 如果该文件不存在,DispatcherServlet 将不使用任何特定于它的配置文件,而是仅依赖于全局上下文(根上下文)。

这种配置的好处

  1. 简化配置
    • 可以避免为 DispatcherServlet 创建额外的配置文件,简化配置管理。
  2. 共享全局配置
    • DispatcherServlet 直接使用根上下文的配置,使得全局 bean 定义可以被 DispatcherServlet 使用,减少重复配置。

WebApplicationContext 是 ApplicationContext 的扩展,专门为 Web 应用程序提供额外的功能。它与普通的 ApplicationContext 不同之处在于:

  1. 主题解析: WebApplicationContext 能够解析和管理主题(themes),主题是定义 Web 应用程序外观和感觉的静态资源集合,如 CSS 和图片等。

  2. 与 Servlet 的关联: WebApplicationContext 能够知道它所关联的 Servlet。这通过与 ServletContext 的链接实现,ServletContext 提供了对 Web 应用程序资源和配置的访问。

  3. 绑定在 ServletContext 中: WebApplicationContext 被绑定在 ServletContext 中,因此可以在整个 Web 应用程序的生命周期中访问它。

通过 RequestContextUtils 类的静态方法,你可以随时查找 WebApplicationContext,以便在需要时访问它。

请注意,我们可以通过基于 Java 的配置实现相同的目的:

public class GolfingWebAppInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {@Overrideprotected Class<?>[] getRootConfigClasses() {// GolfingAppConfig defines beans that would be in root-context.xmlreturn new Class<?>[] { GolfingAppConfig.class };}@Overrideprotected Class<?>[] getServletConfigClasses() {// GolfingWebConfig defines beans that would be in golfing-servlet.xmlreturn new Class<?>[] { GolfingWebConfig.class };}@Overrideprotected String[] getServletMappings() {return new String[] { "/golfing/*" };}
}

Special Bean Types In the WebApplicationContext

在Spring MVC中,DispatcherServlet 使用特殊的 bean 来处理请求并渲染适当的视图。这些特殊的 bean 是 Spring MVC 的一部分。你可以通过在 WebApplicationContext 中配置其中一个或多个来选择使用哪些特殊的 bean。但是,最初你不需要这样做,因为如果没有配置任何特殊的 bean,Spring MVC 会使用默认的一组 bean。下面是列出的一些特殊 bean 类型及其功能:

Special bean types in the WebApplicationContext

Bean typeExplanation
HandlerMappingMaps incoming requests to handlers and a list of pre- and post-processors (handler interceptors) based on some criteria the details of which vary by HandlerMapping implementation. The most popular implementation supports annotated controllers but other implementations exists as well.
HandlerAdapterHelps the DispatcherServlet to invoke a handler mapped to a request regardless of the handler is actually invoked. For example, invoking an annotated controller requires resolving various annotations. Thus the main purpose of a HandlerAdapter is to shield the DispatcherServlet from such details.
HandlerExceptionResolverMaps exceptions to views also allowing for more complex exception handling code.
ViewResolverResolves logical String-based view names to actual View types.
LocaleResolver & LocaleContextResolverResolves the locale a client is using and possibly their time zone, in order to be able to offer internationalized views
ThemeResolverResolves themes your web application can use, for example, to offer personalized layouts
MultipartResolverParses multi-part requests for example to support processing file uploads from HTML forms.
FlashMapManagerStores and retrieves the “input” and the “output” FlashMap that can be used to pass attributes from one request to another, usually across a redirect.

这里是中文形式的表格:

Bean 类型描述
HandlerMapping确定请求如何映射到具体的处理器(控制器)。
HandlerAdapter调用选定的处理器来处理请求。
HandlerExceptionResolver解析处理器(控制器)抛出的异常,并提供适当的处理方式(例如错误页面或 JSON 响应)。
ViewResolver将逻辑视图名称解析为实际的视图对象(如 JSP、Thymeleaf、Freemarker 等),并处理视图的渲染。
LocaleResolver解析客户端请求的区域信息,使应用程序能够提供语言和文化特定的内容。
ThemeResolver解析客户端请求的主题信息,允许动态切换和管理不同的视觉主题。
Bean 类型默认实现类
------------------------------------------------------------------------------------
HandlerMappingBeanNameUrlHandlerMappingRequestMappingHandlerMapping
HandlerAdapterHttpRequestHandlerAdapterRequestMappingHandlerAdapter
HandlerExceptionResolverDefaultHandlerExceptionResolver
ViewResolverInternalResourceViewResolver
LocaleResolverAcceptHeaderLocaleResolver
ThemeResolverFixedThemeResolver

详细说明

  1. HandlerMapping(处理器映射)

    • BeanNameUrlHandlerMapping:将 URL 请求映射到具有特定名称的 bean。
    • RequestMappingHandlerMapping:基于注解的请求映射,处理使用 @RequestMapping 注解的控制器方法。
  2. HandlerAdapter(处理器适配器)

    • HttpRequestHandlerAdapter:处理实现了 HttpRequestHandler 接口的处理器。
    • RequestMappingHandlerAdapter:处理基于注解的控制器,适配 @RequestMapping 注解的方法。
  3. HandlerExceptionResolver(处理器异常解析器)

    • DefaultHandlerExceptionResolver:默认的异常解析器,处理常见的异常类型,如 NoSuchRequestHandlingMethodExceptionHttpRequestMethodNotSupportedException 等。
  4. ViewResolver(视图解析器)

    • InternalResourceViewResolver:将逻辑视图名称解析为内部资源视图(如 JSP 文件),通过转发请求来渲染视图。
    • 示例:在这里插入图片描述
  5. LocaleResolver(区域解析器)

    • AcceptHeaderLocaleResolver:根据请求头中的 Accept-Language 信息解析区域设置。
  6. ThemeResolver(主题解析器)

    • FixedThemeResolver:使用固定的主题,不支持动态切换主题。

这些默认实现类提供了基础的功能,可以满足大多数 Web 应用程序的需求。如果有特定的需求,可以通过在配置文件中定义自定义的 bean 来覆盖这些默认实现。

Default DispatcherServlet Configuration

  1. 默认配置文件 DispatcherServlet.properties:

    • DispatcherServlet 在 org.springframework.web.servlet 包下的 DispatcherServlet.properties 文件中维护了特殊 bean 的默认实现列表。每种特殊 bean 都有其默认的实现。
  2. 定制特殊 bean:

    • 虽然每种特殊 bean 都有合理的默认设置,但迟早你会需要定制其中一个或多个 bean 的属性。例如,常见的做法是配置 InternalResourceViewResolverprefix 属性,指定视图文件的父路径。
  3. 覆盖默认实现:

    • 当你在 WebApplicationContext 中配置特殊 bean(例如 InternalResourceViewResolver)时,实际上是覆盖了原本会被用作该特殊 bean 类型的默认实现列表。例如,如果配置了 InternalResourceViewResolver,那么默认的 ViewResolver 实现列表就会被忽略。
  4. 其他配置选项:

    • 在第 22.16 节 “Configuring Spring MVC” 中,你将了解到配置 Spring MVC 的其他选项,包括 MVC Java 配置和 MVC XML 命名空间。这些选项为配置 Spring MVC 提供了简单的起点,假设你对 Spring MVC 的工作原理了解不多。不论你如何选择配置你的应用程序,本节中解释的概念都是基础且有益的。

总结来说,这段话强调了在配置 Spring MVC 应用程序时,理解和定制 DispatcherServlet 的特殊 bean 是至关重要的。通过配置特殊 bean,你可以根据应用程序的需求修改默认的行为,并控制请求处理和视图解析的细节。

DispatcherServlet Processing Sequence

当设置好 DispatcherServlet 并且接收到该 DispatcherServlet 的请求时,DispatcherServlet 开始按照以下步骤处理请求:

  1. 绑定 WebApplicationContext:

    • DispatcherServlet 首先在请求中查找并绑定 WebApplicationContext。这个 WebApplicationContext 默认以 DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE 作为键名绑定在请求中,控制器和其他处理流程中的元素可以使用它。WebApplicationContext 包含了整个应用程序的配置和 bean 定义。
  2. 绑定 LocaleResolver:

    • LocaleResolver 负责解析请求的区域设置信息,以便在处理请求时确定要使用的语言和文化。如果应用程序不需要国际化支持,可以忽略这一步骤。
  3. 绑定 ThemeResolver:

    • ThemeResolver 负责解析请求的主题信息,允许视图根据请求动态切换和管理不同的视觉主题。如果应用程序不使用主题功能,可以忽略这一步骤。
  4. 处理文件上传(如果需要):

    • 如果配置了 multipart 文件解析器,DispatcherServlet 将检查请求是否包含多部分内容(文件上传)。如果有多部分内容,请求将被包装在 MultipartHttpServletRequest 中,以便其他处理流程进一步处理。关于多部分处理的更多信息,请参见第 22.10 节 “Spring 的多部分(文件上传)支持”。
  5. 查找适当的处理器(Handler):

    • DispatcherServlet 查找与请求匹配的处理器。如果找到处理器,将按照处理器关联的执行链(预处理器、后处理器和控制器)的顺序执行,以准备模型数据或进行渲染。
  6. 渲染视图或处理异常:

    • 如果处理器返回了模型数据,则进行视图渲染。如果处理过程中抛出了异常,那么声明在 WebApplicationContext 中的处理器异常解析器将捕获这些异常,并根据配置的方式处理异常情况,例如返回特定的错误页面或 JSON 响应。
  7. 支持最后修改日期(Last-Modified):

    • DispatcherServlet 还支持根据 Servlet API 指定的最后修改日期返回给客户端。它通过查找适当的处理器映射,并检查找到的处理器是否实现了 LastModified 接口来确定特定请求的最后修改日期。
  8. 自定义 DispatcherServlet:

    • 你可以通过向 web.xml 文件中的 Servlet 声明添加 Servlet 初始化参数(init-param 元素)来定制单个 DispatcherServlet 实例。下表列出了支持的参数列表。

这些步骤和功能说明了 DispatcherServlet 在处理请求时的详细流程,以及如何通过配置和定制来适应应用程序的特定需求。

DispatcherServlet initialization parameters

ParameterExplanation
contextClassClass that implements ConfigurableWebApplicationContext, to be instantiated and locally configured by this Servlet. By default, XmlWebApplicationContext is used.
contextConfigLocationString that is passed to the context instance (specified by contextClass) to indicate where context(s) can be found. The string consists potentially of multiple strings (using a comma as a delimiter) to support multiple contexts. In case of multiple context locations with beans that are defined twice, the latest location takes precedence.
namespaceNamespace of the WebApplicationContext. Defaults to [servlet-name]-servlet.

关于 DispatcherServlet 可配置参数的表格及其解释:

参数解释
contextClass实现了 ConfigurableWebApplicationContext 接口的类,将由此 Servlet 实例化并进行本地配置。默认情况下,使用 XmlWebApplicationContext。这个参数允许你指定用于创建 WebApplicationContext 的具体类。
contextConfigLocation传递给上述 contextClass 实例的字符串,指示可以找到上下文(或多个上下文)的位置。这个字符串可以是多个位置,使用逗号作为分隔符。在多个上下文位置的情况下,如果有重复定义的 bean,则以最后一个位置为准。这个参数允许你指定上下文配置文件的位置。
namespaceWebApplicationContext 的命名空间。默认为 [servlet-name]-servlet。这个参数影响 Servlet 创建的 ApplicationContext 的命名空间,用于在 Servlet 容器中唯一标识 ApplicationContext。

这些参数允许你在 web.xml 文件中通过 init-param 元素为单个 DispatcherServlet 实例进行定制配置。通过配置这些参数,你可以控制 DispatcherServlet 如何实例化和配置其关联的 WebApplicationContext,以满足特定应用程序的需求。

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

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

相关文章

程序的控制结构——if-else语句(双分支结构)【互三互三】

目录 &#x1f341; 引言 &#x1f341;if-else语句&#xff08;双分支结构&#xff09; &#x1f449;格式1&#xff1a; &#x1f449;功能&#xff1a; &#x1f449;程序设计风格提示&#xff1a; &#x1f449;例题 &#x1f449;格式2&#xff1a; &#x1f449;…

Monaco 使用 ColorProvider

Manco 中可以使用调色板对色值进行修改&#xff0c;首先看一下调色版效果。 调色板是 Monaco-Editor 中一个特别的组件&#xff0c;通过两个方法实现呼出调色板&#xff0c;provideColorPresentations 显示调色窗口&#xff0c;provideDocumentColors 监听页面的变更&#xff0…

如何将libwebsockets库编译为x86架构

在之前的文章中&#xff0c;我们已经详细介绍了如何交叉编译libwebsockets并将其部署到ELF 1开发板上。然而在调试阶段&#xff0c;发现将libwebsockets在Ubuntu环境下编译为x86架构可能更为方便和高效。 通过在主机环境中编译运用x86架构下的libwebsockets库&#xff0c;可以…

阿里ChatSDK使用,开箱即用聊天框

介绍&#xff1a; 效果&#xff1a;智能助理 ChatSDK&#xff0c;是在ChatUI的基础上&#xff0c;结合阿里云智能客服的最佳实践&#xff0c;沉淀和总结出来的一个开箱即用的&#xff0c;可快速搭建智能对话机器人的框架。它简单易上手&#xff0c;通过简单的配置就能搭建出对…

公益快报 | 中科亿海微以企业奖学金为纽带,深化校企合作

近日&#xff0c;为回报母校、激励湖南大学机器人视觉感知与控制技术国家工程研究中心广大学生&#xff0c;中科亿海微电子科技&#xff08;苏州&#xff09;有限公司&#xff08;简称“中科亿海微”&#xff09;捐赠设立企业奖学金。此项奖学金的设立标志着校企合作迈向全方位…

实现组件存储 WinSxS 文件夹解析

目录 背景 目录名的组成 解析目录结构 更新&总结 文章出处链接&#xff1a;[https://blog.csdn.net/qq_59075481/article/details/140385969]. 背景 WinSxS 文件夹位于 Windows 文件夹中&#xff0c;例如 C: \Windows\WinSxS。它是 Windows 组件存储文件的位置。 Wind…

idea启动vue项目一直卡死在51%,问题分析及其如何解决

如果你的项目也一直卡在百分之几十&#xff0c;你可以参考下面的方法&#xff0c;试一试能否解决 问题描述&#xff1a; 通过在idea终端中输入命令 npm run serve 启动vue项目&#xff0c;启动进程一直卡在51% 如何解决&#xff1a; 检查 < template > 标签中的html内容…

深度学习中的超参管理方法:argparse模块

在深度学习方法中我们不可避免地会遇到大量超参数如&#xff08;batch_size、learning_rate等&#xff09;。不同的超参数组合可以得到不同的训练/测试结果。所以在训练和测试过程中我们需要不断调整超参数获得理想的结果&#xff08;炼丹&#xff09;&#xff0c;如果每一次去…

【Windows】硬链接和软链接(OneDrive同步指定目录?)

文章目录 一、场景带入二、Windows下的硬链接和软链接2.1 硬链接&#xff08;Hard Link&#xff09;2.2 软链接&#xff08;符号链接&#xff0c;Symbolic Link&#xff09;2.3 软链接和快捷方式2.4 应用场景 三、OneDrive中的应用3.1 错误姿势3.2 好像可行的尝试3.3 合理的解决…

智能猫砂盆两种类型怎么选?深度剖析热门前三的品牌!

应该也有很多铲屎官像我一样&#xff0c;第一个入手的通常都是封闭式的智能猫砂盆&#xff0c;自动清洁是很好用&#xff0c;但问题也随之而来。有时候滚筒式的智能猫砂盆会在清洁过程中将砂团摔碎&#xff0c;导致粪便暴露出来产生臭味&#xff0c;这样我们回来不得不又再次进…

LangChain框架详解

LangChain框架详解 LangChain是一个基于语言模型开发应用程序的强大框架&#xff0c;旨在帮助开发人员简化与大模型交互、数据检索以及将不同功能模块串联起来以完成复杂任务的过程。它提供了一套丰富的工具、组件和接口&#xff0c;使开发人员能够轻松构建上下文感知和具备逻…

基于stm32+小程序开发智能家居门禁系统-硬件-软件实现

视频演示&#xff1a; 基于stm32智能家居门禁系统小程序开发项目 视频还有添加删除卡号&#xff0c;添加删除指纹&#xff0c;关闭继电器电源等没有演示。 代码Git&#xff1a; https://github.com/Abear6666/stm32lock 总体功能&#xff1a; 本门禁系统主要解锁功能分别为卡…

冲积图(alluvial plot)展示竞争性内源RNA(ceRNA)网络

导读&#xff1a; 用冲积图展示ceRNA网络可以更好地查看竞争和吸附关系&#xff0c;让静态的图&#xff0c;“流动”起来。 冲积图简介 Alluvial plot&#xff08;冲积图&#xff09;是一种流程图&#xff0c;最初设计用于展示网络结构随时间的变化。这种图表特别适用于展示…

06_TypeScript 中的函数

TypeScript 中的函数 一、函数的定义es5 定义函数的方法TypeScript 定义函数的方法ts 中定义方法传参 二、可选参数三、默认参数&#xff08;跟可选参数一样&#xff09;四、剩余参数&#xff08;三点运算符的应用&#xff09;五、函数重载六、箭头函数 es6 一、函数的定义 es…

【持续集成_05课_Linux部署SonarQube及结合开发项目部署】

一、Linux下安装SonarQube 1、安装sonarQube 前置条件&#xff1a;sonarQube不能使用root账号进行启动&#xff0c;所以需要创建普通用户及 其用户组 1&#xff09;创建组 2&#xff09;添加用户、组名、密码 3&#xff09;CMD上传qube文件-不能传到home路径下哦 4&#xff09…

王牌站士Ⅳ--矢量数据库对 RAG 效率的影响

前言 近年来&#xff0c;检索增强生成 (RAG) 模型越来越受欢迎。RAG 模型利用大型神经网络以及外部知识源的检索机制。这使得模型拥有的知识比其内部存储的更多&#xff0c;从而使其能够为广泛的主题和领域生成高质量的输出。 影响 RAG 模型性能的关键因素之一是从外部源检索相…

【启明智显分享】ESP32-S3 4.3寸触摸串口屏HMI应用方案:WIFI/蓝牙无线通信助力烘干设备实现远程遥控

技术不断进步&#xff0c;人们对烘干设备的美观度、功能多样性提出更高要求&#xff0c;传统的数码管显示、按键式控制已经无法满足客户的需求。用智能屏替代传统的数码管可以很好的解决这个问题&#xff0c;为用户带来更好的人机交互体验。 基于此&#xff0c;启明智显提出将乐…

C++基础(十八):继承(重点)

各位看官&#xff0c;大家好&#xff01;今天我们将探讨C中的三大特性之一&#xff1a;继承。继承是一种面向对象编程的重要概念&#xff0c;它允许我们通过创建新的类&#xff0c;从而复用和扩展现有类的功能。通过继承&#xff0c;我们不仅能够提高代码的可重用性和可维护性&…

9.5 栅格图层符号化多波段彩色渲染

文章目录 前言多波段彩色渲染QGis设置为多波段彩色二次开发代码实现多波段彩色 总结 前言 介绍栅格图层数据渲染之多波段彩色渲染说明&#xff1a;文章中的示例代码均来自开源项目qgis_cpp_api_apps 多波段彩色渲染 以“3420C_2010_327_RGB_LATLNG.tif”数据为例&#xff0c…

常见条件控制算法流程图

内容讲解&#xff1a;流程控制[if…else…(if…elif…else…),while,for] 常见条件控制算法流程图高清图