【stm32】RTC时钟的介绍与使用

RTC时钟的介绍与使用

  • 一、时间戳
    • 1、Unix时间戳
    • 2、UTC/GMT
    • 3、时间戳转换
  • 二、BKP简介及代码编写
    • 1、BKP简介
    • 2、BKP基本结构
    • 3、BKP库函数介绍:
    • 4、程序编写:
  • 三、RTC简介及代码编写
    • 1、RTC简介
    • 2、RTC框图
    • 2、RTC基本结构
    • 3、RTC相关库函数介绍:
    • 4、程序编写:
    • 5、RTC操作注意事项

一、时间戳

1、Unix时间戳

  • Unix 时间戳(Unix Timestamp)定义为从UTC/GMT的1970年1月1日0时0分0秒开始所经过的秒数,不考虑闰秒
  • 时间戳是一个计数器数值,这个数值表示从1970年1月1日0时0分0秒开始到现在总共所经过的秒数
  • 时间戳存储在一个秒计数器中,秒计数器为32位/64位的整型变量
  • 世界上所有时区的秒计数器相同,不同时区通过添加偏移来得到当地时间
    在这里插入图片描述

2、UTC/GMT

  • GMT(Greenwich Mean Time)格林尼治标准时间(伦敦标准时间)是一种以地球自转为基础的时间计量系统。它将地球自转一周的时间间隔等分为24小时,以此确定计时标准
  • UTC(Universal Time Coordinated)协调世界时是一种以原子钟为基础的时间计量系统。它规定铯133原子基态的两个超精细能级间在零磁场下跃迁辐射9,192,631,770周所持续的时间为1秒。当原子钟计时一天的时间与地球自转一周的时间相差超过0.9秒时,UTC会执行闰秒来保证其计时与地球自转的协调一致

3、时间戳转换

\quad C语言的time.h模块提供了时间获取和时间戳转换的相关函数,可以方便地进行秒计数器、日期时间和字符串之间的转换。
在这里插入图片描述

在这里插入图片描述

二、BKP简介及代码编写

1、BKP简介

  • BKP(Backup Registers)备份寄存器
  • BKP可用于存储用户应用程序数据。当VDD(2.0-3.6V)电源被切断,他们仍然由VBAT(1.8~3.6V)维持供电。当系统在待机模式下被唤醒,或系统复位或电源复位时,他们也不会被复位
    • VSS1、VDD1、VSS2、VDD2、VSS3、VDD3是内部数字部分电路的供电,VDDA、VSSA 是内部模拟部分电路的供电,以上四组以VDD开头的供电,都是系统的主电源,在正常使用STM32时,以上四组供电均都需要接到33V的电源上;VBAT 是备用电池供电引脚,如果要使用STM32内部的BKP和RTC,该引脚必须接备用电池,用来维持BKP和RTC,在VDD主电源掉电后的供电。
  • TAMPER引脚产生的侵入事件将所有备份寄存器内容清除
    • TAMPER引脚:用于安全保障设计
  • RTC引脚输出RTC校准时钟、RTC闹钟脉冲或者秒脉冲(RTC配置)
  • 存储RTC时钟校准寄存器(RTC配置)
  • 用户数据存储容量:
    • 20字节(中容量和小容量设备中BKP为20字节)/ 84字节(大容量和互联型设备中BKP为84字节)

2、BKP基本结构

在这里插入图片描述
\quad 后备区域:指的是BKP备份寄存器、RTC相关电路
\quad STM32后备区域的特性:当VDD主电源掉电时,后备区域仍然可以由VBAT的备用电池供电;当VDD主电源上电时,后备区域供电会由VBAT切换到VDD

3、BKP库函数介绍:

void BKP_DeInit(void);  // 恢复缺省配置
void BKP_TamperPinLevelConfig(uint16_t BKP_TamperPinLevel);// 配置TAMPER引脚的有效电平
void BKP_TamperPinCmd(FunctionalState NewState);// 是否开启侵入检测功能LMDDUGd
void BKP_ITConfig(FunctionalState NewState);// 中断配置,
void BKP_RTCOutputConfig(uint16_t BKP_RTCOutputSource);//时钟输出功能配置
void BKP_SetRTCCalibrationValue(uint8_t CalibrationValue);// 设置RTC校准值
void BKP_WriteBackupRegister(uint16_t BKP_DR, uint16_t Data);// 写备份寄存器
uint16_t BKP_ReadBackupRegister(uint16_t BKP_DR);// 读备份寄存器
FlagStatus BKP_GetFlagStatus(void);
void BKP_ClearFlag(void);
ITStatus BKP_GetITStatus(void);
void BKP_ClearITPendingBit(void);

