基于STM32开发的智能门禁系统

目录

  1. 引言
  2. 环境准备工作
    • 硬件准备
    • 软件安装与配置
  3. 系统设计
    • 系统架构
    • 硬件连接
  4. 代码实现
    • 系统初始化
    • 人脸识别与RFID验证
    • 门锁控制与状态显示
    • Wi-Fi通信与远程监控
  5. 应用场景
    • 家庭与办公楼的门禁管理
    • 商业场所的安全控制
  6. 常见问题及解决方案
    • 常见问题
    • 解决方案
  7. 结论

1. 引言

随着安全需求的提高,智能门禁系统成为保障家庭、办公楼和商业场所安全的重要手段。通过集成人脸识别、RFID验证、门锁控制等功能,智能门禁系统可以自动识别用户身份并控制门锁的开启与关闭,确保安全性。本文将介绍如何使用STM32微控制器设计和实现一个智能门禁系统,并支持通过Wi-Fi模块进行远程监控和控制。

2. 环境准备工作

硬件准备

  • STM32开发板(例如STM32F103C8T6)
  • 人脸识别模块(例如ESP32-CAM,用于人脸识别)
  • RFID读卡器模块(例如MFRC522,用于身份验证)
  • 电磁门锁(用于门禁控制)
  • 继电器模块(用于控制门锁)
  • OLED显示屏(用于显示系统状态)
  • Wi-Fi模块(例如ESP8266,用于远程控制)
  • 面包板和连接线
  • USB下载线

软件安装与配置

  • Keil uVision:用于编写、编译和调试代码。
  • STM32CubeMX:用于配置STM32微控制器的引脚和外设。
  • ST-Link Utility:用于将编译好的代码下载到STM32开发板中。

步骤:

  1. 下载并安装Keil uVision。
  2. 下载并安装STM32CubeMX。
  3. 下载并安装ST-Link Utility。

3. 系统设计

系统架构

智能门禁系统通过STM32微控制器作为核心控制单元,结合人脸识别模块和RFID读卡器,实现对人员身份的验证。系统根据身份验证结果自动控制电磁门锁的开关,并将门禁状态通过OLED显示屏实时显示,用户还可以通过Wi-Fi模块远程监控和管理门禁系统。

硬件连接

  1. 人脸识别模块连接:将ESP32-CAM模块的VCC引脚连接到STM32的3.3V引脚,GND引脚连接到GND,TX、RX引脚分别连接到STM32的USART引脚(例如PA9、PA10),用于人脸识别数据传输。
  2. RFID读卡器连接:将MFRC522读卡器的VCC引脚连接到STM32的3.3V引脚,GND引脚连接到GND,SCK、MISO、MOSI和SDA引脚分别连接到STM32的SPI引脚(例如PA5、PA6、PA7、PB0),用于读取RFID标签。
  3. 电磁门锁连接:将电磁门锁的正极连接到继电器模块的输出引脚,继电器控制引脚连接到STM32的GPIO引脚(例如PA1),用于控制门锁的开关。
  4. OLED显示屏连接:将OLED显示屏的VCC引脚连接到STM32的3.3V引脚,GND引脚连接到GND,SCL和SDA引脚连接到STM32的I2C引脚(例如PB6、PB7),用于显示系统状态。
  5. Wi-Fi模块连接:将Wi-Fi模块的TX、RX引脚分别连接到STM32的USART引脚(例如PA9、PA10),VCC引脚连接到STM32的3.3V引脚,GND引脚连接到GND,支持远程控制和数据传输。

4. 代码实现

系统初始化

#include "stm32f1xx_hal.h"
#include "face_recognition.h"
#include "rfid.h"
#include "lock_control.h"
#include "oled.h"
#include "wifi.h"

void SystemClock_Config(void);
static void MX_GPIO_Init(void);
static void MX_USART1_UART_Init(void);
static void MX_SPI1_Init(void);
static void MX_I2C1_Init(void);

int main(void) {
  HAL_Init();
  SystemClock_Config();
  MX_GPIO_Init();
  MX_USART1_UART_Init();
  MX_SPI1_Init();
  MX_I2C1_Init();

  FaceRecognition_Init();
  RFID_Init();
  LockControl_Init();
  OLED_Init();
  WiFi_Init();

  while (1) {
    // 系统循环处理
  }
}

