ADB 实现手机访问电脑上运行的网站,真机调试H5网站

1. 确保准备工作完成

硬件与软件要求

检查环境

  • 在终端中运行以下命令,确认 adb 已正确安装:

    复制代码
    adb version
  • 连接手机后,运行以下命令,查看设备是否被识别:

    复制代码
    adb devices

    如果设备列表为空,请检查 USB 调试是否开启,或尝试更换数据线/USB 接口。

2. 启动本地服务

在电脑上启动你需要调试的本地服务(如 Vue 开发服务器)。假设服务运行在 localhost:8001

3. 通过 ADB 配置端口转发

使用 adb 的端口转发功能,将电脑上的本地服务映射到手机上。

命令格式

xml 复制代码
adb reverse tcp:<本地端口> tcp:<远程端口>

示例

假设你的本地服务运行在 localhost:8003,运行以下命令:

lua 复制代码
adb reverse tcp:8003 tcp:8003

这会将电脑的 8003 端口映射到手机的 8003 端口。

4. 在手机浏览器中访问

在手机浏览器中输入以下地址:

arduino 复制代码
http://localhost:8003

此时,手机会通过 adb 的端口转发访问电脑上的本地服务。

在PC端edg浏览器中输入以下地址:

bash 复制代码
edge://inspect/#devices

点击:inspect 按钮

此时会弹出与手机浏览器同步的调试页面

5. 验证连接

如果页面正常加载,说明配置成功。你可以像平常一样进行调试。


6. 注意事项

  • 端口冲突 :如果 8003 端口已被占用,可以更换为其他端口(例如 80803000)。

  • 服务绑定地址 :确保本地服务绑定到 0.0.0.0,而不仅仅是 127.0.0.1。例如,在 vue.config.js 中设置:

    yaml 复制代码
    javascript
    devServer: {
      host: '0.0.0.0',
      port: 8003
    }
  • 防火墙设置 :确保电脑的防火墙允许 adb 和开发服务器的端口通信。


7. 常见问题排查

问题 1:手机无法访问 localhost

  • 确保 adb reverse 命令已正确执行。
  • 检查本地服务是否正在运行,并且绑定到 0.0.0.0

问题 2:端口转发无效

  • 清除所有 adb 转发规则:

    lua 复制代码
    adb reverse --remove-all
  • 重新执行端口转发命令。

问题 3:USB 连接不稳定

  • 尝试更换 USB 数据线或接口。
  • 使用 adb kill-serveradb start-server 重启 adb 服务。

通过以上步骤,即使手机和电脑不在同一个网络中,也可以通过 adb 让手机访问电脑上运行的网站。

相关推荐
Laravel技术社区34 分钟前
用PHP8实现斗地主游戏,实现三带一,三带二,四带二,顺子,王炸功能(第二集)
前端·游戏·php
m0_738120722 小时前
应急响应——知攻善防Web-3靶机详细教程
服务器·前端·网络·安全·web安全·php
程序员爱钓鱼8 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
PineappleCoder9 小时前
工程化必备!SVG 雪碧图的最佳实践:ID 引用 + 缓存友好,无需手动算坐标
前端·性能优化
JIngJaneIL9 小时前
基于springboot + vue古城景区管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
敲敲了个代码9 小时前
隐式类型转换:哈基米 == 猫 ? true :false
开发语言·前端·javascript·学习·面试·web
澄江静如练_9 小时前
列表渲染(v-for)
前端·javascript·vue.js
JustHappy10 小时前
「chrome extensions🛠️」我写了一个超级简单的浏览器插件Vue开发模板
前端·javascript·github
Loo国昌10 小时前
Vue 3 前端工程化:架构、核心原理与生产实践
前端·vue.js·架构