0

0

怎样利用WebUSB API与硬件设备进行通信?

幻影之瞳

幻影之瞳

发布时间:2025-09-27 14:37:01

|

560人浏览过

|

来源于php中文网

原创

WebUSB API允许网页通过浏览器直接与USB设备通信。在安全上下文下,调用navigator.usb.requestDevice()请求设备连接,用户授权后获得访问权限。接着调用device.open()打开设备,selectConfiguration()选择配置,claimInterface()独占接口。使用transferOut()发送数据,transferIn()接收数据,实现与硬件交互。需在用户操作中触发请求,监听disconnect事件处理设备断开,捕获异常确保稳定性。该技术适用于调试工具、教育设备和IoT面板,在Chrome等支持环境中实用性强。

怎样利用webusb api与硬件设备进行通信?

WebUSB API 让网页可以直接与 USB 设备通信,无需安装原生驱动或专用软件。只要浏览器支持(目前主要为 Chrome 及基于 Chromium 的浏览器),你就可以在网页中读取和控制兼容的 USB 硬件。

启用 WebUSB 并请求设备连接

要使用 WebUSB,必须通过安全上下文(即 HTTPS 或 localhost)运行页面。第一步是请求用户选择一个 USB 设备:

  • 调用 navigator.usb.requestDevice() 并传入过滤条件(如 vendorId 和 productId)
  • 用户会看到系统级设备选择对话框,授权后获得对设备的访问权限

示例代码:

navigator.usb.requestDevice({ filters: [{ vendorId: 0x1234 }] })
  .then(device => {
    console.log('已连接设备:', device.productName);
  })
  .catch(error => {
    console.error('用户拒绝或未找到设备:', error);
  });

打开设备并配置接口

获取设备实例后,需要打开它并设置正确的配置和接口,才能进行数据传输:

  • 调用 device.open() 打开设备连接
  • 多数设备需选择一个配置(通常为 configuration[0])
  • 接着 claimInterface() 来独占某个接口,防止其他程序干扰

示例流程:

device.open()
  .then(() => device.selectConfiguration(1))
  .then(() => device.claimInterface(0))
  .then(() => { console.log('设备就绪'); });

发送与接收数据

设备准备好后,即可通过控制传输、中断传输或批量传输与硬件交互:

可赞AI
可赞AI

文字一秒可视化,免费AI办公神器

下载
  • 使用 transferOut() 向设备发送数据(例如控制指令)
  • 使用 transferIn() 从设备读取数据(需指定端点号)
  • 某些设备需持续轮询或监听中断,可用循环或 await 响应

发送数据示例:

const data = new Uint8Array([0x01, 0x02, 0x03]);
device.transferOut(0x01, data);

接收数据示例:

device.transferIn(0x81, 64)
  .then(result => {
    const received = new Uint8Array(result.data.buffer);
    console.log('收到数据:', received);
  });

处理权限与错误

WebUSB 受严格安全限制,常见问题包括权限拒绝、设备断开或接口被占用:

  • 始终在用户操作(如点击按钮)中调用 requestDevice,避免自动弹窗被拦截
  • 监听 disconnect 事件及时清理状态:navigator.usb.addEventListener('disconnect', ...)
  • 捕获异常并提示用户重新连接或检查设备

基本上就这些。WebUSB 简化了网页与硬件的对接流程,适合开发调试工具、教育设备或 IoT 控制面板。虽然目前兼容性有限,但在受控环境下非常实用。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

826

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

741

2023.11.06

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1074

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

149

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1220

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

16

2026.01.19

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2065

2024.08.16

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

27

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

7

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
如何进行WebSocket调试
如何进行WebSocket调试

共1课时 | 0.1万人学习

TypeScript全面解读课程
TypeScript全面解读课程

共26课时 | 5万人学习

前端工程化(ES6模块化和webpack打包)
前端工程化(ES6模块化和webpack打包)

共24课时 | 5.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号