void SystemClock_Config(void) {
  // 配置系统时钟
}

static void MX_GPIO_Init(void) {
  // 初始化GPIO
  __HAL_RCC_GPIOA_CLK_ENABLE();
  GPIO_InitTypeDef GPIO_InitStruct = {0};

  GPIO_InitStruct.Pin = GPIO_PIN_1; // 控制电磁门锁
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  GPIO_InitStruct.Pull = GPIO_NOPULL;
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
}

static void MX_USART1_UART_Init(void) {
  // 初始化USART1用于人脸识别模块和Wi-Fi通信
  huart1.Instance = USART1;
  huart1.Init.BaudRate = 115200;
  huart1.Init.WordLength = UART_WORDLENGTH_8B;
  huart1.Init.StopBits = UART_STOPBITS_1;
  huart1.Init.Parity = UART_PARITY_NONE;
  huart1.Init.Mode = UART_MODE_TX_RX;
  huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart1) != HAL_OK) {
    Error_Handler();
  }
}

static void MX_SPI1_Init(void) {
  // 初始化SPI1用于RFID模块通信
  hspi1.Instance = SPI1;
  hspi1.Init.Mode = SPI_MODE_MASTER;
  hspi1.Init.Direction = SPI_DIRECTION_2LINES;
  hspi1.Init.DataSize = SPI_DATASIZE_8BIT;
  hspi1.Init.CLKPolarity = SPI_POLARITY_LOW;
  hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;
  hspi1.Init.NSS = SPI_NSS_SOFT;
  hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_16;
  hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB;
  hspi1.Init.TIMode = SPI_TIMODE_DISABLE;
  hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  hspi1.Init.CRCPolynomial = 10;
  if (HAL_SPI_Init(&hspi1) != HAL_OK) {
    Error_Handler();
  }
}

static void MX_I2C1_Init(void) {
  // 初始化I2C1用于OLED显示屏通信
  hi2c1.Instance = I2C1;
  hi2c1.Init.ClockSpeed = 100000;
  hi2c1.Init.DutyCycle = I2C_DUTYCYCLE_2;
  hi2c1.Init.OwnAddress1 = 0;
  hi2c1.Init.AddressingMode = I2C_ADDRESSINGMODE_7BIT;
  hi2c1.Init.DualAddressMode = I2C_DUALADDRESS_DISABLE;
  hi2c1.Init.OwnAddress2 = 0;
  hi2c1.Init.GeneralCallMode = I2C_GENERALCALL_DISABLE;
  hi2c1.Init.NoStretchMode = I2C_NOSTRETCH_DISABLE;
  if (HAL_I2C_Init(&hi2c1) != HAL_OK) {
    Error_Handler();
  }
}

人脸识别与RFID验证

#include "face_recognition.h"
#include "rfid.h"

void FaceRecognition_Init(void) {
  // 初始化人脸识别模块
}

bool FaceRecognition_Verify(void) {
  // 验证人脸识别结果
  return true; // 示例中假设人脸识别通过
}

void RFID_Init(void) {
  // 初始化RFID读卡器模块
}

bool RFID_Verify(void) {
  // 验证RFID标签
  return true; // 示例中假设RFID验证通过
}

门锁控制与状态显示

#include "lock_control.h"
#include "oled.h"

void LockControl_Init(void) {
  // 初始化门锁控制模块
}

void LockControl_Open(void) {
  // 打开电磁门锁
  HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_SET);
}

void LockControl_Close(void) {
  // 关闭电磁门锁
  HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_RESET);
}

void OLED_DisplayStatus(bool faceVerified, bool rfidVerified, const char *lockStatus) {
  // 在OLED显示屏上显示验证结果和门锁状态
  char displayStr[64];
  sprintf(displayStr, "Face: %s\nRFID: %s\nLock: %s",
          faceVerified ? "Verified" : "Not Verified",
          rfidVerified ? "Verified" : "Not Verified",
          lockStatus);
  OLED_ShowString(0, 0, displayStr);
}

Wi-Fi通信与远程监控

#include "wifi.h"

