小米路由器开启SSH,设置阿里云ddns,开启外网访问SSH和WEB管理界面 ...

打印 上一主题 下一主题

主题 1011|帖子 1011|积分 3033


媒介

例如:随着人工智能的不停发展,机器学习这门技能也越来越重要,许多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。

提示:以下是本篇文章正文内容,下面案例可供参考
一、开启SSH

这里使用的是github上的开源项目XMiR-Patcher实现。
https://github.com/openwrt-xiaomi/xmir-patcher
下载项目到本地。
然后运行以下命令,必要留意的是linux或mac必要安装python3.8和openssl


  • Windows
    Run run.bat
  • Linux / Mac OS
    Install python 3.8, openssl
    Run run.sh
运行并输入ip和密码
先输入路由器ip-》回车-》输入2-》数据路由器密码
乐成后ssh的账号密码都为root
  1. ==========================================================
  2. Xiaomi MiR Patcher
  3. 1 - Set IP-address (current value: 192.168.31.1)
  4. 2 - Connect to device (install exploit)
  5. 3 - Read full device info
  6. 4 - Create full backup
  7. 5 - Install EN/RU languages
  8. 6 - Install Breed bootloader
  9. 7 - Install firmware (from directory "firmware")
  10. 8 - {{{ Other functions }}}
  11. 9 - [[ Reboot device ]]
  12. 0 - Exit
  13. Select: 192.168.31.1 #输入自己的路由器ip
  14. ==========================================================
  15. Xiaomi MiR Patcher
  16. 1 - Set IP-address (current value: 192.168.31.1)
  17. 2 - Connect to device (install exploit)
  18. 3 - Read full device info
  19. 4 - Create full backup
  20. 5 - Install EN/RU languages
  21. 6 - Install Breed bootloader
  22. 7 - Install firmware (from directory "firmware")
  23. 8 - {{{ Other functions }}}
  24. 9 - [[ Reboot device ]]
  25. 0 - Exit
  26. Select: 2 # 选择2 然后根据提示输入密码
复制代码
二、设置阿里云ddns

小米路由器本身自带了ddns,但是局限性比较高只能用以下4种。

1.准备工作

怎样想使用自己的域名,必要上阿里云购买一个域名。
   注册AccessKey
首先登录个人的阿里云账号,我的是RAM账户。各位的可以使用主账户进利用用AccessKey。
点击ACCESSKEY管理
创建你的AccessKey,并记录下来。
  留意如果是RAM的话一定要添加AliyunDNSFullAccess授权策略
2.创建ddns脚本

