08SpringBoot高级--自动化配置

目录

Spring Boot Starter 依赖管理解释

一、核心概念

二、工作原理

依赖传递:

自动配置:

版本管理:

三、核心流程

四、常用 Starter 示例

五、自定义 Starter 步骤

创建配置类:

配置属性:

注册自动配置:在 META-INF/spring.factories 中添加:

打包发布:创建 Maven 项目并发布到仓库,其他项目可直接引用。

六、优势与注意事项

优势:

注意事项:

@Configuration 注解的底层原理与工作机制

一、核心概念

二、核心特性

1. 声明 Bean 定义

2. 支持 Bean 依赖注入

3. 实现 Bean 作用域

三、底层工作机制

1. 配置类的 CGLIB 增强

2. Bean 方法的拦截处理

3. 与 @Component 注解的区别

四、关键注解组合

1. @Import 导入其他配置类

2. @PropertySource 加载外部配置

3. @Profile 实现环境配置

五、最佳实践

1. 配置类设计原则

2. Bean 命名策略

3. 生命周期管理

六、注意事项

1. 代理限制

2. 循环依赖问题

3. 性能考虑

@EnableAutoConfiguration 自动配置注解底层原理解释

核心作用

核心机制

自动配置类发现

条件化配置(Conditional)

关键流程简化

与其他注解的配合

简单示例

核心优势

Spring Boot 自动化配置原理:按条件开启自动配置类和配置项 

一、自动化配置的核心机制:条件注解与自动发现

1. 自动配置类的加载入口

2. 条件注解:自动配置的 “开关”

二、按条件开启自动配置的具体流程

1. 主配置类的条件判断

2. 配置项的条件化开启

三、用户如何干预自动配置?

四、自动化配置的优先级与加载顺序

自动配置类的加载顺序

用户配置 vs 自动配置

五、总结:条件化配置的核心价值


Spring Boot Starter 依赖管理解释

一、核心概念

Starter 是 Spring Boot 提供的一种依赖管理方式,通过一个依赖就能引入某个功能所需的所有组件,避免手动配置大量依赖的麻烦。


二、工作原理

  1. 依赖传递
    • 例如引入 spring-boot-starter-web 会自动包含:
      • Spring MVC
      • Tomcat 服务器
      • JSON 处理库
      • 其他必要组件
  2. 自动配置
    • 每个 Starter 都关联一个或多个自动配置类
    • 自动配置类根据条件(如类是否存在)自动创建 Bean
    • 例如 WebMvcAutoConfiguration 会自动配置 Spring MVC
  3. 版本管理
    • Spring Boot 通过 spring-boot-dependencies 统一管理所有依赖版本
    • 开发者无需指定版本号,避免版本冲突

三、核心流程


四、常用 Starter 示例

Starter 名称功能描述
spring-boot-starter-web创建 Web 应用(REST、MVC)
spring-boot-starter-data-jpaJPA 数据库访问
spring-boot-starter-security安全认证与授权
spring-boot-starter-test测试工具集(JUnit、Mockito 等)
spring-boot-starter-validationBean 验证(JSR-303)

五、自定义 Starter 步骤

  1. 创建配置类
    @Configuration
    public class MyAutoConfiguration {@Beanpublic MyService myService() {return new MyServiceImpl();}
    }
    
  2. 配置属性
    @ConfigurationProperties(prefix = "my.service")
    public class MyProperties {private String name = "default";// getter/setter
    }
    
  3. 注册自动配置
    在 META-INF/spring.factories 中添加:
    org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
    com.example.MyAutoConfiguration
    
  4. 打包发布:
    创建 Maven 项目并发布到仓库,其他项目可直接引用。

