STM32项目分享:智能家居(机智云)升级版
目录
一、前言
二、项目简介
1.功能详解
2.主要器件
三、原理图设计
四、PCB硬件设计
PCB图
五、程序设计
六、实验效果
七、资料内容
项目分享
一、前言
项目成品图片:
哔哩哔哩视频链接:
STM32智能家居(机智云)升级版
(资料分享见文末)
二、项目简介
1.功能详解
基于STM32的智能家居(机智云)升级版
功能如下:
- 检测功能:监测环境温湿度、烟雾浓度、一氧化碳、空气质量、光照强度、大气压强
- 显示功能:将检测到的数据显示在OLED上
- 控制功能:系统可以控制LED灯、步进电机(窗户)
- 手动模式:机智云APP远程控制LED灯和步进电机。
- 自动模式:系统检测到烟雾浓度/一氧化碳/空气质量超出阈值时、蜂鸣报警并开窗通风;光线低于阈值时,自动开启LED灯
- 阈值调节:按键调节系统阈值
- 手机APP:通过ESP8266 WIFI模块连接网络,接入机智云服务器,实现数据上报和控制下发
2.主要器件
- STM32F103C8T6单片机
- OLED 屏幕
- DHT11温湿度传感器
- 光敏电阻
- MQ-2烟雾传感器
- MQ-7一氧化碳传感器
- MQ-135空气质量传感器
- ESP8266-01S(WIFI模块)
- 步进电机
- 有源蜂鸣器
三、原理图设计
四、PCB硬件设计
PCB图
五、程序设计
#include "stm32f10x.h" // Device header
#include "oled.h"
#include "adcx.h"
#include "bmp280.h"
#include "sensormodules.h"
#include "dht11.h"
#include "key.h"
#include "tim2.h"
#include "tim3.h"
#include "flash.h"
#include "motor.h"
#include "led.h"
#include "usart.h"
#include "iwdg.h"SensorModules sensorData; //声明传感器模块的结构体变量
SensorThresholdValue Sensorthreshold; //声明传感器阈值结构体变量#define KEY_Long1 11#define KEY_1 1
#define KEY_2 2
#define KEY_3 3
#define KEY_4 4#define FLASH_START_ADDR 0x0801f000 //写入的起始地址uint8_t motorFlag = 0;
uint8_t oledPages = 1; //系统显示页面
uint8_t model; //系统模式typedef enum
{DISPLAY_PAGE1 = 1,DISPLAY_PAGE2,SETTINGS_PAGE
} OLED_PAGES;/*** @brief 显示菜单1的固定内容* @param 无* @retval 无*/
void OLED_Menu1(void)
{//显示“温度: C”OLED_ShowChinese(1,1,48);OLED_ShowChinese(1,2,49);OLED_ShowChar(1,5,':');OLED_ShowChar(1,8,'C');//显示“湿度: %”OLED_ShowChinese(1,5,50);OLED_ShowChinese(1,6,51);OLED_ShowChar(1,13,':'); OLED_ShowChar(1,16,'%');//显示”光照强度: Lux“OLED_ShowChinese(2, 1, 8);OLED_ShowChinese(2, 2, 9); OLED_ShowChinese(2, 3, 10);OLED_ShowChinese(2, 4, 11); OLED_ShowChar(2, 9, ':');OLED_ShowString(2, 14, "Lux");//显示“大气压强: ”OLED_ShowChinese(3, 1, 12);OLED_ShowChinese(3, 2, 13);OLED_ShowChinese(3, 3, 14);OLED_ShowChinese(3, 4, 15);OLED_ShowChar(3, 9, ':');OLED_ShowString(3, 14, "hPa");//显示“系统模式:”OLED_ShowChinese(4, 1, 28);OLED_ShowChinese(4, 2, 29);OLED_ShowChinese(4, 3, 30);OLED_ShowChinese(4, 4, 31); OLED_ShowChar(4, 9, ':');
}/*** @brief 显示菜单2的固定内容* @param 无* @retval 无*/
void OLED_Menu2(void)
{//显示“烟雾浓度: ppm”OLED_ShowChinese(1, 1, 20);OLED_ShowChinese(1, 2, 21);OLED_ShowChinese(1, 3, 22);OLED_ShowChinese(1, 4, 23); OLED_ShowChar(1, 9, ':');OLED_ShowString(1,13,"ppm");//显示“一氧化碳: ppm”OLED_ShowChinese(2, 1, 16);OLED_ShowChinese(2, 2, 17);OLED_ShowChinese(2, 3, 18);OLED_ShowChinese(2, 4, 19); OLED_ShowChar(2, 9, ':');OLED_ShowString(2,13,"ppm"); //显示“空气质量: ppm”OLED_ShowChinese(3, 1, 24);OLED_ShowChinese(3, 2, 25);OLED_ShowChinese(3, 3, 26);OLED_ShowChinese(3, 4, 27); OLED_ShowChar(3, 9, ':');OLED_ShowString(3,13,"ppm");
}/*** @brief 显示菜单1的传感器数据* @param 无* @retval 无*/
void SensorDataDisplay1(void)
{//显示温度数据OLED_ShowNum(1, 6, sensorData.temp, 2);//显示湿度数据OLED_ShowNum(1, 14, sensorData.humi, 2);//显示光照强度数据OLED_ShowNum(2, 10, sensorData.lux, 4); //显示大气压强数据OLED_ShowNum(3, 10, 1020, 4);//显示系统状态数据if (!model){OLED_ShowChinese(4, 6, 36);OLED_ShowChinese(4, 7, 37); }else{OLED_ShowChinese(4, 6, 32);OLED_ShowChinese(4, 7, 33); }
}/*** @brief 显示菜单2的传感器数据* @param 无* @retval 无*/
void SensorDataDisplay2(void)
{//显示烟雾浓度数据OLED_ShowNum(1, 10, sensorData.smoke, 3); //显示一氧化碳数据OLED_ShowNum(2, 10, sensorData.CO, 3); //显示空气质量数据OLED_ShowNum(3, 10, sensorData.AQI, 3);
}/*** @brief 显示系统阈值设置界面1* @param 无* @retval 无*/
void OLED_SetInterfacevoid(void)
{//显示“光照阈值”OLED_ShowChinese(1, 2, 8);OLED_ShowChinese(1, 3, 9); OLED_ShowChinese(1, 4, 42);OLED_ShowChinese(1, 5, 43); OLED_ShowChar(1, 11, ':');//显示“烟雾阈值”OLED_ShowChinese(2, 2, 20);OLED_ShowChinese(2, 3, 21); OLED_ShowChinese(2, 4, 42);OLED_ShowChinese(2, 5, 43); OLED_ShowChar(2, 11, ':');//显示“一氧化碳阈值”OLED_ShowString(3, 3, "CO");OLED_ShowChinese(3, 4, 42);OLED_ShowChinese(3, 5, 43); OLED_ShowChar(3, 11, ':');//显示“空气质量阈值”OLED_ShowString(4, 3, "AQI");OLED_ShowChinese(4, 4, 42);OLED_ShowChinese(4, 5, 43); OLED_ShowChar(4, 11, ':');//显示光照阈值数值OLED_ShowNum(1, 12, Sensorthreshold.luxValue, 4);//显示烟雾阈值数值OLED_ShowNum(2, 12, Sensorthreshold.smokeValue, 3);//显示一氧化碳阈值数值OLED_ShowNum(3, 12, Sensorthreshold.COValue, 3);//显示空气质量阈值数值OLED_ShowNum(4, 12, Sensorthreshold.AQIValue, 3);
}/*** @brief 记录阈值界面下按KEY1的次数* @param 无* @retval 返回次数*/
uint8_t SetSelection(void)
{static uint8_t count = 1;if(KeyNum == KEY_1){KeyNum = 0;count++;if (count > 4){count = 1;}}return count;
}/*** @brief 显示阈值界面的选择符号* @param num 为显示的位置* @retval 无*/
void OLED_Option(uint8_t num)
{switch(num){case 1: OLED_ShowChar(1,1,'>');OLED_ShowChar(2,1,' ');OLED_ShowChar(3,1,' ');OLED_ShowChar(4,1,' ');break;case 2: OLED_ShowChar(1,1,' ');OLED_ShowChar(2,1,'>');OLED_ShowChar(3,1,' ');OLED_ShowChar(4,1,' ');break;case 3: OLED_ShowChar(1,1,' ');OLED_ShowChar(2,1,' ');OLED_ShowChar(3,1,'>');OLED_ShowChar(4,1,' ');break;case 4: OLED_ShowChar(1,1,' ');OLED_ShowChar(2,1,' ');OLED_ShowChar(3,1,' ');OLED_ShowChar(4,1,'>');break;default: break;}
}/*** @brief 对阈值界面的传感器阈值进行修改* @param num 为当前用户需要更改的传感器阈值位置* @retval 无*/
void ThresholdModification(uint8_t num)
{switch (num){case 1:if (KeyNum == KEY_3){KeyNum = 0;Sensorthreshold.luxValue += 10;if (Sensorthreshold.luxValue > 2000){Sensorthreshold.luxValue = 0;}}else if (KeyNum == KEY_4){KeyNum = 0;Sensorthreshold.luxValue -= 10;if (Sensorthreshold.luxValue > 2000){Sensorthreshold.luxValue = 2000;} }break;case 2:if (KeyNum == KEY_3){KeyNum = 0;Sensorthreshold.smokeValue += 10;if (Sensorthreshold.smokeValue > 500){Sensorthreshold.smokeValue = 0;}}else if (KeyNum == KEY_4){KeyNum = 0;Sensorthreshold.smokeValue -= 10;if (Sensorthreshold.smokeValue > 500){Sensorthreshold.smokeValue = 500;} } break;case 3:if (KeyNum == KEY_3){KeyNum = 0;Sensorthreshold.COValue += 10;if (Sensorthreshold.COValue > 500){Sensorthreshold.COValue = 0;}}else if (KeyNum == KEY_4){KeyNum = 0;Sensorthreshold.COValue -= 10;if (Sensorthreshold.COValue > 500){Sensorthreshold.COValue = 500;} }break;case 4:if (KeyNum == KEY_3){KeyNum = 0;Sensorthreshold.AQIValue += 10;if (Sensorthreshold.AQIValue > 500){Sensorthreshold.AQIValue = 0;}}else if (KeyNum == KEY_4){KeyNum = 0;Sensorthreshold.AQIValue -= 10;if (Sensorthreshold.AQIValue > 500){Sensorthreshold.AQIValue = 500;} }break;default: break; }
}/*** @brief 根据标志位控制步进电机的运行* @param 无* @retval 无*/
void MotorOperation(void)
{if (motorFlag == 1){MOTOR_Direction_Angle(1, 0, 90, 1);MOTOR_STOP();motorFlag = 0;}else if (motorFlag == 2){MOTOR_Direction_Angle(0, 0, 90, 1);MOTOR_STOP();motorFlag = 0; }}/*** @brief 传感器数据扫描* @param 无* @retval 无*/
void SensorScan(void)
{DHT11_Read_Data(&sensorData.humi, &sensorData.temp);Get_Average_LDR_LUX(&sensorData.lux);Get_Average_MQ2_PPM(&sensorData.smoke);Get_Average_MQ7_PPM(&sensorData.CO);Get_Average_MQ135_PPM(&sensorData.AQI);sensorData.hPa = (uint32_t)BMP280_Get_Pressure();
}int main(void)
{ADCX_Init();Timer2_Init(9,14398);Uart2_Init(9600);Uart1_Init(115200);IWDG_Init();OLED_Init();Bmp_Init();DHT11_Init();Key_Init();MOTOR_Init();LED_Init();Buzzer_Init();Sensorthreshold.luxValue = FLASH_R(FLASH_START_ADDR); //从指定页的地址读FLASHSensorthreshold.smokeValue = FLASH_R(FLASH_START_ADDR+2); //从指定页的地址读FLASHSensorthreshold.COValue = FLASH_R(FLASH_START_ADDR+4); //从指定页的地址读FLASHSensorthreshold.AQIValue = FLASH_R(FLASH_START_ADDR+6); //从指定页的地址读FLASHGENERAL_TIM_Init();userInit(); //完成机智云初始赋值gizwitsInit(); //开辟一个环形缓冲区while (1){IWDG_ReloadCounter(); //使能重装载寄存器计数SensorScan(); //获取传感器数据switch (oledPages){case DISPLAY_PAGE1:OLED_Menu1(); //显示主页面1固定信息SensorDataDisplay1();//显示传感器1数据MotorOperation();/*按键按下时进入主页面2*/if (KeyNum == KEY_2){KeyNum = 0;oledPages = DISPLAY_PAGE2;OLED_Clear();}/*按键按下时切换模式*/if (KeyNum == KEY_1){KeyNum = 0;model = !model;if (!model){LED_OFF();Buzzer_OFF();}}/*按键按下时进入阈值设计界面*/if (KeyNum == KEY_Long1){KeyNum = 0;oledPages = SETTINGS_PAGE;OLED_Clear();}break;case DISPLAY_PAGE2:OLED_Menu2();SensorDataDisplay2();MotorOperation();/*按键按下时进入主页面2*/if (KeyNum == KEY_2){KeyNum = 0;oledPages = DISPLAY_PAGE1;OLED_Clear();} break;case SETTINGS_PAGE:OLED_SetInterfacevoid(); //显示阈值设置界面的固定内容OLED_Option(SetSelection()); //实现阈值设置页面的选择功能ThresholdModification(SetSelection()); //实现阈值调节功能 //判断是否退出阈值设置界面if (KeyNum == KEY_2){KeyNum = 0;oledPages = DISPLAY_PAGE1; //跳转到主界面OLED_Clear(); //清屏//存储修改的传感器阈值至flash内 FLASH_W(FLASH_START_ADDR, Sensorthreshold.luxValue, Sensorthreshold.smokeValue, Sensorthreshold.COValue, Sensorthreshold.AQIValue);}break;default: break;}userHandle(); //更新机智云数据点变量存储的值gizwitsHandle((dataPoint_t *)¤tDataPoint); //数据上传至机智云 }
}
六、实验效果
七、资料内容
项目分享
相关文章:
STM32项目分享:智能家居(机智云)升级版
目录 一、前言 二、项目简介 1.功能详解 2.主要器件 三、原理图设计 四、PCB硬件设计 PCB图 五、程序设计 六、实验效果 七、资料内容 项目分享 一、前言 项目成品图片: 哔哩哔哩视频链接: STM32智能家居(机智云)升级版 (资料…...
Flask-SQLAlchemy核心概念:模型类与数据库表、类属性与表字段、外键与关系映射
前置阅读,关于Flask-SQLAlchemy支持哪些数据库及基本配置,链接:Flask-SQLAlchemy_数据库配置 摘要 本文以一段典型的 SQLAlchemy 代码示例为引入,阐述以下核心概念: 模型类(Model Class) ↔ 数…...
算法优选系列(9.BFS 解决拓扑排序)
目录 拓扑排序简介: 编辑 课程表(medium): 课程表II(medium): 火星词典(hard): 拓扑排序简介: 有向无环图(DAG图) 如上图每条边…...
DevExpress Blazor中文教程 - 如何用AI聊天组件构建大型语言模型聊天APP?
DevExpress Blazor UI组件使用了C#为Blazor Server和Blazor WebAssembly创建高影响力的用户体验,这个UI自建库提供了一套全面的原生Blazor UI组件(包括Pivot Grid、调度程序、图表、数据编辑器和报表等)。 AI服务提供各种量身定制的模型来满…...
PHP:经典编程语言在当代Web开发中的新活力
在当今的Web开发领域,新技术和新语言层出不穷,但PHP(超文本预处理器)作为一门经典且功能强大的编程语言,依然在Web开发中占据着重要地位,并不断展现出新的活力。 PHP的历史与现状 PHP诞生于1994年&#x…...
ToDesk云电脑、并行智算云与顺网云AI支持能力深度实测报告
随着AI技术的迅猛发展,云计算平台已成为突破本地硬件限制、实现高效AI计算的关键基础设施。本报告对ToDesk云电脑、并行智算云和顺网云三大主流云平台进行了全面测评,从硬件配置、AI软件兼容性、性能表现、用户体验及成本效益等维度深入分析其AI支持能力…...
javaweb的拦截功能,自动跳转登录页面
我们开发系统时候,肯定希望用户登录后才能进入主页面去访问其他服务,但要是没有拦截功能的话,他就可以直接通过url访问或者post注入攻击了。 因此我们可以通过在后端添加拦截过滤功能把没登录的用户给拦截下来,让他去先登录&#…...
精益数据分析(75/126):用户反馈的科学解读与试验驱动迭代——Rally的双向验证方法论
精益数据分析(75/126):用户反馈的科学解读与试验驱动迭代——Rally的双向验证方法论 在创业的黏性阶段,用户反馈是优化产品的重要依据,但如何避免被表面反馈误导?如何将反馈转化为可落地的迭代策略&#x…...
轻量级高性能Rust HTTP服务器库Hyperlane,助力现代网络服务开发
轻量级高性能Rust HTTP服务器库Hyperlane,助力现代网络服务开发 Hyperlane是一款专为简化网络服务开发而设计的轻量级、高性能Rust HTTP服务器库。它凭借纯Rust和标准库构建,实现了Windows、Linux和macOS全平台兼容,依托Tokio异步运行时&…...
PCB设计实践(二十四)PCB设计时如何避免EMI
PCB设计中避免电磁干扰(EMI)是一项涉及电路架构、布局布线、材料选择及制造工艺的系统工程。本文从设计原理到工程实践,系统阐述EMI产生机制及综合抑制策略,覆盖高频信号控制、接地优化、屏蔽技术等核心维度,为高密度、…...
VRRP 协议
一、前言 最近被问到一个VRRP的网络协议,一开始我是蒙蔽的状态,至于什么是VRRP,我后面查了一下,因为对于网络这方面我也不是很精通,见谅! VRRP,全称叫虚拟路由冗余协议,是我孤陋寡闻…...
年度工作计划总结述职报告PPT模版一组分享
工作计划总结述职报告PPT模版:工作计划述职报告PPT模版https://pan.quark.cn/s/fba40a5e87da 第一套PPT模版是医院年度工作计划的封面页,有蓝橙配色、医院标题、年度工作计划的大字、英文副标题、汇报人信息和右上角的医院logo区域,右侧还有医…...
【容易坑】mybatis中使用if标签比较两个字符串是否相等
资料都来自于网络,这里只是记录一下,仅供参考 现象 上传参数确实为3,但是到了sql中还是2,很纳闷,确定不是上送参数的问题 问题解决 问题的关键点就在于为啥偏偏是2身上,仔细看一下sql语句,这个…...
AI与产品架构设计(7):实时数据驱动下的AI架构设计:从流数据到智能决策
实时数据驱动下的AI架构设计:从流数据到智能决策 一、引言:从静态智能到流式智能的革命性跨越 在AI演进的历程中,我们正经历着从"数据仓库时代"向"数据流时代"的范式迁移。传统AI系统依赖的离线批处理模式,…...
测试W5500的第4步_使用ioLibrary库创建UDP客户端和服务器端
从下载网络测试工具,经常会区分UDP客户端和UDP服务器端。其实这么区分,是不正确的。它区分,是因为担心使用的人不会配置,这是它这么设计的原因。 UDP(User Datagram Protocol,用户数据报协议)是一种简单的,无连接的传…...
六台升降台完整的限位保护逻辑
一、限位保护的核心逻辑 以下是实现限位保护功能的关键代码,集成在主控制程序中: // // 限位保护处理 - 集成在主程序中 // FOR i : 1 TO 6 DO// 读取限位状态(从变频器状态字获取)Lifts[i].UpperLimit : (Lifts[i].StatusWord …...
腾讯位置服务地点搜索开发指南
概述 提供多种搜索功能: 指定城市/区域搜索:如在北京搜索景点。新增高级参数:支持获取车站、机场、园区等较大范围地点的子点和出入口热度,辅助用户选择准确目的地。周边搜索:如,搜索颐和园附近半径500米内…...
101个α因子#12
(sign(delta(volume, 1)) * (-1 * delta(close, 1)))worldquant brain平台上调整后的语法: (sign(ts_delta(volume, 1)) * (-1 * ts_delta(close, 1)))这个alpha因子的逻辑可以分为以下几个步骤: 1. 计算成交量的变化方向:sign(ts_delta(vol…...
opencv_version_win32
很多人发了opencv的编译方法,很少见到启动和关闭了那些模块,现在发个WIN64 opencv编译后的信息。 执行opencv_version_win32.exe 因为显卡较老 2060 super, NVIDIA GPU arch: 75 80 86 87 89 90。至于更高的反本没有显卡因此不知道。 BLAS库使用效率较高…...
Flask 路由装饰器:从 URL 到视图函数的优雅映射
前置知识,关于Python装饰器的语法,链接:Python 装饰器:从“语法糖”到“代码神器”的深度解析 1、路由装饰器的功能:给 URL 贴 “功能标签” 在 Flask 开发中,你一定见过这样的代码: from fla…...
动态规划3、悟到核心
题目引入: #include <iostream> #include <queue> #include <vector> #include <tuple> #include <algorithm> #include <cstring> using namespace std;// dp[i]考虑前i家店能收获的最大价值 // 面对第i家店铺,你可…...
VLM-MPC:自动驾驶中模型预测控制器增强视觉-语言模型
《VLM-MPC: Model Predictive Controller Augmented Vision Language Model for Autonomous Driving》2024年8月发表,来自威斯康星大学的论文。 受视觉语言模型(VLM)的紧急推理能力及其提高自动驾驶系统可理解性的潜力的启发,本文…...
HTTP/HTTPS 协议浅解
文章目录 一、HTTP 协议(一)定义(二)特点(三)应用场景(四)优势(五)劣势 二、HTTPS 协议(一)定义(二)特点&…...
Ajax快速入门教程
输入java时,页面并没有刷新但是下面自动联想出了跟java有关的东西,像这种就叫异步交互 它不会妨碍你的输入,同时还能够同步进行对于java相关联想词的推送 发送异步请求需要借助工具axios 引入axios,可以直接在scripts中引入 get和…...
如何在Java中处理PDF文档(教程)
在开发文档管理系统、自动化工具或商业应用程序时,Java开发者常需处理PDF文档的编辑需求。无论是添加页面、调整内容尺寸、插入水印还是添加注释,选择一套可靠易用的Java PDF开发工具包至关重要。 JPedal(Java PDF开发工具包)的新…...
springcloud集成seata报错Error creating bean with name ‘globalTransactionScanner‘
1. pom文件引入依赖 <!-- seata --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-seata</artifactId></dependency> 2. 报错 3. 在启动配置中添加一行配置: --add-opensjava.base/j…...
使用 OpenCV 实现哈哈镜效果:让图像“扭曲起来”!
在计算机视觉和图像处理领域,OpenCV 提供了非常强大的图像几何变换能力,不仅可以用于纠正图像,还能制造各种“有趣”的视觉效果。今天,我们就来实现一个经典的“哈哈镜”效果,让图像像在游乐园里一样被拉伸、压缩、扭曲…...
pikachu靶场 暴力破解
学习中参考的博客如下 pikachu靶场暴力破解专题-CSDN博客 1,基于表单的暴力破解 出现了一个登录页面 解题步骤:抓包,发到bp里,右键发到Intruder,因为有两个位置要爆破,所以选择集群炸弹攻击ÿ…...
鸿蒙开发:应用上架第三篇,配置签名信息打出上架包
前言 本文基于Api13 经过前面两篇文章,我们获取到了密钥和证书请求文件以及最终的发布证书和发布证书Profile文件,可以说,所有的签名信息文件,我们都已经完成了,正所谓,万事俱备只欠东风,这篇文…...
基于R语言的贝叶斯网络模型实践技术应用:开启科研新视角
在现代科研领域,变量间的因果关系推断是生态学、环境科学、医学等多学科研究的核心问题。然而,传统的统计学方法往往只能揭示变量间的相关关系,而非因果关系。贝叶斯网络作为一种结合图论与统计学理论的新型模型,不仅能够统合多种…...
第五章 GPT模块配置
由于GPT配置需要和Irq和Mcu进行配合设置(GPT可以由芯片外设中的GTM和GPT12实现,这次是以GTM为实现)。 1 GTM外设时钟配置 首先需要对MCU组件进行配置,配置GTM的时钟,需要参照GTM的CMU时钟树。 下图时钟树的CLS0_CLK为MCU(McuClockSettingConfig_0中的 McuSTMFrequency )f…...
虚拟机NAT模式获取不到ip
虚拟机NAT模式获取不到ip 如图所示 解决方案: 先查看NetworkManager是否启动 systemctl status NetworkManager如果没启动就启动一遍 使用DHCP手动获取一遍ip sudo dhclient ens33成功得到ip 这是后遇到了另一个问题,ip释放后,不能自动…...
Docker的网络介绍
网络简单介绍 在介绍 Docker 的网络模式之前,先简单说下我们在使用 Vmware 虚拟机中的网络模式,形成对比,更好理解。 1、Vmware 中的网络模式 1.1、VMnet0(桥接模式) 虚拟机通过宿主机的物理网卡直接连接到外部网络…...
Nginx负载均衡配置详解
在Nginx中配置负载均衡主要通过 upstream 模块实现,结合反向代理将请求分发到多个后端服务器。以下是详细配置步骤和案例解析: 一、基础配置 1. 配置语法 http {upstream backend_servers {# 负载均衡策略server backend1.example.com;server backend2.example.com;server …...
关于 Web 漏洞原理与利用:4. 文件上传漏洞
定义:文件上传漏洞是指应用程序允许用户上传文件,但没有严格校验上传文件的类型、内容、路径等属性,导致攻击者可以上传并执行恶意代码。 绕过方式: 前端绕过 1. 前端限制的原理 前端限制上传文件类型的常见方式有三种…...
(6)python爬虫--selenium
文章目录 前言一、初识selenium二、安装selenium2.1 查看chrome版本并禁止chrome自动更新2.1.1 查看chrome版本2.1.2 禁止chrome更新自动更新 2.2 安装对应版本的驱动程序2.3安装selenium包 三、selenium关于浏览器的使用3.1 创建浏览器、设置、打开3.2 打开/关闭网页及浏览器3…...
MCU 上电不启动的常见原因分析与排查思路
在开发过程中,“MCU 上电不运行”是我们经常遇到的问题之一。但客户对此类问题的描述往往较为模糊,仅简单表示“产品不工作”或“怀疑 MCU 没有运行”,这给我们现场排查带来了较大的挑战。即便工程师到达现场,往往也无法迅速定位问…...
Spark Core 源码关键环节的深度解析
以下是对 Spark Core 源码关键环节的深度解析,包括核心组件启动与调度机制、Shuffle与调度系统、RDD高级机制。每个环节都细化到具体方法、逻辑、源码片段,附有流程图思路与速记口诀,便于记忆和理解。 一、核心组件启动与调度机制 1. RpcEnv…...
net Core》》包与库 LibMan、NPM
LibMan 资料 NPM 资料 在 Visual Studio 中使用 npm package.json 保存之后 vs会自动下载的。 注意:如果您没有看到 node_modules 文件夹,请确保在 Visual Studio 解决方案资源管理器中启用了“显示所有文件”选项 要卸载该库,您只需从 …...
数学建模,机器决策人建模
目录 数学建模 微分方程 动态系统建模 时间序列分析 概述 指数衰减 随机漂移 总结 曲线拟合 最优化方法 梯度下降法 概率建模(如贝叶斯建模、马尔可夫过程、MDP/POMDP) 等 贝叶斯建模 贝叶斯定理 优势 马尔可夫过程 马尔可夫过程的分类…...
FFmpeg中使用Android Content协议打开文件设备
引言 随着Android 10引入的Scoped Storage(分区存储)机制,传统的文件访问方式发生了重大变化。FFmpeg作为强大的多媒体处理工具,也在不断适应Android平台的演进。本文将介绍如何在FFmpeg 7.0版本中使用Android content协议直接访…...
SQL查询, 响应体临时字段报: Unknown column ‘data_json_map‘ in ‘field list‘
Overridepublic AjaxResult list(AgentPageReqVO pageReqVO, Integer pageNo, Integer pageSize) {// 1. 查询数据库获取代理列表List<AgentDO> list agentMapper.selectPage(pageReqVO).getList();// 如果结果为空,直接返回空分页结果if (CollectionUtils.i…...
OpenCv高阶(十四)——LBPH人脸识别
文章目录 前言一、LBPH原理1. LBP(局部二值模式)特征提取2. 图像分块处理3. 生成直方图4. 人脸识别(匹配阶段)5. LBPH的特点6. 变种与优化 二、LBPH人脸识别简单实现(一)LBPH人脸识别1、图像读取࿰…...
C#开发利器:SharpBoxesCore全解析
SharpBoxesCore 是一个基于 C# 的开源开发工具库,旨在为开发者提供一系列常用功能模块和辅助类,以提高开发效率、减少重复代码编写,并增强项目的可维护性和扩展性。该库集成了多种实用工具类和通用扩展方法,适用于桌面应用、Web 项…...
回表是数据库概念,还是mysql的概念?
主键索引没有列,根据耳机索引去查主键索引,又没有查表,为啥叫回表呢? “回表”这个词,其实算是数据库里的一个通用概念,不过它最常见的应用场景是在 MySQL 的 InnoDB 引擎里,所以很多人一提起回…...
49、c# 能⽤foreach 遍历访问的对象需满足什么条件?
在 C# 中,要使用 foreach 循环遍历一个对象,该对象必须满足以下条件之一: 1. 实现 IEnumerable 或 IEnumerable 接口 非泛型版本:System.Collections.IEnumerable public class MyCollection : IEnumerable {private int[] _da…...
DL00987-基于深度学习YOLOv11的红外鸟类目标检测含完整数据集
提升科研能力,精准识别红外鸟类目标! 完整代码数据集见文末 针对科研人员,尤其是研究生们,是否在鸟类目标检测中遇到过数据不够精准、处理困难等问题?现在,我们为你提供一款基于深度学习YOLOv11的红外鸟类…...
07 接口自动化-用例管理框架之pytest单元测试框架
文章目录 一、pytest用例管理框架(单元测试框架)二、pytest简介三、pytest的最基本的测试用例的规则四、运行方式1.主函数方式2.命令行方式3.通过pytest.ini的配置文件运行 五、pytest 默认执行测试用例的顺序六、跳过测试用例1.无条件跳过 pytest.mark.…...
Flutter 中 build 方法为何写在 StatefulWidget 的 State 类中
Flutter 中 build 方法为何写在 StatefulWidget 的 State 类中 在 Flutter 中,build 方法被设计在 StatefulWidget 的 State 类中而非 StatefulWidget 类本身,这种设计基于几个重要的架构原则和实际考量: 1. 核心设计原因 1.1 生命周期管理…...
多技术栈 iOS 项目的性能调试实战:从 Flutter 到 Unity(含 KeyMob 工具实测)
多技术栈 iOS 项目的性能调试实战:从 Flutter 到 Unity 随着移动端开发日趋多元化,iOS 项目中纯 Objective-C/Swift 已不再是唯一选择。越来越多团队采用 Flutter、React Native、Unity、WebView 混合等方案构建 App。这种“技术栈混合”带来灵活性的同…...