4、程序编写:

现象:PB1引脚接上按键,按下按键,数组的值写入BKP寄存器,主电源掉电后,能保存最后一次变化的值;若VBT也掉电,则BKP寄存器的值会被清空

#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"
#include "Key.h"uint8_t KeyNum;uint16_t ArrayWrite[] = {0x1234, 0x5678};
uint16_t ArrayRead[2];int main(void)
{OLED_Init();Key_Init();OLED_ShowString(1, 1, "W:");OLED_ShowString(2, 1, "R:");RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE); // 开启PWR的时钟RCC_APB1PeriphClockCmd(RCC_APB1Periph_BKP, ENABLE); // 开启BKP的时钟PWR_BackupAccessCmd(ENABLE); // PWR备份访问控制while (1){KeyNum = Key_GetNum();if (KeyNum == 1){ArrayWrite[0] ++;ArrayWrite[1] ++;BKP_WriteBackupRegister(BKP_DR1, ArrayWrite[0]);BKP_WriteBackupRegister(BKP_DR2, ArrayWrite[1]);OLED_ShowHexNum(1, 3, ArrayWrite[0], 4);OLED_ShowHexNum(1, 8, ArrayWrite[1], 4);}ArrayRead[0] = BKP_ReadBackupRegister(BKP_DR1);ArrayRead[1] = BKP_ReadBackupRegister(BKP_DR2);OLED_ShowHexNum(2, 3, ArrayRead[0], 4);OLED_ShowHexNum(2, 8, ArrayRead[1], 4);}
}

三、RTC简介及代码编写

1、RTC简介

  • RTC(Real Time Clock)实时时钟
  • RTC是一个独立的定时器,可为系统提供时钟和日历的功能
  • RTC和时钟配置系统处于后备区域,系统复位时数据不清零,VDD(2.0-3.6V)断电后可借助VBAT(1.8~3.6V)供电继续走时
  • 32位的可编程计数器,可对应Unix时间戳的秒计数器
  • 20位的可编程预分频器,可适配不同频率的输入时钟
  • 可选择三种RTC时钟源:
    HSE时钟除以128(通常为8MHz/128)
    LSE振荡器时钟(通常为32.768KHz)
    LSI振荡器时钟(40KHz)

2、RTC框图

在这里插入图片描述

  • 核心部分:(中左)分频和计数计时部分, (中右)中断输出使能和NVIC部分,(上)APB1总线读写部分,(下)与PWR关联的部分(作用是RTC的闹钟可以唤醒设备,退出待机模式),灰色区域为后备区域,在主电源掉电后可以使用备用电池维持供电
    • 分频和计数计时部分:RTCCLK—>RTC预分频器进行分频(由两个寄存器组成:重装载寄存器RTC_PRL-也是计数目标、RTC_DIV余数寄存器-自减计数器,存储当前的计数值 )—>32位可编程计数器(可以看作是Unix时间戳的秒计数器,闹钟寄存器RTC_ALR:当CNT的值跟ALR设定的闹钟值一样时,产生RTC_Alarm闹钟信号,通往右边的中断系统,另外一个功能是闹钟信号可以让STM32退出待机模式)
    • 中断部分:以下三个信号可触发中断,
      1、RTC_Second,秒中断,来源于CNT的输入时钟,如果开启此中断,程序会每秒进一次RTC中断
      2、RTC_Overflow,溢出中断,当CNT的32位计数器计满溢出,会触发一次中断
      3、RTC_Alarm,闹钟中断,当计数器和闹钟值相等时,触发中断,同时,闹钟信号可以把设备从待机模式唤醒
    • 中断标志位和中断输出控制:F(Flag)结尾的是对应的中断标志位,IE(Interrupt Enable)结尾的是中断使能,最后3个信号通过一个或门,进入到NVIC中断控制器
    • APB1总线和APB1接口:程序读写寄存器的地方

