紧急提醒,你的计算机或许已中招,赶快进行排查

news2024/11/15 18:24:11

大家早上好,我是YUAN。

这几天,安全圈又曝出了一个重大漏洞。如果你的电脑使用的是技嘉-GIGABYTE主板,那么你可能已经中招了,但还不知情。

在介绍这个漏洞之前,让我们思考一个问题:如果产品经理让你实现一个自动检测更新的功能,你会怎么做呢?

9eef6f422da90961470cd09749070a1b.jpeg

这是一个很常见的功能,包括微信、浏览器等常用软件都拥有这个功能。通常的实现方法是,在软件启动时与后台通信,如果发现新版本,就从指定地址下载最新的安装包进行安装。这种实现方法看起来很简单,但是从安全的角度来看,其中存在什么风险呢?

首先,我们如何确保与真正的后台进行通信,而不是被攻击者引导到一个假地址上?

其次,我们如何确保下载的安装包是正确的,没有被篡改?

为了实现一个安全的升级程序,我们需要确保与真正的后台建立通信,并确保下载到的程序确实是我们的程序,未被篡改。通常,我们会使用HTTPS进行通信,并使用数字签名校验等手段来确保安全性。

然而,技嘉-GIGABYTE近日曝出的漏洞就是在检测更新这个功能上犯了错。

bdbf815099589fbcea8d88c8bc7cab39.jpeg

国外专注固件的网络安全公司Eclypsium披露,他们在台湾制造商技嘉出售的主板固件中发现了漏洞。当技嘉主板重新启动时,主板固件中的代码会启动一个更新程序,该程序会下载并执行另一个软件。问题出在更新机制上,逆向分析发现,这个更新程序对下载的内容完全没有进行校验就直接运行了。更糟糕的是,这个更新程序在某些情况下可以使用HTTP而不是HTTPS进行下载。

c567d11613c0e9f3fd313709f77b5e3a.jpeg

如果黑客通过某些手段将HTTP中访问的域名劫持到自己的服务器上,那么技嘉更新程序将下载黑客预先准备的恶意程序,例如勒索软件、挖矿程序、木马或其他任意程序。因为技嘉没有进行任何校验!

2c5c5742d0fd55d7de19d0584182fe6b.jpeg

那么,使用HTTPS就一定安全了吗?很遗憾,并不一定。逆向分析发现,技嘉并未对HTTPS连接过程中的服务器证书进行校验,黑客同样可以构建假的HTTPS服务进行攻击。

427009bd025401cba52b843d760f2814.jpeg

一般来说,浏览器访问HTTPS相对安全是因为浏览器会验证服务器证书的可信性,一旦发现不可信,就会显示警告信息。

关于浏览器如何验证证书的可信性,可以参考我之前写过的一篇文章:

为了一个HTTPS,浏览器操碎了心!

08b07a70ebb3a81ab44b4e06c94ccdf9.jpeg

实现自动检测更新的功能是非常常见的,但是很多程序员为了简单省事,只是实现了这个功能而没有考虑安全性。对于一些小公司而言,他们开发了一些简单的软件,用户数量不多,黑客也不会注意到他们。但是,一旦这些软件的用户数量增加,就需要重视安全问题了。特别是像微信、抖音这样的国民应用,如果发现此类安全问题,那将是一场灾难。

因此,程序员们需要多了解一些安全知识,这对大家来说是有益的。据报道,受此漏洞影响的PC计算机规模可能高达几百万。如果你使用技嘉-GIGABYTE主板的电脑,建议立即检查一下。

最后,让我们思考一下,这个漏洞是否只是技嘉-GIGABYTE的一个错误呢?欢迎在评论区留言分享你的看法。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于Selenium+Python实现自动解数独,秒变最强大脑

前言 在本文中,我将向大家介绍如何使用Python编写一个数独脚本,并实现模拟完成数独游戏的脚本。数独是一种经典的逻辑游戏,它可以帮助我们锻炼逻辑思维能力。通过编写数独脚本,我们可以使用Python语言解决数独问题,从而…

一、枚举类型——新特性(模式匹配-覆盖范围)

模式匹配会引导你逐渐使用 sealed 关键字,这有助于确保你已覆盖了所有可能传入选择器表达式的类型。不过接下来再看一个示例: SealedPatternMatch.java JDK 17 import java.util.List;sealed interface Transport { };record Bicycle(String id) impleme…

第八章:YOLO v3(渐进式改进)网络详解

(目标检测篇)系列文章目录 第一章:R-CNN网络详解 第二章:Fast R-CNN网络详解 第三章:Faster R-CNN网络详解 第四章:SSD网络详解 第五章:Mask R-CNN网络详解 第六章:YOLO v1网络详解 第七章:YOLO v2网络详解 第八章:YOLO v3网络详解 文章目录 系列文章目录技…

ruiyo-cloud-plus集成shardingsphere-proxy进行分库分表

一、什么shardingsphere-proxy Sharding-Proxy是ShardingSphere的第二个产品。 它定位为透明化的数据库代理端,提供封装了数据库二进制协议的服务端版本,用于完成对异构语言的支持。 目前先提供MySQL版本,它可以使用任何兼容MySQL协议的访问…

阿里云轻量应用服务器和云服务器ECS有什么区别?

阿里云服务器ECS和轻量应用服务器有什么区别?云服务器ECS是明星级云服务器,轻量应用服务器可以理解为简化版的云服务器ECS,轻量适用于单机应用,云服务器ECS适用于集群类高可用高容灾应用,阿里云百科来详细说下阿里云轻…

用栈实现队列——力扣232