aliyun_ddns.sh
  1. #!/bin/sh
  2. set -e
  3. #================================================================================================================#
  4. # 功能:用于更新阿里云域名IP,实现DDNS功能
  5. #
  6. # 在 http://www.gebi1.com/forum.php?mod=viewthread&tid=287344&page=1&_dsign=8f94f74c 提供的脚本文件基础上修改的。
  7. # ghui, modified 12/2/2019
  8. # 在 N1 debian Buster with Armbian Linux 5.3.0-aml-g12 手动执行/定时任务(crontab)执行测试通过
  9. #================================================================================================================#
  10. #
  11. # 使用方法:
  12. #
  13. # 方法1. 外部参数
  14. # 修改源码,将对应参数 修改为$1,$2,$3,$4,$5,$6
  15. # aliddns.sh <aliddns_ak> <aliddns_sk> <aliddns_subdomain> <aliddns_domain> <aliddns_iptype> <aliddns_ttl>
  16. # 示例(A 代表 IPv4,AAAA 代表 IPv6):
  17. # 执行:aliddns.sh "xxxx" "xxx" "test" "mydomain.site" "A" 600
  18. # 执行:aliddns.sh "xxxx" "xxx" "test" "mydomain.site" "AAAA" 600
  19. #
  20. # 方法2. 内部参数
  21. # 修改源码,将$1,$2,$3,$4,$5,$6 替换为对应参数
  22. #
  23. # 示例:
  24. # aliddns_ak="<aliddns_ak>"
  25. # aliddns_sk="<aliddns_sk>"
  26. # aliddns_subdomain="<aliddns_subdomain>"
  27. # aliddns_domain="<aliddns_domain> "
  28. # aliddns_iptype="<aliddns_iptype>"
  29. # aliddns_ttl=<aliddns_ttl>
  30. # 执行:aliddns.sh
  31. #
  32. #================================================================================================================#
  33. #--------------------------------------------------------------
  34. # 参数
  35. #
  36. # (*)阿里云 AccessKeyId
  37. aliddns_ak="阿里云 AccessKeyId "
  38. # (*)阿里云 AccessKeySecret
  39. aliddns_sk="阿里云 AccessKeySecret "
  40. # (*)域名:test.mydomain.com
  41. aliddns_subdomain="test.mydomain.com " #'test'
  42. aliddns_domain="mydomain.com.cn"  #'mydomain.com'
  43. # (*)ip地址类型:'A' 或 'AAAA',代表ipv4 和 ipv6
  44. aliddns_iptype="A" # 'A' 或 'AAAA',代表ipv4 和 ipv6
  45. # TTL 默认10分钟 = 600秒
  46. aliddns_ttl=600 #"600"
  47. #--------------------------------------------------------------
  48. machine_ip=""
  49. ddns_ip=""
  50. aliddns_record_id=""
  51. if [ "$aliddns_subdomain" = "@" ]
  52. then
  53.   aliddns_name=$aliddns_domain
  54. else
  55.   aliddns_name=$aliddns_subdomain.$aliddns_domain
  56. fi
  57. now=`date`
  58. echo "**************************************************"
  59. echo "$now"
  60. echo "$aliddns_name"
  61. function getMachine_IPv4() {
  62.    
  63.     echo $(/usr/bin/wget -qO- -t1 -T2 http://ip.3322.net)
  64. }
  65. function getMachine_IPv6() {
  66.    
  67.     ipv6=`ip addr | grep "inet6.*global" | grep -v "deprecated" | awk '{print $2}' | awk -F"/" '{print $1}' | sed -n '1,1p'`
  68.     echo $ipv6
  69. }
  70. function getDDNS_IP() {
  71.    
  72.     current_ip=`nslookup -query=$aliddns_iptype $aliddns_name | grep "Address" | grep -v "#53" | awk '{print $2}'`
  73.     echo $current_ip
  74. }
  75. function urlencode() {
  76.    
  77.     # urlencode <string>
  78.     out=""
  79.     while read -n1 c
  80.     do
  81.         case $c in
  82.             [a-zA-Z0-9._-]) out="$out$c" ;;
  83.             *) out="$out`printf '%%%02X' "'$c"`" ;;
  84.         esac
  85.     done
  86.     echo -n $out
  87. }
  88. function enc() {
  89.    
  90.     echo -n "$1" | urlencode
  91. }
  92. function send_request() {
  93.    
  94.     local args="AccessKeyId=$aliddns_ak&Action=$1&Format=json&$2&Version=2015-01-09"
  95.     local hash=$(echo -n "GET&%2F&$(enc "$args")" | openssl dgst -sha1 -hmac "$aliddns_sk&" -binary | openssl base64)
  96.     curl -s "http://alidns.aliyuncs.com/?$args&Signature=$(enc "$hash")"
  97. }
  98. function get_recordid() {
  99.    
  100.     grep -Eo '"RecordId":"[0-9]+"' | cut -d':' -f2 | tr -d '"'
  101. }
  102. function query_recordid() {
  103.    
  104.     send_request "DescribeSubDomainRecords" "SignatureMethod=HMAC-SHA1&SignatureNonce=$timestamp&SignatureVersion=1.0&SubDomain=$aliddns_name&Timestamp=$timestamp&Type=$aliddns_iptype"
  105. }
  106. function update_record() {
  107.    
  108.     send_request "UpdateDomainRecord" "RR=$aliddns_subdomain&RecordId=$1&SignatureMethod=HMAC-SHA1&SignatureNonce=$timestamp&SignatureVersion=1.0&TTL=$aliddns_ttl&Timestamp=$timestamp&Type=$aliddns_iptype&Value=$(enc $machine_ip)"
  109. }
  110. function add_record() {
  111.    
  112.     send_request "AddDomainRecord&DomainName=$aliddns_domain" "RR=$aliddns_subdomain&SignatureMethod=HMAC-SHA1&SignatureNonce=$timestamp&SignatureVersion=1.0&TTL=$aliddns_ttl&Timestamp=$timestamp&Type=$aliddns_iptype&Value=$(enc $machine_ip)"
  113. }
  114. if [ "$aliddns_iptype" = 'A' ]
  115. then
  116.     echo "ddns is IPv4."
  117.     machine_ip=`echo "$(getMachine_IPv4)"`
  118.     echo "machine_ip = $machine_ip"
  119.     aliddns_record_id=$aliddnsipv4_record_id
  120. else
  121.     echo "ddns is IPv6."
  122.     machine_ip=`echo "$(getMachine_IPv6)"`
  123.     echo "machine_ip = $machine_ip"
  124.     aliddns_record_id=$aliddnsipv6_record_id
  125. fi
  126. ddns_ip=`echo "$(getDDNS_IP)"`
  127. echo "ddns_ip = $ddns_ip"
  128. if [ "$machine_ip" = "" ]
  129. then
  130.     echo "machine_ip is empty!"
  131.     exit 0
  132. fi
  133. if [ "$machine_ip" = "$ddns_ip" ]
  134. then
  135.     echo "skipping\n"
  136.     exit 1
  137. fi
  138. echo "start update..."
  139. timestamp=`date -u "+%Y-%m-%dT%H%%3A%M%%3A%SZ"`
  140. if [ "$aliddns_record_id" = "" ]
  141. then
  142.     aliddns_record_id=`query_recordid | get_recordid`
  143.     echo "----------------" $aliddns_record_id "\n"
  144.    
  145.     if [ "$aliddns_iptype" = 'A' ]
  146.     then
  147.         aliddnsipv4_record_id=$aliddns_record_id
  148.     else
  149.         aliddnsipv6_record_id=$aliddns_record_id
  150.     fi
  151. fi
  152. #add support */%2A and @/%40 record
  153. if [ "$aliddns_record_id" = "" ]
  154. then
  155.     echo "add record starting"
  156.     aliddns_record_id=`add_record | get_recordid`
  157.     if [ "$aliddns_record_id" = "" ]
  158.     then
  159.         echo "aliddns_record_id is empty. \n"
  160.     else
  161.         if [ "$aliddns_iptype" = 'A' ]
  162.         then
  163.             aliddnsipv4_record_id=$aliddns_record_id
  164.         else
  165.             aliddnsipv6_record_id=$aliddns_record_id
  166.         fi
  167.         echo "added record $aliddns_record_id \n"
  168.     fi
  169. else
  170.     echo "update record starting"
  171.     update_record $aliddns_record_id
  172.     echo "updated record $aliddns_record_id \n"
  173. fi