PCLK1在主电源掉电后停止,为了保证RTC主电源掉电正常工作,RTC里的寄存器都是在RTCCLK的同步下变更的,当我们用PCLK1驱动的总线,去读取RTCCLK驱动的寄存器时,就会有一个时钟不同步的问题,RTC奇存器,只有在RTCCLK的上升沿更新,但是PCLK1的频率36MHZ,远大于RTCCLK的频率32KHZ,如果在APB1刚开启时,就立刻读取RTC奇存器,有可能RTC寄存器还没有更新到APB1总线上,此时读取到的值,就是错误的(通常读取到0),所以要求,在APB1总线刚开启时,等待RTCCLK的触发上升沿后,RTC把它所在寄存器的值同步到APB1总线上,之后再读取的值就是正确的
对于使用库函数,只需在初始化时,调用一个等待同步的函数即可实现

\quad 32位可编程计数器:对应时间戳中的秒计数器,在读取时间时,得到的是秒数,再使用time.h模块里的localtime函数,即可得到年月日时分秒的信息;写入时间时,先填充年月日时分秒信息到struct tm结构体,在用mktime函数,得到秒数,写入32位计数器即可
\quad 20位的可编程预分频器:对于32位秒计数器,1s需要自增一次, 所以驱动计数器的时钟需要1HZ的信号,但实际提供给RTC的时钟RTCCLK的频率较高,此时就需要在提供给计数器时钟前加一个分频器降频,保证分频器输出给计数器的频率为1HZ,计时才是对的,为了适配各种频率的RTCCLK,加了一个20位的分频器,可以选择对输入时钟进行1~2^20范围的分频

高速时钟,一般供内部程序运行和主要外设使用
低速时钟,一般供RTC、看门狗使用

2、RTC基本结构

在这里插入图片描述

3、RTC相关库函数介绍:

// rcc.h
void RCC_LSEConfig(uint8_t RCC_LSE);      // 配置LSE外部低速时钟
void RCC_LSICmd(FunctionalState NewState);// 配置LSI内部低速时钟
void RCC_RTCCLKConfig(uint32_t RCC_RTCCLKSource);// RTCCLK配置,选择RTCCLK的时钟源
void RCC_RTCCLKCmd(FunctionalState NewState);// 启动RTCCLKvoid RTC_ITConfig(uint16_t RTC_IT, FunctionalState NewState);// 配置中断输出
void RTC_EnterConfigMode(void);// 进入配置模式
void RTC_ExitConfigMode(void);// 退出配置模式
uint32_t  RTC_GetCounter(void);// 获取CNT计数器的值  读取时钟
void RTC_SetCounter(uint32_t CounterValue); // 写入CNT计数器的值  设置时间
void RTC_SetPrescaler(uint32_t PrescalerValue);// 写入预分频器(PRL重装寄存器,用来配置预分频器的分频系数)
void RTC_SetAlarm(uint32_t AlarmValue);// 写入闹钟值
uint32_t  RTC_GetDivider(void);// 读取预分频器中的DIV余数寄存器
void RTC_WaitForLastTask(void);// 等待上次操作完成
void RTC_WaitForSynchro(void);// 等待同步
FlagStatus RTC_GetFlagStatus(uint16_t RTC_FLAG);
void RTC_ClearFlag(uint16_t RTC_FLAG);
ITStatus RTC_GetITStatus(uint16_t RTC_IT);
void RTC_ClearITPendingBit(uint16_t RTC_IT);

4、程序编写:

