首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux 禁用usb设备

在Linux系统中,禁用USB设备可以通过多种方式实现,主要涉及修改内核模块加载、配置udev规则以及使用特定的命令行工具。以下是详细的基础概念、方法及其应用场景:

基础概念

  • USB设备:通用串行总线(USB)设备是一种常见的接口标准,用于连接计算机和外部设备,如鼠标、键盘、存储设备等。
  • 内核模块:Linux内核可以通过加载和卸载模块来动态扩展其功能。USB相关的驱动通常作为内核模块存在。
  • udev:是Linux的设备管理器,负责管理和控制设备节点。

方法及应用场景

1. 使用 echo 命令临时禁用USB端口

这种方法适用于临时禁用某个USB端口,重启后会失效。

代码语言:txt
复制
echo "0" > /sys/bus/usb-serial/drivers/usb-serial/unbind

应用场景:当需要临时断开某个USB设备以便进行维护或防止数据泄露时。

2. 修改 /etc/modprobe.d/blacklist.conf

通过编辑这个文件,可以永久禁用特定的USB驱动模块。

代码语言:txt
复制
blacklist usb_storage

然后运行 update-initramfs -u 更新initramfs。

应用场景:长期禁用某些USB设备,如存储设备,以提高系统安全性。

3. 使用 udev 规则

创建一个新的udev规则文件,例如 /etc/udev/rules.d/99-disable-usb-storage.rules,内容如下:

代码语言:txt
复制
ACTION=="add", SUBSYSTEM=="usb", ATTR{idVendor}=="xxxx", ATTR{idProduct}=="xxxx", RUN+="/bin/sh -c 'echo 0 > /sys$env{DEVPATH}/authorized'"

替换 xxxx 为特定设备的Vendor ID和Product ID。

应用场景:精确控制特定USB设备的启用或禁用,适用于需要根据设备ID进行细粒度管理的场景。

解决常见问题

如果在执行上述操作后USB设备仍然被启用,可能的原因及解决方法包括:

  • 权限问题:确保操作是以root用户或具有足够权限的用户执行的。
  • 内核模块未正确卸载:使用 lsmod | grep usb_storage 检查相关模块是否已加载,并尝试手动卸载。
  • udev规则未生效:重新加载udev规则并重启系统以确保新规则被应用。
代码语言:txt
复制
sudo udevadm control --reload-rules && sudo udevadm trigger