void WiFi_Init(void) {
  // 初始化Wi-Fi模块
}

bool WiFi_IsConnected(void) {
  // 检查Wi-Fi是否已连接
  return true; // 示例中假设已连接
}

void WiFi_SendStatus(bool faceVerified, bool rfidVerified, const char *lockStatus) {
  // 发送验证状态和门锁状态到服务器或远程设备
  char dataStr[64];
  sprintf(dataStr, "Face: %s, RFID: %s, Lock: %s",
          faceVerified ? "Verified" : "Not Verified",
          rfidVerified ? "Verified" : "Not Verified",
          lockStatus);
  HAL_UART_Transmit(&huart1, (uint8_t*)dataStr, strlen(dataStr), HAL_MAX_DELAY);
}

主程序循环处理

main函数的while循环中,系统将不断进行人脸识别和RFID验证,并根据验证结果自动控制电磁门锁的开关,同时更新OLED显示屏上的状态信息,并通过Wi-Fi模块将数据发送到远程设备。

while (1) {
  // 进行人脸识别和RFID验证
  bool faceVerified = FaceRecognition_Verify();
  bool rfidVerified = RFID_Verify();

  // 根据验证结果控制电磁门锁
  if (faceVerified && rfidVerified) {
    LockControl_Open(); // 打开门锁
    OLED_DisplayStatus(faceVerified, rfidVerified, "Open");
  } else {
    LockControl_Close(); // 关闭门锁
    OLED_DisplayStatus(faceVerified, rfidVerified, "Closed");
  }

  // 更新Wi-Fi状态并发送门禁系统状态
  if (WiFi_IsConnected()) {
    WiFi_SendStatus(faceVerified, rfidVerified, faceVerified && rfidVerified ? "Open" : "Closed");
  }

  HAL_Delay(1000); // 添加短暂延时
}

⬇帮大家整理了单片机的资料

包括stm32的项目合集【源码+开发文档】

点击下方蓝字即可领取,感谢支持!⬇

点击领取更多嵌入式详细资料

问题讨论,stm32的资料领取可以私信!

 

5. 应用场景

家庭与办公楼的门禁管理

本系统适用于家庭和办公楼,通过智能门禁控制系统自动识别用户身份并控制门锁的开关,提升安全性和便利性。用户还可以通过Wi-Fi远程监控门禁状态,并在必要时进行远程控制。

商业场所的安全控制

本系统也适用于商业场所,通过智能门禁系统对员工和访客进行身份验证,确保场所的安全性。管理人员可以通过远程监控门禁状态,实现集中管理和灵活控制。

6. 常见问题及解决方案

常见问题

  1. 人脸识别不准确:可能是光线不足或摄像头角度不佳。

    • 解决方案:确保人脸识别模块安装在良好的光线环境下,并调整摄像头角度。
  2. RFID读卡失败:可能是RFID标签受损或读卡器信号弱。

    • 解决方案:检查RFID标签的状态,确保其完好无损,并尝试更换或调整读卡器。
  3. Wi-Fi连接不稳定:可能是网络信号弱或Wi-Fi模块配置不当。

    • 解决方案:检查Wi-Fi模块的配置,确保网络环境良好。必要时更换信号更强的路由器或使用信号放大器。

解决方案

  1. 模块校准与维护:定期检查人脸识别模块和RFID读卡器的状态,确保验证结果的准确性。必要时进行校准和更换。

  2. 系统监控与维护:定期测试电磁门锁、OLED显示屏和Wi-Fi模块的工作状态,确保系统能够在身份验证后及时响应,并保持门禁系统的正常运行。

  3. Wi-Fi网络优化:根据实际情况优化Wi-Fi网络配置,确保系统能够稳定、快速地传输数据,避免网络延迟和信号中断。

7. 结论

本文详细介绍了如何使用STM32微控制器及相关硬件和软件,开发一个智能门禁系统。通过人脸识别和RFID验证,系统能够自动控制电磁门锁的开关,确保家庭、办公楼和商业场所的安全性。用户还可以通过Wi-Fi远程监控和控制门禁系统,适应不同的应用场景。该系统的设计和实现为现代门禁管理提供了一个有效的解决方案。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值