// myRTC.c
#include "stm32f10x.h"                  // Device header
#include <time.h>uint16_t MyRTC_Time[] = {2023, 1, 1, 23, 59, 55};void MyRTC_SetTime(void);void MyRTC_Init(void)
{RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);RCC_APB1PeriphClockCmd(RCC_APB1Periph_BKP, ENABLE);PWR_BackupAccessCmd(ENABLE); // 电源控制寄存器(PWR_CR) 的 DBP 位来使能对后备寄存器和 RTC 的访问// 如果BKP 寄存器被清0,说明备用电池断电,才需要初始化RTC,重新设置时间if (BKP_ReadBackupRegister(BKP_DR1) != 0xA5A5)  {RCC_LSEConfig(RCC_LSE_ON);  // 配置LSE外部低速时钟while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) != SET);// 等待标志位RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE);// 选择RTCCLK时钟源RCC_RTCCLKCmd(ENABLE);  // 使能RTC时钟RTC_WaitForSynchro();  // 等待同步RTC_WaitForLastTask(); // 等待上一次操作完成//RTC_SetPrescaler(32768 - 1); // 配置预分频器;LSE频率:32768HZ,得到1HZ:32768/(32768-1)RTC_WaitForLastTask();  // 等待上一次操作完成MyRTC_SetTime();// 将A5A5写入到BKP寄存器中,备用电源断电才会被清0,确保在有备用电源供电的情况下只初始化一次BKP_WriteBackupRegister(BKP_DR1, 0xA5A5); }else  // 写入BKP寄存器的数据未被清0{RTC_WaitForSynchro(); // 等待同步RTC_WaitForLastTask();// 等待操作完成}
}//如果LSE无法起振导致程序卡死在初始化函数中
//可将初始化函数替换为下述代码,使用LSI当作RTCCLK
//LSI无法由备用电源供电,故主电源掉电时,RTC走时会暂停
/* 
void MyRTC_Init(void)
{RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR, ENABLE);RCC_APB1PeriphClockCmd(RCC_APB1Periph_BKP, ENABLE);PWR_BackupAccessCmd(ENABLE);if (BKP_ReadBackupRegister(BKP_DR1) != 0xA5A5){RCC_LSICmd(ENABLE);while (RCC_GetFlagStatus(RCC_FLAG_LSIRDY) != SET);RCC_RTCCLKConfig(RCC_RTCCLKSource_LSI);RCC_RTCCLKCmd(ENABLE);RTC_WaitForSynchro();RTC_WaitForLastTask();RTC_SetPrescaler(40000 - 1);RTC_WaitForLastTask();MyRTC_SetTime();BKP_WriteBackupRegister(BKP_DR1, 0xA5A5);}else{RCC_LSICmd(ENABLE);while (RCC_GetFlagStatus(RCC_FLAG_LSIRDY) != SET);RCC_RTCCLKConfig(RCC_RTCCLKSource_LSI);RCC_RTCCLKCmd(ENABLE);RTC_WaitForSynchro();RTC_WaitForLastTask();}
}*/void MyRTC_SetTime(void)
{time_t time_cnt;struct tm time_date;// 将时间填入struct tm结构体time_date.tm_year = MyRTC_Time[0] - 1900;time_date.tm_mon = MyRTC_Time[1] - 1;time_date.tm_mday = MyRTC_Time[2];time_date.tm_hour = MyRTC_Time[3];time_date.tm_min = MyRTC_Time[4];time_date.tm_sec = MyRTC_Time[5];time_cnt = mktime(&time_date) - 8 * 60 * 60;   // 日期时间转换成秒计数器RTC_SetCounter(time_cnt);  // 把指定的秒数写入RTC的CNT寄存器RTC_WaitForLastTask();     // 等待操作完成 
}void MyRTC_ReadTime(void)
{time_t time_cnt;struct tm time_date;time_cnt = RTC_GetCounter() + 8 * 60 * 60;  // 读取CNT寄存器中的秒数存储到time_cnt  转换为东八区(+8h)time_date = *localtime(&time_cnt);// 将秒数转成日期时间MyRTC_Time[0] = time_date.tm_year + 1900;MyRTC_Time[1] = time_date.tm_mon + 1;MyRTC_Time[2] = time_date.tm_mday;MyRTC_Time[3] = time_date.tm_hour;MyRTC_Time[4] = time_date.tm_min;MyRTC_Time[5] = time_date.tm_sec;
}
//myRTC.h
#ifndef __MYRTC_H
#define __MYRTC_Hextern uint16_t MyRTC_Time[];void MyRTC_Init(void);
void MyRTC_SetTime(void);
void MyRTC_ReadTime(void);#endif
//main.c
#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"
#include "MyRTC.h"int main(void)
{OLED_Init();MyRTC_Init();OLED_ShowString(1, 1, "Date:XXXX-XX-XX");OLED_ShowString(2, 1, "Time:XX:XX:XX");OLED_ShowString(3, 1, "CNT :");OLED_ShowString(4, 1, "DIV :");while (1){MyRTC_ReadTime();  // 读取RTC时间OLED_ShowNum(1, 6, MyRTC_Time[0], 4);OLED_ShowNum(1, 11, MyRTC_Time[1], 2);OLED_ShowNum(1, 14, MyRTC_Time[2], 2);OLED_ShowNum(2, 6, MyRTC_Time[3], 2);OLED_ShowNum(2, 9, MyRTC_Time[4], 2);OLED_ShowNum(2, 12, MyRTC_Time[5], 2);OLED_ShowNum(3, 6, RTC_GetCounter(), 10);
//        OLED_ShowNum(4, 6, RTC_GetDivider(), 10);// 从32767减到0 为1s// 32767-0 为1000ms 线性转换成0-999 1000msOLED_ShowNum(4, 6, (32767-RTC_GetDivider()) / 32767.0 * 999, 10);// 从32767减到0 为1s}
}

5、RTC操作注意事项

  • 执行以下操作将使能对BKP和RTC的访问:
    设置RCC_APB1ENR的PWREN和BKPEN,使能PWR和BKP时钟
    设置PWR_CR的DBP,使能对BKP和RTC的访问
  • 若在读取RTC寄存器时,RTC的APB1接口曾经处于禁止状态,则软件首先必须等待RTC_CRL寄存器中的RSF位(寄存器同步标志)被硬件置1
  • 必须设置RTC_CRL寄存器中的CNF位,使RTC进入配置模式后,才能写入RTC_PRL、RTC_CNT、RTC_ALR寄存器
  • 对RTC任何寄存器的写操作,都必须在前一次写操作结束后进行。可以通过查询RTC_CR寄存器中的RTOFF状态位,判断RTC寄存器是否处于更新中。仅当RTOFF状态位是1时,才可以写入RTC寄存器

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

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

相关文章

在docker中搭建redis哨兵环境

文章目录 一、引言二、环境准备前提条件目录结构 三、配置文件1. 主节点配置文件 sentinel-master.conf2. 从节点配置文件3. 哨兵配置文件 sentinel.conf4. Docker Compose 文件 四、启动 Docker Compose五、验证哨兵机制1. 检查主节点状态2. 检查从节点状态3. 检查哨兵状态4. …

职场高手揭秘,细节如何左右你的成败与升迁之路

身在职场&#xff0c;每一个人都想得到老板的器重&#xff0c;能不断地加薪、升职&#xff0c;从而获得职场的成功。但你知道&#xff0c;影响一个人职场成功&#xff0c;或者说影响升职加薪的最重要因素是什么吗&#xff1f; 许多人会说那要靠运气&#xff0c;也有人认为工作…

微信小程序 高校教材征订系统

文章目录 项目介绍具体实现截图技术介绍mvc设计模式小程序框架以及目录结构介绍错误处理和异常处理java类核心代码部分展示详细视频演示源码获取 项目介绍 系统分为三个角色&#xff0c;分别是教材科、系教学秘书、教研室主任。系统主要完成功能是教材科要发布教材征订信息&am…

RNN中的梯度消失与梯度爆炸问题

梯度消失与梯度爆炸问题 循环神经网络&#xff08;Recurrent Neural Network&#xff0c;RNN&#xff09;是一类具有短期记忆能力的神经网络&#xff0e;在循环神经网络中&#xff0c;神经元不但可以接受其他神经元的信息&#xff0c;也可以接受自身的信息&#xff0c;形成具有…

Unity网络开发基础(part5.网络协议)

目录 前言 网络协议概述 OSI模型 OSI模型的规则 第一部分 物理层 数据链路层 网络层 传输层 第二部分 ​编辑 应用层 表示层 会话层 每层的职能 TCP/IP协议 TCP/IP协议的规则 TCP/IP协议每层的职能 TCP/IP协议中的重要协议 TCP协议 三次握手 四次挥手 U…

ENSP GVRP动态学习VLAN

手工配置的VLAN称为静态VLAN&#xff0c;通过GVRP协议创建的VLAN称为动态VLAN。 GVRP有三种注册模式&#xff0c;不同的模式对静态VLAN和动态VLAN的处理方式也不同。 GVRP的三种注册模式分别定义如下&#xff1a; Normal模式&#xff1a;允许动态VLAN在端口上进行注册…

【JavaEE初阶 — 多线程】单例模式 & 指令重排序问题

目录 1. 单例模式 (1) 饿汉模式 (2) 懒汉模式 1. 单线程版本 2. 多线程版本 2. 解决懒汉模式产生的线程安全问题 (1) 产生线程安全的原因 (2) 解决线程安全问题 1. 通过加锁让读写操作紧密执行 方法一 方法二 2. 处理加锁引入的新问题 问题描述 …

论文阅读:Computational Long Exposure Mobile Photography (二)

这篇文章是谷歌发表在 2023 ACM transaction on Graphic 上的一篇文章&#xff0c;介绍如何在手机摄影中实现长曝光的一些拍摄效果。 Abstract 长曝光摄影能拍出令人惊叹的影像&#xff0c;用运动模糊来呈现场景中的移动元素。它通常有两种模式&#xff0c;分别产生前景模糊或…

大语言模型鼻祖Transformer的模型架构和底层原理

Transformer 模型的出现标志着自然语言处理&#xff08;NLP&#xff09;技术的一次重大进步。这个概念最初是针对机器翻译等任务而提出的&#xff0c;Transformer 后来被拓展成各种形式——每种形式都针对特定的应用&#xff0c;包括原始的编码器-解码器&#xff08;encoder-de…

解决vue3导出.xlsx的blob文件受损问题

1、 首先要设置get或者post请求的类型。这里我用到post请求 eg&#xff1a;在http.ts中添加公共的方法。 export function post1(url: string, params: any): Promise<AxiosResponse> | Promise<AxiosResponse<any>> {return new Promise((resolve, reject…

Jest项目实战(6):搭建文档网站

搭建文档网站 创建 API 文档可以选择如下的 3 种方式&#xff1a; 功能较少&#xff0c;可以直接写在 README.md 文件里面内容较多&#xff0c;可以单独写一个文件API 数量众多&#xff08;Vue、React 这种级别&#xff09;&#xff0c;需要考虑单独拿一个网站来做详细的文档…

STM32项目---水质水位检测

1 项目简介 1.1 项目需求 本项目通过测量水体的TDS来反映水体的质量。并同时可以测量水位&#xff08;水深&#xff09;。 1.2 系统总体设计 2 硬件模块 2.1 硬件选型 水位测量模块 TDS采集模块 外置ADC模块&#xff08;ADS1115&#xff09; 2.2 水位测量模块使用方法 …

从神经元到神经网络:深度学习的进化之旅

神经元、神经网络 神经元 Neuron )&#xff0c;又名感知机( Perceptron )&#xff0c;在模型结构上与 逻辑回归 一致&#xff0c;这里以一个二维输入量的例子对其进行进一步 的解释&#xff1a; 假设模型的输 入向 量是一 维特征向 (x1,x2). 则单神 经元的模型结构 如下…

