添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

Repository files navigation

Redmi AX6S 解锁 SSH、刷入 OpenWRT 教程

解锁 Telnet & SSH

更新系统 ROM 版本到开发版,开发版默认已开启 Telnet
使用浏览器进入小米路由器管理后台,进入 常用设置 -> 系统状态 ,点击 手动升级 ,选择下载好的开发版固件点击开始升级。

Redmi AX6S 开发版固件下载地址: miwifi_rb03_firmware_stable_1.2.7.bin

获取 Telnet & SSH 登录路由器的 root 用户密码
打开 https://miwifi.dev/ssh ,输入小米路由器管理后台首页显示的序列号(SN),点击 Calc 即可计算出密码。

手动开启 SSH 服务
使用 Telnet 协议连接路由器,执行下面 开启 SSH 服务 的命令,命令执行成功后就可以使用 SSH 协议连接路由器了。

# Telnet 连接信息
IP 地址:192.168.31.1
端口号:23
用户名:root
密码:上一步获取的密码
# SSH 连接信息
IP 地址:192.168.31.1
端口号:22
用户名:root
密码:上一步获取的密码
# 开启 SSH 服务
nvram set telnet_en=1 && nvram set ssh_en=1 && nvram set uart_en=1 && nvram set boot_wait=on && nvram commit
/etc/init.d/dropbear enable & /etc/init.d/dropbear start

自动开启 SSH 服务
经过上面的步骤,已经成功在小米路由器上解锁 SSH 服务,但是由于小米路由器是 Snapshot 系统,重启会重置为最初状态,导致解锁 SSH 失效。
解决办法:创建一个脚本添加到开机自启动,来实现自动开启 SSH 服务:

# 创建一个目录
mkdir /data/auto_ssh && cd /data/auto_ssh
# 下载脚本文件,使用 GitHub 地址下载失败可以使用 jsDelivr CDN 地址进行下载
# GitHub 地址
curl -kfsSL -O https://raw.githubusercontent.com/lemoeo/AX6S/main/auto_ssh.sh && chmod +x auto_ssh.sh
# jsDelivr CDN 地址
curl -kfsSL -O https://cdn.jsdelivr.net/gh/lemoeo/AX6S@main/auto_ssh.sh && chmod +x auto_ssh.sh
# 执行下面命令解锁 SSH 并添加开机自启动
./auto_ssh.sh install

如果不需要自动开启 SSH 服务,使用下面命令移除开机自启动:

./auto_ssh.sh uninstall

如何切换回稳定版系统
小米路由器是双系统分区,系统更新会刷写到另一个分区然后从另一个分区启动,所以更新开发版之后,之前的稳定版系统还存在于原来的分区。可以通过修改引导分区切换回升级前的系统。

首先查看当前引导分区:

nvram get flag_last_success

如果查看当前引导分区返回结果为 0 ,说明当前开发版系统在 0 分区,更新之前的稳定版系统就在 1 分区。执行命令修改引导分区为 1 分区并重启路由器:

nvram set flag_last_success=1
nvram set flag_boot_rootfs=1
nvram commit
reboot

同理,如果查看当前引导分区返回结果为 1 ,那么更新之前的稳定版系统就在 0 分区。执行命令修改引导分区为 0 分区并重启路由器:

nvram set flag_last_success=0
nvram set flag_boot_rootfs=0
nvram commit
reboot

因为我们已经添加了 自动开启 SSH 服务 的脚本,理论上只要不恢复出厂设置或者重新刷机,切换回稳定版系统或者系统升级都不会影响自动开启 SSH 服务。

如果恢复出厂设置或者进行了刷机,需要重新刷入开发版固件进行解锁 SSH 的操作。
想要恢复出厂设置或者刷机后不用再刷入开发版固件,可以参考下面的 固化 Telnet & SSH 教程。

固化 Telnet & SSH

首先使用 SSH 协议连接路由器

备份 Bdata 和 crash 分区

执行命令 cat /proc/mtd ,查看 name 为 Bdata 和 crash 对应的 dev 信息。
例如:Bdata 和 crash 对应的 dev 分别为 mtd5 和 mtd7。

执行下面命令备份 Bdata 和 crash,如果你的 Bdata 和 crash 不是 mtd5 和 mtd7,将 mtd5 和 mtd7 替换为对应的值即可:

nanddump -f /tmp/Bdata_mtd5.img /dev/mtd5
nanddump -f /tmp/crash_mtd7.img /dev/mtd7

打开 WinSCP ,使用 SCP 协议连接路由器,将备份的 Bdata_mtd5.img 和 crash_mtd7.img 下载保存。

使用 HxD.exe 打开 Bdata_mtd5.img,将 telnet_en、ssh_en、uart_en 的值修改为 1 ,如图所示:

复制 boot_wait=on ,以覆盖方式粘贴到图中位置:

此时修改后的结果如图所示:

计算校验和,首先点击 编辑 -> 选择块

起始偏移输入 4 ,结束偏移输入 FFFF ,点击 确定

点击 分析 -> 校验码

选择 CRC-32 ,点击 确定

将开头四个字节修改为计算出的校验和的逆序的方式:

修改完成,点击 保存

首先使用 WinSCP,将修改后的 crash_mtd7.img 上传到路由器的 /tmp 目录下,执行下面命令刷入并重启路由器:

mtd -r write /tmp/crash_mtd7.img crash
reboot

上传修改后的 Bdata_mtd5.img,执行命令刷入并重启路由器:

