当心!Win98/ME屏保大漏洞

 


近日在玩屏幕保护时发现了个漏洞,如果有人利用了这个漏洞,就可以不用输入屏保密码进入硬盘,甚至于运行该机中的程序!鉴于这个漏洞对电脑安全有一定的影响,特写出来希望大家能够有所防范。
当你使用的屏幕保护程序为Windows自带的“频道屏幕保护程序”时,就有危险了!通过如下办法可以不经输入密码进入硬盘,甚至于造成更大的破坏!
当频道屏幕保护程序运行后,在屏幕上点击鼠标右键或按键盘使屏保密码输入窗口出现,然后用鼠标拖动输入框,让密码输入窗口中的“取消”按钮刚好在屏幕中央的图片上(就是中心为淡蓝色的锅状卫星天线那个图片,“取消”按钮放在它上面。图1)。把鼠标左键对准“取消”按钮,左右键同时按下(就和你在扫雷中做的那样),如果你做得恰到好处,就会弹出IE的右键菜单(图2)。没出来?再试一次,左右键一起按下然后一起放开即可。在弹出的菜单中选择“图片另存为”,就会弹出“保存图片”对话框,此时就可以访问整个硬盘了,和在Explore里一样,此时你的所有文件夹都暴露在别人的眼皮底下了!但此时无法运行任何程序,因为此时在“保存图片”对话框的“保存类型”栏中只能选择位图文件,无法选择其它文件类型。
如果你的电脑中还装有电子书阅读工具ReadBook,那才真的危险了!因为ReadBook在默认安装状态下是会添加到右键菜单中的(在右键菜单中会增加“用ReadBook阅读”选项),如果有心人对着某个文件夹点击右键就会弹出右键菜单,从中选择“用ReadBook阅读”,ReadBook就会运行!随着ReadBook的运行,原本不可见的任务栏出现了!“开始”菜单也随之而来!现在,这个有心人可以运行“开始”菜单和任务栏上的任何程序了!如果你的开始菜单中有什么危险的程序,那你的系统也就危险了!
注意:如果在该屏保中无法使右键菜单弹出,那是因为你在按动鼠标左右键时,没有同时按下,或者是按动时“取消”按钮不在图片上。你可等到该屏保屏幕中央的图片自动变大时再点击,就会成功调出右键菜单。 注:以上在Win98及Win ME中发现有此漏洞,Win2000等未试。
解决方案:不使用Windows自带的“频道屏幕保护程序”,换个其它的屏保使用就不会有这个麻烦了!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个基于STM32F103和AD8232的心电信号采集和心率计算的示例程序。请注意,这是一个简单的示例,可能需要根据具体硬件和应用进行调整。 ```c #include "stm32f10x.h" #include "stdio.h" #define ADC1_DR_Address ((uint32_t)0x4001244C) // ADC1数据寄存器地址 #define SAMPLE_SIZE 500 // 采样点数 #define THRESHOLD 500 // 心电信号阈值,可根据实际情况调整 uint16_t ADCValue[SAMPLE_SIZE]; // ADC采样值数组 uint16_t heartRate = 0; // 心率变量 void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); } void ADC_Configuration(void) { ADC_InitTypeDef ADC_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE); ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; ADC_InitStructure.ADC_ScanConvMode = DISABLE; ADC_InitStructure.ADC_ContinuousConvMode = ENABLE; ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; ADC_InitStructure.ADC_NbrOfChannel = 1; ADC_Init(ADC1, &ADC_InitStructure); ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_55Cycles5); ADC_Cmd(ADC1, ENABLE); ADC_ResetCalibration(ADC1); while (ADC_GetResetCalibrationStatus(ADC1)) ; ADC_StartCalibration(ADC1); while (ADC_GetCalibrationStatus(ADC1)) ; ADC_TempSensorVrefintCmd(ENABLE); } void TIM_Configuration(void) { TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); TIM_TimeBaseStructure.TIM_Period = 999; // 1ms中断一次 TIM_TimeBaseStructure.TIM_Prescaler = 7199; // 72MHz计时器时钟分频7200 TIM_TimeBaseStructure.TIM_ClockDivision = 0; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE); TIM_Cmd(TIM2, ENABLE); } void NVIC_Configuration(void) { NVIC_InitTypeDef NVIC_InitStructure; NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1); NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); } void TIM2_IRQHandler(void) { static uint16_t index = 0; static uint16_t lastValue = 0; uint16_t adcValue; if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) { TIM_ClearITPendingBit(TIM2, TIM_IT_Update); adcValue = ADC_GetConversionValue(ADC1); // 读取ADC采样值 if (adcValue > THRESHOLD && lastValue <= THRESHOLD) // 心电信号上升沿 { heartRate = 60000 / (index * 2); // 计算心率 index = 0; } lastValue = adcValue; ADCValue[index++] = adcValue; // 存储采样值 if (index >= SAMPLE_SIZE) // 采样完成 { TIM_Cmd(TIM2, DISABLE); // 停止计时器 } } } int main(void) { GPIO_Configuration(); ADC_Configuration(); TIM_Configuration(); NVIC_Configuration(); while (1) { if (heartRate != 0) { printf("Heart rate: %d bpm\n", heartRate); heartRate = 0; TIM_Cmd(TIM2, ENABLE); // 重新启动计时器 } } } ``` 该程序的核心部分是在TIM2中断中读取ADC采样值并计算心率。当心电信号上升沿被检测到时,根据采样点数和时间间隔计算出心率值。在计算心率过程中,也可以将采样值存储到数组中,用于后续的信号处理和分析。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值