银行信贷风控专题:Python、R 语言机器学习数据挖掘应用实例合集:xgboost、决策树、随机森林、贝叶斯等

银行信贷风控专题&#xff1a;Python、R 语言机器学习数据挖掘应用实例合集&#xff1a;xgboost、决策树、随机森林、贝叶斯等 原创 拓端研究室 全文链接&#xff1a;https://tecdat.cn/?p38026 在当今金融领域&#xff0c;风险管控至关重要。无论是汽车贷款违约预测、银行挖掘…

某华迪加现场大屏互动系统mobile.do.php任意文件上传

免责声明 本文章仅供学习与交流&#xff0c;请勿用于非法用途&#xff0c;均由使用者本人负责&#xff0c;文章作者不为此承担任何责任 漏洞描述 该系统是实现现场大屏互动&#xff0c;里面功能众多&#xff0c;但在mobile.do.php接口处存在任意文件上传漏洞 搜索语法 fof…

基于Python的学生宿舍管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

【AI视频换脸整合包及教程】AI换脸新星:Rope——让换脸变得如此简单

在数字技术迅猛发展的今天&#xff0c;人工智能&#xff08;AI&#xff09;的应用已经渗透到了我们生活的方方面面&#xff0c;从日常的语音助手到复杂的图像处理&#xff0c;无不体现着AI技术的魅力。特别是在娱乐和创意领域&#xff0c;AI技术更是展现出了惊人的潜力。其中&a…

A012-基于Spring Boot的私房菜定制上门服务系统的设计与实现

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统私房菜定制上门服务系统信息管理难度大&#xff0c;容错率…

EV录屏好用吗?盘点2024年10款专业好用的录屏软件。

EV录屏的方式有很多种&#xff0c;它设置了很多模式&#xff0c;并且录制高清&#xff0c;可以免费使用。但是现在很多的录屏工具都有着与这个软件相似的功能&#xff0c;在这里我可以给大家列举一些。 1、福昕电脑录屏 这个软件为用户提供了多种录制模式&#xff0c;让视频录…

【网易云插件】听首歌放松放松

先看效果&#xff1a; 网易云有两种类似的插件。 第一种 &#xff1a; iframe 优点&#xff1a;可以自己调整插件的高度、宽度 缺点&#xff1a;很多博客网站不支持嵌入iframe&#xff0c;请试一下您的网站是否支持 登录可直接复制代码。 也可以在我这里 <iframe fram…