mtd -r write /tmp/Bdata_mtd5.img Bdata
reboot

清除解锁(修复 WIFI 客户端数量显示、Internet 灯不亮等一些奇怪的问题)

mtd erase crash
reboot

固化后如何解锁 SSH 服务

因为官方固件中默认限制了稳定版不能打开 SSH 服务,所以即便进行了固化操作,在恢复出厂设置或者刷机之后,SSH 服务默认也是关闭状态,但是 Telnet 默认是开启状态。此时可以通过 Telnet 连接路由器,进行如下操作解锁 SSH 服务。

临时解锁 SSH 服务(路由器重启会失效)
使用 Telnet 协议连接路由器,执行下面命令即可:

sed -i 's/channel=.*/channel=\"debug\"/g' /etc/init.d/dropbear
/etc/init.d/dropbear restart

自动解锁 SSH 服务
由于小米路由器 Snapshot 系统的特性,重启会恢复系统文件导致解锁 SSH 失效,创建一个脚本添加到开机自启动,来实现自动开启 SSH 服务:

# 创建一个目录
mkdir /data/auto_ssh && cd /data/auto_ssh
# 下载脚本文件,使用 GitHub 地址下载失败可以使用 jsDelivr CDN 地址进行下载
# GitHub 地址
curl -kfsSL -O https://raw.githubusercontent.com/lemoeo/AX6S/main/auto_ssh.sh && chmod +x auto_ssh.sh
# jsDelivr CDN 地址
curl -kfsSL -O https://cdn.jsdelivr.net/gh/lemoeo/AX6S@main/auto_ssh.sh && chmod +x auto_ssh.sh
# 执行下面命令解锁 SSH 并添加开机自启动
./auto_ssh.sh install

移除开机自动解锁 SSH 服务:

./auto_ssh.sh uninstall

参考教程:
https://www.right.com.cn/forum/thread-8206757-1-1.html
https://www.wutaijie.cn/?p=254

刷入 OpenWRT 固件

【20220427】AX6S 开源/闭源无线驱动Openwrt 刷机教程/固件下载
[更新v3][20220417]红米AX6S LEDE R22.4.1定制化多功能OpenWrt固件
[更新][220423]红米AX6S OpenWrt官方master分支自用养老固件
OpenWrt 官方固件

刷入下载的固件

使用 WinSCP 将下载的固件中的 factory.bin 上传到路由器的 /tmp 目录下。

使用 SSH 链接路由器,执行命令:

# 设置启动第一个系统分区
nvram set flag_last_success=0 & nvram set flag_boot_rootfs=0
# 保存设置
nvram commit
# 刷入过度固件 factory.bin 到第一个系统分区 firmware 并重启路由器
mtd -r write /tmp/factory.bin firmware

路由器重启完成之后,打开 http://192.168.6.1 进入 OpenWRT 后台管理界面
用户名:root
密码:password
登录之后依次点击进入 系统 -> 备份/升级 -> 刷写新的固件
去掉勾选 保留配置 ,选择下载的固件 mt76.bin 或 open2.4g.bin 或者你下载的其它固件,点击 刷写固件 -> 处理
等待固件刷入完成即可。

桥接模式下访问光猫后台

小米路由器官方系统

SSH 连接路由器

编辑网络接口配置文件 vim /etc/config/network ,找到 wan 相关配置如下:

config interface 'wan'
        option proto 'pppoe'
        option mtu '1500'
        option special '0'
        option username 'xxxxxxxxxxxx'
        option mru '1480'
        option password 'xxxxxx'
        option ifname 'eth1'
        option last_succeed '1'
        option ipv6 'auto'

其中 option ifname 'eth1' 表示此接口使用的物理网卡是 eth1

编辑文件 /etc/config/network,在文件尾部添加如下配置:

config interface 'modem'
        option proto 'static'
        option ifname 'eth1'
        option ipaddr '192.168.1.100'
        option netmask '255.255.255.0'

注意:option ifname 和 wan 的 option ifname 相同,option ipaddr 设置为和光猫相同网段的IP地址。

编辑防火墙配置文件 vim /etc/config/firewall,找到如下配置:

config zone
        option name 'wan'
        list network 'wan'
        list network 'wan6'
        option input 'REJECT'
        option output 'ACCEPT'
        option forward 'REJECT'
        option masq '1'
        option mtu_fix '1'

list network 'wan6' 下面添加一行 list network 'modem', 修改完成后的配置如下:

config zone
        option name 'wan'
        list network 'wan'
        list network 'wan6'
        list network 'modem'
        option input 'REJECT'
        option output 'ACCEPT'
        option forward 'REJECT'
        option masq '1'
        option mtu_fix '1'

保存文件,重启路由器即可访问光猫后台管理界面。

参考教程:
https://blog.csdn.net/qq1337715208/article/details/121570165

OpenWRT 系统

打开 OpenWRT 后台管理界面,在 网络 -> 接口 中添加一个新的接口配置如下:

名称:modem
协议:静态地址
接口:选择和 wan 相同的接口

点击 提交,然后在 modem 接口基本设置中 IPv4 地址设置为与光猫相同网段的地址,子网掩码设置为 255.255.255.0,防火墙设置中区域分配为 wan,配置如下:

# 基本设置
IPv4 地址:192.168.1.100
IPv4 子网掩码:255.255.255.0
# 防火墙设置
创建/分配防火墙区域:wan

点击 保存&应用,即可访问光猫管理界面。