复制代码
该脚原来自https://cloud.tencent.com/developer/article/2093275

将脚本放到/data/scripts/下定名为aliyun_ddns.sh
可以使用命令运行脚本测试是否可行
  1. /data/scripts/aliyun_ddns.sh
复制代码
3.添加定时任务

添加定时任务,每20分钟执行一次脚本
  1. echo "*/20 * * * * /data/scripts/aliyun_ddns.sh
  2. " >> /etc/crontabs/root/etc/init.d/cron restart
复制代码
三、开启外网访问SSH和WEB管理界面

由于小米路由为了安全考虑,对WEB与防火墙规则进行限制,WEB管理、SSH只能通过内网登 陆,外网无法访问,在路由器的WEB管理页面新建端口转发中不能添加路由本机内网IP。

开启小米路由的SSH后,我们可以通过登岸SSH在命令行中手动添加防火墙中端口转发规则
1、解除WEB管理页面访问限制



  • cd /etc/nginx //切换目次
  • cp miwifi-webinitrd.conf miwifi-webinitrd.conf.bak //养成备份好风俗:
  • vi miwifi-webinitrd.conf //编辑miwifi-webinitrd.conf
动光标找到 set $finalvar "$canproxy $isluci";

在图中位置插入下面代码(按i键进入编辑模式)
  1. set $isluci "1";
复制代码
完成后按ESC退出编辑,Shift + ;键 :输入wq 回车保存并退出

重启httpd服务使设置生效
  1. /etc/init.d/sysapihttpd restart
复制代码
如果是老版本位置在/etc/sysapihttpd/
2.手动添加防火墙端口转发规则,开启外网访问WEB管理和SSH

  1. vi /etc/config/firewall                    //编辑防火墙配置
复制代码
1.添加WEB管理外网端口转发规则代码段:
  1. config redirect 'MIWEB'                                                         
  2.         option src 'wan'                                                            
  3.         option src_dport '1314'                                                   
  4.         option name 'WEB'                                
  5.         option ftype '1'                                                                                 
  6.         option dest_port '80'                              
  7.         option proto 'tcp'     
复制代码
WEB管理界面外网端口为1314 可通过外网IP:1314访问 (例 http://61.181.133.5:1314),绑定DDNS的用户可通过域名:1314进行访问。
2.添加SSH外网登岸端口转发规则代码段:
  1. config redirect 'Myssh'                                         
  2.         option src 'wan'                                       
  3.         option src_dport '2345'                                
  4.         option dest 'lan'                                       
  5.         option dest_port '22'                                   
  6.         option proto 'tcp'
复制代码
SSH登岸外网端口为2345
添加对应规则后保存退出
重启防火墙使规则生效
  1. /etc/init.d/firewall restart
复制代码
现在就可以通过外网WEB管理设置小米路由和进行SSH登岸了.

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

曂沅仴駦

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表