题目描述 思路 class MyQueue {stack<int> inStack, outStack;void in2out(){while(!inStack.empty()){outStack.push(inStack.top());inStack.pop();}} public:MyQueue() {}void push(int x) {inStack.push(x);}int pop() {if(outStack.empty()){in2out();}int x out…

etiger.vip 答案 1907最高的山

1907.最高的山 题目描述 有n座山&#xff0c;编号从1到n&#xff0c;第i座山的高度为hi&#xff0c;请问其中最高的山是哪一座&#xff1f; 输入输出格式 输入格式 第一行一个正整数n&#xff0c;表示山的数量&#xff0c;n<1000。 第二行n个正整数&#xff0c;中间由空…

四元数转换为一个旋转矩阵

#include <iostream> #include <vector> #include <Eigen/Core> #include <Eigen/Geometry> #

回调函数的应用(sqort函数)——指针进阶(三)

目录 前言 什么是回调函数&#xff1f; 回调函数的应用 qsort函数 qsort函数的使用 qsort模拟实现 模拟函数的使用 总结 前言 回调函数是一种非常常见的编程技术&#xff0c;在许多不同的编程语言和框架中都有广泛的应用。但它到底是什么&#xff0c;以及如何使用呢&#xff1…

-XX:MaxDirectMemorySize

-XX:MaxDirectMemorySize最大堆外内存大小&#xff0c;此参数的含义是当Direct ByteBuffer分配的堆外内存到达指定大小后就触发Full GC。首先可以在jdk文档中找到&#xff1a;关于MaxDirectMemorySize内存的描述&#xff1a;Sets the maximum total size (in bytes) of the New…

02_06内核cpu信息及内存布局及堆管理及内存使用情况

linux_cpu_大致信息查看 因为需要知道当前linux cpu是多少位的,才能知道内核空间的分布 64位Linux-般使用48位来表示虚拟地址空间&#xff0c;45位表示物理地址。通过命令: cat/proc/cpuinfo。 查看Linux内核位数和proc文件系统输出系统软硬件信息如下: 通过cat /proc/cpuinfo…

RabbitMQ笔记--消息中间件,rabbitmq安装及简单使用

1.消息中间件 消息&#xff1a;指在应用间传送的数据。 消息队列中间件&#xff1a;指利用高效可靠的消息传递机制进行与平台无关的数据交流&#xff0c;并基于数据通信来进行分布式系统的集成。通过提供消息传递和消息排队模型&#xff0c;可以在分布式环境下扩展进程间的通…

unittest自动化测试之unittest封装方法

目录 封装方法 完整代码 总结&#xff1a; 封装方法 在编写自动化脚本的时候&#xff0c;都要求代码简介&#xff0c;上一篇unittest---unittest断言中代码重复性比较多&#xff0c;我们进行一次简单的优化&#xff08;优化方法不同&#xff0c;请勿喷&#xff09; 我们可以…

Video4linux: cannot set V4L control... 解决方案

问题描述 最近在用USB_CAM读取摄像头的时候&#xff0c;总是出现如下问题&#xff1a; 思来想去真是难受。 问题分析 在usb_cam/ config /usb_cam.yaml文件中&#xff0c;把他报错的东西加在ignore里面即可。 首先打开camera_driver.cpp文件&#xff0c;把908行的printf语句…

ARM64学习笔记---建立异常向量表(二)

源码: #include "mm.h" #include "sysregs.h".section .rodata .align 3 .globl el_string1 el_string1:.string "Booting at EL".section ".text.boot" .globl _start _start://读取mpidr_el1寄存器的值&#xff0c;该寄存器决定了…

学无止境·MySQL(4-3)(多表查询加强版-------更新版)

比4-2表中多几个数据&#xff0c;更具备普遍性 试题2&#xff08;更新加强版&#xff09;1、创建表2、找出销售部门中年纪最大的员工的姓名3、求财务部门最低工资的员工姓名4、列出每个部门收入总和高于9000的部门名称5、求工资在7500到8500元之间&#xff0c;年龄最大的人的姓…

MySql 高级-0706

1. MySQL 架构 1.1 MySQL 简介 mysql内核 sql优化攻城狮 mysql服务器的优化 各种参数常量设定 查询语句优化 主从复制 软硬件升级 容灾备份 sql编程 1.2 MySQL逻辑架构介绍 1.2.1第1层:连接层 ** 系统(客户端)访问 MySQL 服务器前&#xff0c;做的第一件事就是建立 TCP 连接…

HTML <map> 标签

实例 带有可点击区域的图像映射: <img src="planets.jpg" border="0" usemap="#planetmap" alt="Planets" /><map name="planetmap" id="planetmap"><area shape="circle" coords=&q…

多元分类预测 | Matlab 粒子群算法(PSO)优化xgboost的分类预测,多输入单输出模型。PSO-xgboost分类预测模型

文章目录 效果一览文章概述部分源码参考资料效果一览 文章概述 多元分类预测 | Matlab 粒子群算法(PSO)优化xgboost的分类预测,多输入单输出模型。PSO-xgboost分类预测模型 多特征输入单输出的二分类及多分类模型。程序内注释详细,直接替换数据就可以用。程序语言为matlab,程…

利用Python构建科学的交易系统:以趋势为例

在股票市场中&#xff0c;趋势被认为是一个非常重要的概念。趋势可以通过股票的价格、交易量等指标来确定。如果一只股票的价格在持续上涨&#xff0c;那么我们可以认为该股票处于上升趋势&#xff1b;反之&#xff0c;如果一只股票的价格在持续下跌&#xff0c;那么我们认为该…