通过这些方法,可以有效地管理和控制Linux系统中USB设备的使用,从而提高系统的安全性和稳定性。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Linux USB 设备基础理论

    通过扫描以下目录获取物理节点所有 USB 设备: /sys/bus/usb/devices/usb* /sys/bus/usb/devices/usb*/$busnum-* 从该文件系统收集某一个设备的主要信息如下...(该总线的第几台设备) speed: 速率 bDeviceClass: 设备类型 idVendor: 设备的生产商ID,由USB设备生产商向USB-IF官方来统一管理和申请 idProduct: 该生产商生产的产品编号...# 定位某一个 USB 设备的方法有两种: busnum + devnum idVendor + idProduct 设备类型bDeviceClass# 类代码 用法 描述 00h 设备描述符 Use...参考文献# USB设备类bDeviceClass、bDeviceSubClass、bDeviceProtocol By USB 中文网 USB设备描述符中的idVendor、idProduct和bcdDevice...By USB 中文网 USB 硬件设备的序列号 By IBM 注:本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。

    42930

    USB设备状态

    当USB设备插上主机时,主机就通过一系列的动作来对设备进行枚举配置(配置是属于枚举的一个态,态表示暂时的状态),这些态如下: 1、接入态(Attached):设备接入主机后,主机通过检测信号线上的电平变化来发现设备的接入...; 2、供电态(Powered):就是给设备供电,分为设备接入时的默认供电值,配置阶段后的供电值(按数据中要求的最大值,可通过编程设置); 3、缺省态(Default):USB在被配置之前,通过缺省地址...0与主机进行通信; 4、地址态(Address):经过了配置,USB设备被复位后,就可以按主机分配给它的唯一地址来与主机通信,这种状态就是地址态; 5、配置态(Configured):通过各种标准的USB...请求命令来获取设备的各种信息,并对设备的某此信息进行改变或设置; 6、挂起态(Suspended):USB总线处于空闲状态的话,该设备就要自动进入挂起状态,在进入挂起状态后,总的电流功耗不超过280UA...是 是 __ __ __ __ __ __ 是 设备在至少3毫秒以内探测不到总线活动,自动进如挂起.设备功能不可用. 下图为设备状态转化图:

    1.7K20

    USB总线-Linux内核USB3.0设备控制器复合设备之legacy方式分析(八)

    2.音频复合设备驱动 从前面的分析中可以看出,复合设备驱动围绕usb_composite_driver和usb_composite_dev两个数据结构展开,legacy方式的复合设备驱动也不例外。...(audio_driver); // 注册audio_driver [include/linux/usb/composite.h] #define module_usb_composite_driver...[include/linux/device.h] #define module_driver(__driver, __register, __unregister, ...) \ static int...USB gadget configfs根据名称查找USB设备控制器,而legacy方式只匹配第一个USB设备控制器,无法匹配指定的USB设备控制器。...若要使用音频设备,则只能通过g_audio驱动构造复合设备,若使用USB虚拟网卡,则只能通过g_ether驱动构造复合设备,若需要多个功能的USB设备,则需要重新构造复合设备,编码定义usb_composite_driver

    4.1K40

    linux usb端点

    一系列相互独立的端点在一起构成了USB逻辑设备,在系统结构中,位于下方红色方框内: 二、端点的分类 每个USB设备都有一个唯一的设备地址,设备地址是设备连接上主机时由主机分配的,主机主要依靠这个设备地址对...USB设备进行访问。...但是需要注意其中的一个特殊端点--端点0,每个USB设备必须要有一个端点0,其作用为对设备枚举和对设备进行一些基本的控制功能,端点0也被称为控制端点。...五、端点与管道 1、管道的概念 管道是主机软件(数据缓存区),和USB设备各各端点之间的数据传输连接,他是两者之间通信流的抽象(实际上数据传输是USB总线接口完成)。...首先,主机向USB设备发出一个请求;接着,就是数据的传送;最后,是一个状态阶段(这部分即一次命令请求的过程)。

    10K31

    网络安全周 - USB 设备

    一、引言随着计算机技术的飞速发展,USB 设备因其便捷性而被广泛应用。然而,这也为恶意攻击者提供了可乘之机。...三、特制鼠标利用漏洞的原理(一)硬件与软件交互漏洞Windows 系统在处理 USB 设备的连接和通信时,存在某些可被利用的交互漏洞。...四、自动修改系统配置的方式与影响(一)修改系统安全设置例如,降低防火墙的防护级别、关闭系统更新、禁用防病毒软件等,使系统更容易受到其他攻击。...(二)USB 设备管理实施严格的 USB 设备接入政策,只允许经过授权的设备接入。(三)安装安全防护软件实时监测系统的异常行为,拦截可疑的 USB 设备操作。...(四)用户安全意识培训提高用户对陌生 USB 设备的警惕性,不随意接入来源不明的设备。

    11110

    C# 获得设备usb信息

    本文告诉大家如何获得设备的usb来进行判断是否有哪些usb和找不到usb可能是什么。...需要在项目右击引用,点击程序集,搜索 System.Management 然后安装他 然后使用下面的代码就可以获得设备的 usb 请看代码 static List<(string DeviceID...} collection.Dispose(); return devices; } 如果需要判断是否存在某个 usb...,就通过 pid vid 判断,判断的方法是拿PNPDeviceID字符串比较 参见:c# 获取移动硬盘信息、监听移动设备的弹出与插入事件 - Chris Cheung - 博客园 如果发现找不到 usb...,可能是在开机的时候进行找usb,一般需要开机之后很久才会把所有的设备添加,所以如果找不到,就看开机的时间,如果太短,那么可能是因为程序太快去查。

    2.1K30

    C# 获得设备usb信息

    本文告诉大家如何获得设备的usb来进行判断是否有哪些usb和找不到usb可能是什么。...需要在项目右击引用,点击程序集,搜索 System.Management 然后安装他 然后使用下面的代码就可以获得设备的 usb 请看代码 static List<(string DeviceID...} collection.Dispose(); return devices; } 如果需要判断是否存在某个 usb...,就通过 pid vid 判断,判断的方法是拿PNPDeviceID字符串比较 参见:c# 获取移动硬盘信息、监听移动设备的弹出与插入事件 - Chris Cheung - 博客园 如果发现找不到 usb...,可能是在开机的时候进行找usb,一般需要开机之后很久才会把所有的设备添加,所以如果找不到,就看开机的时间,如果太短,那么可能是因为程序太快去查。

    2.1K10

    USB干扰无线蓝牙设备整改案例

    环境 下图是系统工作框图,USB3.0外设通过USB线缆与电能连接,USB线缆会辐射出干扰,这个干扰被PC的无线设备接受后产生噪音。...下图是测试环境,近场探头放置在USB设备(硬盘)附近,近场探头采集到的干扰被前置放大后由频谱仪来对干扰进行分析。...下图是分析的结果,灰色曲线是没有USB设备连接时的情况,红色曲线是连接USB设备之后的情况,可以看到没有USB连接时噪声水平大约只有-118dB,而USB设备连接后在2.4GHz附近噪声水平达到了-100dB...下面对USB设备硬盘进行包铜箔处理,如下图所示,一共进行了4种程度的包铜处理,从case1到case4,包的越来越严实,如果缝隙大的话还是有干扰会漏出来。...为了进一步降低干扰,又对连接器进行了屏蔽,下图是屏蔽之后的结果,灰色曲线是没有USB设备连接的情况,噪声水平最低。

    2.4K40
    领券