当前位置: 首页 > news >正文

在java后端发送HTTPClient请求

简介

  • HttpClient
  • 遵循http协议的客户端编程工具包
  • 支持最新的http协议

在这里插入图片描述
在这里插入图片描述

部分依赖自动传递依赖了HttpClient的jar包

  • 明明项目中没有引入 HttpClient 的Maven坐标,但是却可以直接使用HttpClient
  • 原因是:阿里云的sdk依赖中传递依赖了HttpClient的jar包

在这里插入图片描述

在这里插入图片描述

发送get请求

    @Testpublic void testGet() {// 创建HttpGet对象HttpGet httpGet = new HttpGet("http://localhost:8080/user/shop/status");// 创建HttpClient对象 用于发送请求// try-with-resources 语法 需要关闭的资源分别是 httpClient responsetry (CloseableHttpClient httpClient = HttpClients.createDefault();CloseableHttpResponse response = httpClient.execute(httpGet)) {// 获取响应状态码int statusCode = response.getStatusLine().getStatusCode();System.out.println("响应状态码:" + statusCode); //响应状态码:200// 获取响应数据HttpEntity entity = response.getEntity();String result = EntityUtils.toString(entity);System.out.println("响应数据:" + result); // 响应数据:{"code":1,"msg":null,"data":1}} catch (IOException e) {log.error("请求失败", e);e.printStackTrace();}}

发送post请求

    /*** 测试HttpClient 发送post请求 需要提前启动项目 不然请求不到*/@Testpublic void testPost() {// 创建HttpPost对象HttpPost httpPost = new HttpPost("http://localhost:8080/admin/employee/login");// 这个请求是有请求体的// 使用JsonObject构建请求体  更加高效简洁JsonObject jsonObject = new JsonObject();jsonObject.addProperty("username", "admin");jsonObject.addProperty("password", "123456");// 将json对象转为字符串 并设置编码格式 设置传输的数据格式 使用构造器和set方法都是可以设置的StringEntity stringEntity = null;try {stringEntity = new StringEntity(jsonObject.toString());stringEntity.setContentEncoding("UTF-8");stringEntity.setContentType("application/json");} catch (UnsupportedEncodingException e) {throw new RuntimeException(e);}// 设置请求体httpPost.setEntity(stringEntity);// 创建HttpClient对象 用于发送请求// try-with-resources 语法 需要关闭的资源分别是 httpClient responsetry (CloseableHttpClient httpClient = HttpClients.createDefault();CloseableHttpResponse response = httpClient.execute(httpPost)) {// 获取响应状态码int statusCode = response.getStatusLine().getStatusCode();System.out.println("响应状态码:" + statusCode); //响应状态码:200// 获取响应数据HttpEntity entity = response.getEntity();String result = EntityUtils.toString(entity);System.out.println("响应数据:" + result); // 响应数据:{"code":1,"msg":null,"data":{"id":1,"userName":"admin","name":"管理员","token":"eyJhbGciOiJIUzI1NiJ9.eyJlbXBJZCI6MSwiZXhwIjoxNzI4MzgwOTk5fQ.Rm7UWZbDEU_06DJLfegcP31n-9g8AB-Jxa-49Zw-ttM"}}} catch (IOException e) {log.error("请求失败", e);e.printStackTrace();}}

工具类

分装了一个工具类

  • 发送get请求
  • 使用form表单发送post请求
  • 使用json对象发送post请求
package com.sky.utils;import com.alibaba.fastjson.JSONObject;
import lombok.extern.slf4j.Slf4j;
import org.apache.http.NameValuePair;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.utils.URIBuilder;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;/*** Http工具类*/
@Slf4j
public class HttpClientUtil {static final int TIMEOUT_MSEC = 5 * 1000;public static final String UTF_8 = "utf-8";public static final String DEFAULT_CONTENT_TYPE = "application/json";public static final String LOG_ERR_TEMPLATE = "{}路径请求出错,错误详情如下";/*** 发送GET请求,返回字符串*/public static String doGet(String url, Map<String, String> paramMap) throws URISyntaxException, IOException {String result = "";try (CloseableHttpClient httpClient = HttpClients.createDefault()) {URIBuilder builder = new URIBuilder(url);if (paramMap != null) {for (String key : paramMap.keySet()) {builder.addParameter(key, paramMap.get(key));}}URI uri = builder.build();// 创建GET请求HttpGet httpGet = new HttpGet(uri);// 发送请求try (CloseableHttpResponse response = httpClient.execute(httpGet)) {// 判断响应状态if (response.getStatusLine().getStatusCode() == 200) {result = EntityUtils.toString(response.getEntity(), UTF_8);}}} catch (Exception e) {// 日志记录logErr(url);throw e;}return result;}/*** 发送GET请求,返回JSONObject*/public static JSONObject doGetJson(String url, Map<String, String> paramMap) throws URISyntaxException, IOException {JSONObject result = null;try (CloseableHttpClient httpClient = HttpClients.createDefault()) {URIBuilder builder = new URIBuilder(url);if (paramMap != null) {for (String key : paramMap.keySet()) {builder.addParameter(key, paramMap.get(key));}}URI uri = builder.build();// 创建GET请求HttpGet httpGet = new HttpGet(uri);// 发送请求try (CloseableHttpResponse response = httpClient.execute(httpGet)) {// 判断响应状态if (response.getStatusLine().getStatusCode() == 200) {String resultString = EntityUtils.toString(response.getEntity(), UTF_8);result = JSONObject.parseObject(resultString);}}} catch (Exception e) {logErr(url);throw e;}return result;}/*** 发送POST请求,返回字符串 表单请求*/public static String doPost(String url, Map<String, String> paramMap) throws IOException {String resultString = "";try (CloseableHttpClient httpClient = HttpClients.createDefault()) {// 创建Http Post请求HttpPost httpPost = new HttpPost(url);// 创建参数列表if (paramMap != null) {List<NameValuePair> paramList = new ArrayList<>();for (Map.Entry<String, String> param : paramMap.entrySet()) {paramList.add(new BasicNameValuePair(param.getKey(), param.getValue()));}// 模拟表单UrlEncodedFormEntity entity = new UrlEncodedFormEntity(paramList);httpPost.setEntity(entity);}httpPost.setConfig(builderRequestConfig());// 执行http请求try (CloseableHttpResponse response = httpClient.execute(httpPost)) {resultString = EntityUtils.toString(response.getEntity(), UTF_8);}} catch (Exception e) {logErr(url);throw e;}return resultString;}/*** 发送POST请求,返回JSONObject 表单请求*/public static JSONObject doPostJson(String url, Map<String, String> paramMap) throws IOException {JSONObject result = null;try (CloseableHttpClient httpClient = HttpClients.createDefault()) {// 创建Http Post请求HttpPost httpPost = new HttpPost(url);// 创建参数列表if (paramMap != null) {List<NameValuePair> paramList = new ArrayList<>();for (Map.Entry<String, String> param : paramMap.entrySet()) {paramList.add(new BasicNameValuePair(param.getKey(), param.getValue()));}// 模拟表单UrlEncodedFormEntity entity = new UrlEncodedFormEntity(paramList);httpPost.setEntity(entity);}httpPost.setConfig(builderRequestConfig());// 执行http请求try (CloseableHttpResponse response = httpClient.execute(httpPost)) {String resultString = EntityUtils.toString(response.getEntity(), UTF_8);result = JSONObject.parseObject(resultString);}} catch (Exception e) {logErr(url);throw e;}return result;}/*** 发送POST请求,JSON格式数据,返回字符串 json请求*/public static String doPost4Json(String url, Map<String, String> paramMap) throws IOException {String resultString = "";try (CloseableHttpClient httpClient = HttpClients.createDefault()) {HttpPost httpPost = new HttpPost(url);if (paramMap != null) {// 构造json格式数据JSONObject jsonObject = new JSONObject();for (Map.Entry<String, String> param : paramMap.entrySet()) {jsonObject.put(param.getKey(), param.getValue());}StringEntity entity = new StringEntity(jsonObject.toString(), UTF_8);// 设置请求编码entity.setContentEncoding(UTF_8);// 设置数据类型entity.setContentType(DEFAULT_CONTENT_TYPE);httpPost.setEntity(entity);}httpPost.setConfig(builderRequestConfig());// 执行http请求try (CloseableHttpResponse response = httpClient.execute(httpPost)) {resultString = EntityUtils.toString(response.getEntity(), UTF_8);}} catch (Exception e) {logErr(url);throw e;}return resultString;}/*** 发送POST请求,JSON格式数据,返回JSONObject json请求*/public static JSONObject doPost4JsonReturnJson(String url, Map<String, String> paramMap) throws IOException {JSONObject result = null;try (CloseableHttpClient httpClient = HttpClients.createDefault()) {HttpPost httpPost = new HttpPost(url);if (paramMap != null) {// 构造json格式数据JSONObject jsonObject = new JSONObject();for (Map.Entry<String, String> param : paramMap.entrySet()) {jsonObject.put(param.getKey(), param.getValue());}StringEntity entity = new StringEntity(jsonObject.toString(), UTF_8);// 设置请求编码entity.setContentEncoding(UTF_8);// 设置数据类型entity.setContentType(DEFAULT_CONTENT_TYPE);httpPost.setEntity(entity);}httpPost.setConfig(builderRequestConfig());// 执行http请求try (CloseableHttpResponse response = httpClient.execute(httpPost)) {String resultString = EntityUtils.toString(response.getEntity(), UTF_8);result = JSONObject.parseObject(resultString);}} catch (Exception e) {logErr(url);throw e;}return result;}private static RequestConfig builderRequestConfig() {return RequestConfig.custom().setConnectTimeout(TIMEOUT_MSEC).setConnectionRequestTimeout(TIMEOUT_MSEC).setSocketTimeout(TIMEOUT_MSEC).build();}/*** 日志报错* @param url 出错的URL*/private static void logErr(String url) {log.error(LOG_ERR_TEMPLATE, url);}
}

相关文章:

在java后端发送HTTPClient请求

简介 HttpClient遵循http协议的客户端编程工具包支持最新的http协议 部分依赖自动传递依赖了HttpClient的jar包 明明项目中没有引入 HttpClient 的Maven坐标&#xff0c;但是却可以直接使用HttpClient原因是&#xff1a;阿里云的sdk依赖中传递依赖了HttpClient的jar包 发送get请…...

【STM32单片机_(HAL库)】4-3-2【定时器TIM】测量按键按下时间1——编程实现捕获功能

测量按键按下时长思路 测量按键按下时间实验目的 使用定时器 2 通道 2 来捕获按键 &#xff08;按键接PA0&#xff09;按下时间&#xff0c;并通过串口打印。 计一个数的时间&#xff1a;1us&#xff0c;PSC71&#xff0c;ARR65535 下降沿捕获、输入通道 2 映射在 TI2 上、不分…...

MySQL:2059 - Authentication plugin ‘caching_sha2_password‘ cannot be loaded

关于MySQL 客户端在尝试连接到 MySQL 服务器时报错&#xff1a;“2059 - Authentication plugin caching_sha2_password cannot be loaded”&#xff0c;具体是由于 MySQL 服务器默认使用的 caching_sha2_password 认证插件无法加载或不被当前客户端支持。 错误原因 MySQL 8.0…...

【JavaSE】反射、枚举、lambda表达式

目录 反射反射相关类获取类中属性相关方法常用获得类相关的方法示例常用获得类中属性相关的方法示例获得类中注解相关的方法 反射优缺点 枚举常用方法优缺点 枚举与反射lambda表达式语法函数式接口简化规则使用示例变量捕获集合中的应用优缺点 反射 Java的反射&#xff08;refl…...

P3227 [HNOI2013] 切糕

题意: n ∗ m n*m n∗m的矩阵,每个点可以选择一个值 a i , j k a_{i,j}k ai,j​k,然后你能获得 w ( i , j , k ) w(i,j,k) w(i,j,k)的得分&#xff0c;但是相邻两点之间的差值有限制&#xff0c;让你求最大得分。 考虑最小割。 每个点 ( i , j ) (i,j) (i,j)弄出一条长为 R…...

超分服务的分量保存

分量说明 分量的概念主要是对于显卡解码&#xff0c;编码和网络传输而言&#xff0c;显卡可以同时进行几个线程&#xff0c;多个显卡可以分布式计算&#xff0c;对分量进行AI识别&#xff0c;比如我们有cuda的显卡&#xff0c;cuda的核心量可以分给不同的分片视频&#xff0c;第…...

Windows11系统下SkyWalking环境搭建教程

目录 前言SkyWalking简介SkyWalking下载Agent监控实现启动配置SkyWalking启动Java应用程序启动Elasticsearch安装总结 前言 本文为博主在项目环境搭建时记录的SkyWalking安装流程&#xff0c;希望对大家能够有所帮助&#xff0c;不足之处欢迎批评指正&#x1f91d;&#x1f91…...

前端BOM常用操作

BOM操作常用命令详解及代码案例 BOM&#xff08;Browser Object Model&#xff09;是浏览器对象模型&#xff0c;是浏览器提供的JavaScript操作浏览器的API。BOM提供了与网页无关的浏览器的功能对象&#xff0c;虽然没有正式的标准&#xff0c;但现代浏览器已经几乎实现了Java…...

【Go】-viper库的使用

目录 viper简介 viper使用 通过viper.Set设置值 读取配置文件说明 读取配置文件 读取多个配置文件 读取配置项的值 读取命令行的值 io.Reader中读取值 写配置文件 WriteConfig() 和 SafeWriteConfig() 区别: viper简介 配置管理解析库&#xff0c;是由大神 Steve Fr…...

JavaWeb酒店管理系统(详细版)

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…...

C++ | 定长内存池 | 对象池

文章目录 C | 定长内存池 | 对象池一、内存池的引入二、代码中的内存池实现 - ObjectPool类&#xff08;一&#xff09;整体结构&#xff08;二&#xff09;内存分配 - New函数&#xff08;三&#xff09;内存回收 - Delete函数 三、内存池在TreeNode示例中的性能测试演示四、脱…...

python画图|自制渐变柱状图

在前述学习过程中&#xff0c;我们已经通过官网学习了如何绘制渐变的柱状图及其背景。 掌握一门技能的最佳检验方式就是通过实战&#xff0c;因此&#xff0c;本文尝试做一些渐变设计。 前述学习记录可查看链接&#xff1a; Python画图|渐变背景-CSDN博客 【1】柱状图渐变 …...

基于RPA+BERT的文档辅助“悦读”系统 | OPENAIGC开发者大赛高校组AI创作力奖

在第二届拯救者杯OPENAIGC开发者大赛中&#xff0c;涌现出一批技术突出、创意卓越的作品。为了让这些优秀项目被更多人看到&#xff0c;我们特意开设了优秀作品报道专栏&#xff0c;旨在展示其独特之处和开发者的精彩故事。 无论您是技术专家还是爱好者&#xff0c;希望能带给…...

K8S部署流程

一、war打包镜像(survey,analytics,trac系统) 代码打包成war准备tomcat的server.xml文件&#xff0c;修改connector中8080端口为项目的端口 修改前&#xff1a; <Connector port"8080" protocol"HTTP/1.1"connectionTimeout"20000"redirect…...

DevExpress WinForms中文教程:Data Grid - 如何添加或删除行?

本教程介绍DevExpress WinForm的Data Grid控件UI元素和API&#xff0c;它们使您和最终用户能够添加或删除数据行。您将首选学习如何启用内置的数据导航器&#xff0c;然后学习如何使用Microsoft Outlook启发的New Item行添加新记录。最后教程将向您展示基本的API&#xff0c;它…...

u盘格式化后数据能恢复吗?2024年Top4恢复神器来帮忙

在这个电脑和手机满天飞的时代&#xff0c;U盘是我们用来存东西和传文件的得力助手&#xff0c;特别重要。但是&#xff0c;有时候U盘可能会不小心被格式化了&#xff0c;里面的重要文件就不见了。那么&#xff0c;U盘格式化后的数据还能恢复吗&#xff1f;当然可以。今天会告诉…...

深度学习·Argparse

Argparse 命令行选项、参数和子命令解析器 ArgumentParser 命令行传参数->解析参数->获得对应参数 初始化&#xff1a;parser argparse.ArgumentParser(descriptionxxx)添加命令行参数&#xff1a; parser.add_argument("--training_filepath", typestr, he…...

制造企业为何需要PLM系统?PLM系统解决方案对制造业重要性分析

制造企业为何需要PLM系统&#xff1f;PLM系统解决方案对制造业重要性分析 新华社9月23日消息&#xff0c;据全国组织机构统一社会信用代码数据服务中心统计&#xff0c;我国制造业企业总量突破600万家。数据显示&#xff0c;2024年1至8月&#xff0c;我国制造业企业数量呈现稳…...

http协议中的header详细讲解

http协议中的header详细讲解 HTTP 协议和 TCP/IP 协议族内的其他众多的协议相同&#xff0c;用于客户端和服务器之间的通信。 请求访问文本或图像等资源的一端称为客户端&#xff0c;而提供资源响应的一端称为服务器端。 HTTP 协议规定&#xff0c;请求从客户端发出&#xf…...

探索后量子安全:基于格加密技术的未来密码学展望

在信息技术日新月异的今天&#xff0c;量子计算作为下一代计算技术的代表&#xff0c;正逐步从理论走向实践。量子计算的出现对现有的加密体系构成了严重威胁&#xff0c;尤其是基于大数分解和离散对数难题的传统密码学&#xff08;如RSA和Diffie-Hellman协议&#xff09;。为了…...

WPF之UI进阶--完整了解wpf的控件和布局容器及应用

前面三篇有关WPF的基础介绍&#xff0c;分别介绍了wpf与winform的异同&#xff0c;wpf的事件生成和使用以及数据绑定。但我们还缺乏一副好的“皮囊”&#xff0c;所以从这篇开始我们来开始学习wpf的UI相关的内容&#xff0c;首当其冲的就是布局容器。 其实我们知道&#xff0c;…...

unity一键注释日志和反注释日志

开发背景&#xff1a;游戏中日志也是很大的开销&#xff0c;虽然有些日志不打印但是毕竟有字符串的开销&#xff0c;甚至有字符串拼接的开销&#xff0c;有些还有装箱和拆箱的开销&#xff0c;比如Debug.Log(1) 这种 因此需要注释掉&#xff0c;当然还需要提供反注释的功能&am…...

VBA数据库解决方案第十五讲:Recordset集合中单个数据的精确处理

《VBA数据库解决方案》教程&#xff08;版权10090845&#xff09;是我推出的第二套教程&#xff0c;目前已经是第二版修订了。这套教程定位于中级&#xff0c;是学完字典后的另一个专题讲解。数据库是数据处理的利器&#xff0c;教程中详细介绍了利用ADO连接ACCDB和EXCEL的方法…...

甄选范文“论软件需求管理”,软考高级论文,系统架构设计师论文

论文真题 软件需求管理是一个对系统需求变更了解和控制的过程。需求管理过程与需求开发过程相互关联,初始需求导出的同时就要形成需求管理规划,一旦启动了软件开发过程,需求管理活动就紧密相伴。 需求管理过程中主要包含变更控制、版本控制、需求跟踪和需求状态跟踪等4项活…...

Android Studio Dolphin 中Gradle下载慢的解决方法

我用的版本Android Studio Dolphin | 2021.3.1 Patch 1 1.Gradle自身的版本下载慢 解决办法&#xff1a;修改gradle\wrapper\gradle-wrapper.properties中的distributionUrl 将https\://services.gradle.org/distributions为https\://mirrors.cloud.tencent.com/gradle dis…...

Excel实现省-市-区/县级联

数据准备 准备省份-城市映射数据&#xff0c;如下&#xff1a; 新建sheet页&#xff0c;命名为&#xff1a;省-市数据源&#xff0c;然后准备数据&#xff0c;如下所示&#xff1a; 准备城市-区|县映射数据&#xff0c;如下&#xff1a; 新建sheet页&#xff0c;命名为&#x…...

【优化代码结构】函数的参数归一化

某些封装的函数&#xff0c;其参数具有多样性&#xff0c;会导致函数中会增加非常多的分支&#xff0c;比如下面这个 format 函数有如下几种参数方式&#xff0c;其中 formatter 会有很多种情况 date&#xff1a;日期对象formatter&#xff1a; ‘date’&#xff1a;格式化日期…...

CSS中height设置100vh和100%的区别

文章目录 CSS中height设置100vh和100%的区别一、引言二、高度设置的区别1、100%1.1、父元素高度固定1.2、父元素高度未定义 2、100vh2.1、视口高度2.2、不受父元素限制 三、总结 CSS中height设置100vh和100%的区别 一、引言 在前端开发中&#xff0c;我们经常需要设置元素的高…...

红米k60至尊版工程固件 MTK芯片 资源预览 刷写说明 与nv损坏修复去除电阻图示

红米k60至尊版机型代码为:corot。 搭载了联发科天玑9200+处理器。此固件mtk引导为MT6985。博文将简单说明此固件的一些特点与刷写注意事项。对于NV损坏的机型。展示修改校验电阻的图示。方便改写参数等 通过博文了解 1💝💝💝-----此机型工程固件的资源刷写注意事项 2…...

QEMU使用Qemu-Guest-Agent传输文件、执行指令等

简介 之前介绍过qemu传输文件&#xff0c;使用的挂载 / samba方式 &#xff1a;Qemu和宿主机不使用外网进行文件传输。 这是一种方式&#xff0c;这里还有另一种方式&#xff1a;使用Qemu-Guest-Agent&#xff0c;后面简称qga。 官网介绍&#xff1a;https://www.qemu.org/d…...

建设银行官网网站首页纪念币预约/深圳白帽优化

CONVERT_TZ(dt,from_tz,to_tz)转换datetime值dt&#xff0c;从 from_tz 由给定转到 to_tz 时区给出的时区&#xff0c;并返回的结果值。 如果参数无效该函数返回NULL。mysql> SELECT CONVERT_TZ(2004-01-01 12:00:00,GMT,MET);--------------------------------------------…...

长沙市做网站/百度竞价推广一个月多少钱

今天在写线性表的链式存储过程中&#xff0c;遇到了一个比较奇葩的问题&#xff0c;就是同一段程序&#xff0c;用for循环可以顺利执行&#xff0c;然而用while循环就提醒我“结点空间申请失败&#xff01;&#xff01;&#xff01;”&#xff0c;考虑了一上午都没有头绪。记录…...

搬瓦工如何搭建做网站/营销软文代写

前提是你的电脑和手机都已经安装了frida并运行正常。 如果你还没安装frida,请参考文章 Android逆向_使用frida 安装frida环境。这里使用国外大佬写的js脚本&#xff0c;来追踪app的方法调用&#xff0c;首先看一下效果&#xff1a;*** entered com.test.flyer.MainActivity.tes…...

什么网站可以做会计题目/百度应用平台

不称深度指南&#xff0c;只愿浅度指北之前&#xff0c;用 VBA 开发了一个 Excel 插件「浅北表格助手」&#xff0c;随后&#xff0c;也发了两篇关于WordVBA 的教程&#xff0c;后台有小伙伴留言&#xff0c;说希望看到一些偏实用的代码。今天&#xff0c;它来了。我们在写 Wor…...

wordpress游戏插件下载/seo关键词有话要多少钱

使用EF实现多查询&#xff0c;暂未考虑性能问题 2015年10月6日22:26:51 正文 我在数据库有三个表&#xff0c;如下图&#xff1a; sysMenus与sysFunction有主外键关系&#xff0c;而sysUserInfo则与其他二表并无关联。 我现在使用这三个表针对多种情况使用EF实现多种查询手段 方…...

衡阳微信网站开发/软件开发培训

MCU是一个专业术语&#xff0c;如果不是行业人士&#xff0c;其实并不是很清楚MCU究竟是什么。其实MCU就是单片机&#xff0c;英文是Microcontroller Unit&#xff0c;MCU其实也可以理解为简单版本的CPU&#xff0c;MCU目前多应用于消费电子和通讯、汽车电子、工业、医疗设备等…...