六、优势与注意事项

  • 优势
    • 快速搭建项目
    • 减少配置错误
    • 统一依赖版本
    • 易于扩展
  • 注意事项
    • 依赖冲突时使用 mvn dependency:tree 分析
    • 自动配置不生效时检查条件注解
    • 自定义 Starter 需遵循命名规范(*-spring-boot-starter

通过 Starter 机制,Spring Boot 实现了 "约定大于配置" 的理念,让开发者可以更专注于业务逻辑,而不是框架配置。


@Configuration 注解的底层原理与工作机制

一、核心概念

@Configuration 是 Spring 框架中用于定义配置类的注解,它允许将 Spring Bean 的定义以 Java 代码的形式组织,替代传统的 XML 配置文件。

配置类本质上是一个被 Spring 容器管理的 Bean,其中使用 @Bean 注解的方法会被容器拦截并用于创建和管理 Bean 实例。


二、核心特性

1. 声明 Bean 定义
@Configuration
public class AppConfig {@Beanpublic DataSource dataSource() {return new DriverManagerDataSource("jdbc:mysql://localhost:3306/mydb", "user", "pass");}
}
  • @Configuration 标记的类会被 Spring 容器识别为配置类
  • @Bean 注解的方法返回的对象会被注册为 Spring Bean
2. 支持 Bean 依赖注入
@Configuration
public class AppConfig {@Beanpublic UserService userService() {return new UserServiceImpl(userRepository()); // 依赖注入}@Beanpublic UserRepository userRepository() {return new JdbcUserRepository(dataSource()); // 依赖注入}@Beanpublic DataSource dataSource() {return new DriverManagerDataSource();}
}
3. 实现 Bean 作用域
@Configuration
public class AppConfig {@Bean@Scope("prototype") // 原型作用域,每次请求创建新实例public RequestHandler requestHandler() {return new RequestHandler();}
}

三、底层工作机制

1. 配置类的 CGLIB 增强

Spring 会通过 CGLIB 动态代理技术为 @Configuration 类创建子类:

  • 拦截 @Bean 方法的调用,确保 Bean 的单例性
  • 实现方法间的依赖调用(如 userService() 调用 userRepository()
// 伪代码展示 CGLIB 增强效果
public class AppConfig$$EnhancerBySpringCGLIB extends AppConfig {private final Map<String, Object> singletons = new ConcurrentHashMap<>();@Overridepublic UserRepository userRepository() {if (!singletons.containsKey("userRepository")) {singletons.put("userRepository", super.userRepository());}return (UserRepository) singletons.get("userRepository");}
}
2. Bean 方法的拦截处理
  • 当 @Bean 方法被调用时,CGLIB 代理会检查该 Bean 是否已创建
  • 如果已创建,则返回缓存的实例(确保单例性)
  • 如果未创建,则调用原始方法创建新实例
3. 与 @Component 注解的区别
特性@Configuration@Component
CGLIB 增强
Bean 方法拦截支持(确保单例调用)不支持(每次调用创建新实例)
推荐使用场景定义应用配置和 Bean 关系普通组件(如 Service、Repository)

四、关键注解组合

1. @Import 导入其他配置类
@Configuration
@Import({DataSourceConfig.class, SecurityConfig.class})
public class AppConfig {// 合并多个配置类
}
2. @PropertySource 加载外部配置
@Configuration
@PropertySource("classpath:application.properties")
public class AppConfig {@Value("${db.url}")private String dbUrl;@Beanpublic DataSource dataSource() {return new DriverManagerDataSource(dbUrl, "user", "pass");}
}
3. @Profile 实现环境配置
@Configuration
@Profile("dev")
public class DevConfig {@Beanpublic DataSource dataSource() {return new DriverManagerDataSource("jdbc:mysql://devdb:3306/mydb", "dev", "devpass");}
}

五、最佳实践

1. 配置类设计原则
  • 按功能模块化组织配置类(如 DataSourceConfigWebConfig
  • 避免配置类过于庞大,保持单一职责
  • 使用 @Import 或 @ComponentScan 组合多个配置类
2. Bean 命名策略
@Bean("customDataSource") // 显式指定 Bean 名称
public DataSource dataSource() {return new DriverManagerDataSource();
}
3. 生命周期管理
@Configuration
public class AppConfig {@Bean(initMethod = "init", destroyMethod = "cleanup")public ConnectionFactory connectionFactory() {return new JmsConnectionFactory();}
}

六、注意事项

1. 代理限制
  • @Configuration 类必须是可被继承的(不能是 final 类)
  • @Bean 方法必须是可重写的(不能是 private 或 final)
2. 循环依赖问题
  • 避免配置类之间的循环依赖
  • 使用构造器注入时需特别注意
3. 性能考虑
  • CGLIB 代理会带来一定性能开销,但通常可忽略不计
  • 对于性能敏感场景,可考虑使用 @Component 替代

通过 @Configuration 注解,Spring 实现了基于 Java 的配置方式,结合 CGLIB 代理技术确保了 Bean 管理的高效性和灵活性,使开发者能够以更优雅的方式组织应用配置。


@EnableAutoConfiguration 自动配置注解底层原理解释

核心作用

@EnableAutoConfiguration 是 Spring Boot 实现自动化配置的核心注解,作用是根据项目依赖自动激活对应的配置类,避免手动编写大量配置。

核心机制

  1. 自动配置类发现
    • 启动时扫描 META-INF/spring.factories 文件,读取 EnableAutoConfiguration 对应的配置类列表。
    • 例如,引入 spring-boot-starter-web 时,会自动加载 WebMvcAutoConfiguration 等与 Web 相关的配置类。
  2. 条件化配置(Conditional)
    • 配置类通过 @Conditional 系列注解(如 @ConditionalOnClass@ConditionalOnMissingBean)判断是否生效。
    • 例:若类路径存在 Tomcat 相关类且无自定义 ServletContainerFactory,才激活 Web 容器配置。

关键流程简化

  1. 注解触发@EnableAutoConfiguration 触发 AutoConfigurationImportSelector 类加载自动配置类。
  2. 过滤筛选:根据条件注解排除不符合当前环境的配置类。
  3. 注入容器:将符合条件的配置类注册到 Spring 容器,完成 Bean 自动配置。

与其他注解的配合

  • 常与 @SpringBootApplication(组合了 @EnableAutoConfiguration@ComponentScan@Configuration)一起使用。
  • 通过 @AutoConfigureAfter / @AutoConfigureBefore 控制配置类加载顺序。

简单示例

引入 spring-boot-starter-data-jpa 后,@EnableAutoConfiguration 会自动配置:

  • JPA 实体管理器(EntityManagerFactory
  • 数据库连接池(如 HikariCP)
  • 事务管理器(PlatformTransactionManager

核心优势

  • 零配置启动依赖即配置,减少手动编写 XML 或 Java 配置类的工作量。
  • 可扩展性:通过 @Conditional 自定义条件,或通过 spring.factories 扩展自动配置逻辑。

Spring Boot 自动化配置原理:按条件开启自动配置类和配置项 

一、自动化配置的核心机制:条件注解与自动发现

Spring Boot 自动化配置的本质是通过 条件注解 和 自动配置类发现机制,实现 “按需加载” 配置,避免资源浪费。其核心流程如下:

1. 自动配置类的加载入口
  • spring.factories 配置文件
    Spring Boot 启动时,会扫描类路径下的 META-INF/spring.factories 文件,从中读取 org.springframework.boot.autoconfigure.EnableAutoConfiguration 对应的配置类列表(如 WebMvcAutoConfigurationDataSourceAutoConfiguration 等)。

    • 例如,spring-boot-autoconfigure 模块的 spring.factories 中定义了大量自动配置类:
      org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
      org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration,\
      org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration,\
      # 其他配置类...
      
  • @EnableAutoConfiguration 注解触发
    Spring Boot 启动类上的 @EnableAutoConfiguration 会通过 SpringFactoriesLoader 加载上述配置类,将其纳入 Spring 容器管理。

2. 条件注解:自动配置的 “开关”

自动配置类或配置项是否生效,由 @Conditional 及其派生注解决定。这些注解会根据运行时条件(如类是否存在、Bean 是否存在、属性是否配置等)判断是否加载配置。常见条件注解包括:

注解生效条件示例场景
@ConditionalOnClass类路径中存在指定类当存在 javax.servlet.Servlet 时,加载 Web 相关配置
@ConditionalOnMissingClass类路径中不存在指定类避免与非标准类冲突时使用
@ConditionalOnBean容器中存在指定类型的 Bean当存在自定义 DataSource 时,跳过数据源自动配置
@ConditionalOnMissingBean容器中不存在指定类型的 Bean当无自定义 WebMvcConfigurer 时,加载默认 MVC 配置
@ConditionalOnProperty配置文件中存在指定属性且值符合条件当 spring.datasource.enabled=true 时,加载数据源配置
@ConditionalOnResource类路径中存在指定资源文件当存在 application.yml 时加载特定配置
@ConditionalOnWebApplication当前为 Web 应用(Servlet 或 Reactive)仅在 Web 项目中加载 MVC 配置

二、按条件开启自动配置的具体流程

以 WebMvcAutoConfiguration(MVC 自动配置类)为例,看条件注解如何控制其生效:

1. 主配置类的条件判断
@Configuration
@ConditionalOnWebApplication(type = ConditionalOnWebApplication.Type.SERVLET)
@ConditionalOnClass({ Servlet.class, DispatcherServlet.class, WebMvcConfigurer.class })
@ConditionalOnMissingBean(WebMvcConfigurationSupport.class)
@AutoConfigureOrder(Ordered.HIGHEST_PRECEDENCE + 10)
@AutoConfigureAfter({ DispatcherServletAutoConfiguration.class, TaskExecutionAutoConfiguration.class,ValidationAutoConfiguration.class })
public class WebMvcAutoConfiguration {// 配置内容...
}
  • @ConditionalOnWebApplication:确保项目是 Servlet 类型的 Web 应用(非 Reactive)。
  • @ConditionalOnClass:检查类路径中存在 ServletDispatcherServlet 等 Web 相关类。
  • @ConditionalOnMissingBean:当容器中没有用户自定义的 WebMvcConfigurationSupport 时,才生效(若用户自定义了 MVC 配置,自动配置会被覆盖)。
2. 配置项的条件化开启

自动配置类内部的具体 Bean 定义也会通过条件注解控制,例如:

@Bean
@ConditionalOnMissingBean
public InternalResourceViewResolver defaultViewResolver() {// 默认视图解析器配置...
}
  • @ConditionalOnMissingBean 表示当容器中没有自定的 InternalResourceViewResolver 时,才创建默认视图解析器。

三、用户如何干预自动配置?

  1. 通过配置文件禁用自动配置
    在 application.properties 中使用 spring.autoconfigure.exclude 属性排除特定自动配置类:

    # 禁用 WebMvc 自动配置
    spring.autoconfigure.exclude=org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration
    
  2. 通过条件注解自定义配置
    用户可在自定义配置类中使用条件注解,覆盖自动配置的逻辑:

    @Configuration
    @ConditionalOnProperty(name = "myapp.use-custom-mvc", havingValue = "true")
    public class CustomMvcConfiguration {// 自定义 MVC 配置,会覆盖自动配置
    }
    
  3. 通过 @Conditional 扩展条件逻辑
    自定义条件类(实现 Condition 接口),实现更复杂的条件判断:

    public class MyCondition implements Condition {@Overridepublic boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {// 自定义条件逻辑(如检查环境变量、系统属性等)return context.getEnvironment().getProperty("myapp.enabled").equals("true");}
    }// 使用自定义条件
    @Configuration
    @Conditional(MyCondition.class)
    public class MySpecialConfiguration {
    }
    

四、自动化配置的优先级与加载顺序

  1. 自动配置类的加载顺序
    • 通过 @AutoConfigureOrder 或 @Order 注解控制加载顺序,数值越小优先级越高。
    • 例如,WebMvcAutoConfiguration 会在 DispatcherServletAutoConfiguration 之后加载,确保 Servlet 容器已初始化
  2. 用户配置 vs 自动配置
    • 用户自定义的 Bean 或配置类(如添加 @Component 或 @Configuration 的类)会优先于自动配置,体现 “约定优于配置,但配置可覆盖约定” 的原则。

五、总结:条件化配置的核心价值

Spring Boot 的自动化配置通过条件注解实现了 “智能加载”:

  • 避免资源浪费:仅在需要时加载配置(如非 Web 项目不会加载 MVC 配置)。
  • 灵活扩展性:用户可通过简单配置或注解覆盖自动配置,无需修改框架源码。
  • 降低使用门槛:开发者无需手动配置大量 Bean,框架自动处理依赖关系,聚焦业务逻辑。

理解条件注解的工作原理,有助于在开发中精准控制配置的生效条件,解决自动配置与自定义配置的冲突问题。

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

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

相关文章

基于cornerstone3D的dicom影像浏览器 第二十四章 显示方位、坐标系、vr轮廓线

系列文章目录 文章目录 系列文章目录前言一、工具栏修改二、切片窗口显示方位文字1. 修改mprvr.js&#xff0c;添加函数getOrientationMarkers2. 修改DisplayerArea3D.vue 三、vr窗口显示坐标系1. 修改mprvr.js 添加OrientationMarkerTool2. view3d.vue中响应工具栏事件3. 修改…

【C/C++】线程局部存储:原理与应用详解

文章目录 1 基础概念1.1 定义1.2 初始化规则1.3 全局TLS vs 局部静态TLS 2 内存布局2.1 实现机制2.2 典型内存结构2.3 性能特点 3 使用场景/用途3.1 场景3.2 用途 4 注意事项5 对比其他技术6 示例代码7 建议7.1 调试7.2 优化 8 学习资料9 总结 在 C 多线程编程中&#xff0c;线…

【图像大模型】IP-Adapter:图像提示适配器的技术解析与实践指南

IP-Adapter&#xff1a;图像提示适配器的技术解析与实践指南 一、项目背景与技术价值1.1 图像生成中的个性化控制需求1.2 IP-Adapter的核心贡献 二、技术原理深度解析2.1 整体架构设计2.2 图像特征编码器2.3 训练策略 三、项目部署与实战指南3.1 环境配置3.2 模型下载3.3 基础生…

MySQL-5.7 修改密码和连接访问权限

一、MySQL-5.7 修改密码和连接权限设置 修改密码语法 注意&#xff1a;rootlocalhost 和 root192.168.56.% 是两个不同的用户。在修改密码时&#xff0c;两个用户的密码是各自分别保存&#xff0c;如果两个用户密码设置不一样则登陆时注意登陆密码 GRANT ALL PRIVILEGES ON …

Linux基本指令篇 —— touch指令

touch是Linux和Unix系统中一个非常基础但实用的命令&#xff0c;主要用于操作文件的时间戳和创建空文件。下面我将详细介绍这个命令的用法和功能。 目录 一、基本功能 1. 创建空文件 2. 同时创建多个文件 3. 创建带有空格的文件名&#xff08;需要使用引号&#xff09; 二、…

mysql explain使用

文章目录 type 访问类型性能高到低多注意type: index 出现的场景 key 实际使用的索引Extra 额外信息其他字段 通过 EXPLAIN 你可以知道&#xff1a;如是否使用索引、扫描多少行、是否需要排序或临时表 EXPLAIN 三板斧&#xff08;type、key、Extra&#xff09; 例子&#xff1…

JMeter-SSE响应数据自动化

结构图 背景&#xff1a; 需要写一个JMeter脚本来进行自动化测试&#xff0c;主要是通过接口调用一些东西&#xff0c;同时要对响应的数据进行处理&#xff0c;包括不限于错误信息的输出。 1.SSE(摘录) SSE&#xff08;Server-Sent Events&#xff09;是一种基于HTTP协议、允许…

<<运算符重载 和 c_str() 的区别和联系

例题 文章开始之前我们看下以下代码&#xff0c;你能精准的说出正确的输出结果并知道其原理吗&#xff1f; void test() {string s1("hello world");cout << s1 << endl;//cout << s1.c_str() << endl;//const char* p1 "xxxx"…

python web flask专题-Flask入门指南:从安装到核心功能详解

Flask入门指南&#xff1a;从安装到核心功能详解 Flask作为Python最流行的轻量级Web框架之一&#xff0c;以其简洁灵活的特性广受开发者喜爱。本文将带你从零开始学习Flask&#xff0c;涵盖安装配置、项目结构、应用实例、路由系统以及请求响应处理等核心知识点。 1. Flask安…

一种C# 的SM4 的 加解密的实现,一般用于医疗或者支付

一种C# 的SM4 的 加解密的实现 一般用于医疗或者支付 加密 string cipherText SM4Helper.Encrypt_test(data, key); public static string Encrypt_test(string plainText, string key) { byte[] keyBytes Encoding.ASCII.GetBytes(key); byte[] input…

“轩辕杯“云盾砺剑CTF挑战赛 Web wp

文章目录 ezflaskezjsezrceezssrf1.0签到ezsql1.0ez_web1非预期预期解 ezflask ssti, 过滤了一些关键词, 绕一下就行 name{{url_for["__globals__"]["__builtins__"]["eval"]("__tropmi__"[::-1])(os)["po""pen"…

Matlab快速上手五十六:详解符号运算里假设的用法,通过假设可以设置符号变量的取值范围,也可以通过假设设置变量属于集合:整数、正数和实数等

1.符号变量中假设的概念 在符号数学工具箱中&#xff0c;符号变量默认范围是全体复数&#xff0c;也就是说&#xff0c;符号运算是在全体复数域进行的&#xff0c;若需要运算中&#xff0c;不使用全体复数域&#xff0c;可以为变量设定取值范围&#xff0c;这就用到了假设&…

【python实用小脚本-79】[HR转型]Excel难民到数据工程师|用Python实现CSV秒转JSON(附HRIS系统对接方案)

场景故事&#xff1a;从手动复制粘贴到自动化数据流转 "Kelly&#xff0c;我们需要把3000名员工的考勤数据导入新HR系统&#xff0c;今天能完成吗&#xff1f;"去年这个时候&#xff0c;作为HRIS项目负责人的我&#xff0c;面对这个需求时第一反应是打开Excel开始手…

数据透视:水安 B 证如何影响水利企业的生存指数?

某大数据公司提取了 3000 家水利企业的经营数据&#xff0c;一组关联分析令人震惊&#xff1a;B 证配备率与企业利润率的相关系数达 0.67—— 这意味着持证率每提升 10%&#xff0c;企业利润率平均提高 4.2 个百分点。当我们用数据解剖这本红本本&#xff0c;会发现它像一根无形…

从零搭建上门做饭平台:高并发订单系统设计

你知道为什么聪明人都在抢着做上门做饭平台吗&#xff1f;因为这可能是餐饮行业最后一片蓝海&#xff01;传统餐饮还在为房租人工发愁时&#xff0c;上门私厨已经轻装上阵杀出重围。不需要门店租金&#xff0c;不用养服务员&#xff0c;厨师直接上门服务&#xff0c;成本直降60…

openpi π₀ 项目部署运行逻辑(四)——机器人主控程序 main.py — aloha_real

π₀ 机器人主控脚本都在 examples 中&#xff1a; 可以看到包含了多种类机器人适配 此笔记首先记录了 aloha_real 部分 aloha_real 中&#xff0c;main.py 是 openpi ALOHA 平台上“主控执行入口”&#xff0c;负责&#xff1a; 建立与推理服务器&#xff08;serve_policy.…

利用 Python 爬虫获取唯品会 VIP 商品详情:实战指南

在当今电商竞争激烈的环境中&#xff0c;VIP 商品往往是商家的核心竞争力所在。这些商品不仅代表着品牌的高端形象&#xff0c;更是吸引高价值客户的关键。因此&#xff0c;获取 VIP 商品的详细信息对于市场分析、竞品研究以及优化自身产品策略至关重要。Python 作为一种强大的…

鸿蒙桌面快捷方式开发

桌面快捷方式开发实战 [参考文档] (https://developer.huawei.com/consumer/cn/doc/best-practices/bpta-desktop-shortcuts) 在module.json5配置文件中的abilities标签下的metadata中设置resource属性值为$profile:shortcuts_config&#xff0c;指定应用的快捷方式配置文件&…

3分钟学会跨浏览器富文本编辑器开发:精准光标定位+内容插入(附完整代码)

一、痛点直击&#xff1a;传统编辑器的三大坑 作为前端开发&#xff0c;你是否遇到过以下灵魂拷问&#xff1f; ✅ 为什么Firefox光标能精准定位&#xff0c;IE却永远跳转到开头&#xff1f;✅ 图片上传后如何保证插入位置不偏移&#xff1f;✅ 跨浏览器兼容测试时&#xff0…

RK3562 Linux-5.10 内核HUSB311 Type-C 控制器芯片调试记录

硬件原理&#xff1a; 1. type C 接口&#xff1a; 1.1 HUSB311芯片&#xff0c; CC1和CC2 逻辑接到HUSB311 上面&#xff0c; 接I2C0组和USBCC_INT_L USBCC_INT_L 接到GPIO0_A6 做为CC的逻辑中断 1.2 TYPEC_DP/TYPEC_DM 接到ARM 端的USB3.0 OTG上面 1.2 TYPEC_RX1P/TYPEC…