啥是内网穿透?举个栗子,工作中我们经常遇到以下场景:
向别人展示我们本机(局域网)的web demo以及调试一些远程的API (比如微信公众号,企业号的开发)
一般项目部署在内网环境之后,远程调试(包括数据库访问)是比较困难的一件事。这个时候可以使用 tcp 协议去连接访问,减少了出差的必要性。
从事物联网相关行业的用户和设备打交道比较多,但是大多数情况下,设备很难有自己的公网IP。
这些情况下我们就需要一款神器来让我们的服务暴露在公网之中,以从其它任何地方进行访问。那到底我们该怎么做?按照以往的经验,我们可以选择花生壳,或者ngrok。
但是今天我要介绍的是一个更好的选择:serveo。
神奇之处就在于无需下载安装任何的软件,一条命令搞定!,更重要的是它免费,完全免费,真的免费,重要的事说三遍!
基本用法
假设你想要在公网之中暴露3000端口,那么你只需在命令终端中输入以下命令:
ssh -R 80:localhost:3000 serveo.net
终端会用绿色字体提供一个网址(如果是初次输这条命令,会询问你是否相信传送过来的RSA钥匙指纹,请选择 yes),你就可以用提供的网址从任何一台能够访问互联网的电脑,用浏览器来进行访问。如下图:
其它用法
如果对80,443,22以外的端口进行转发,那将是原始的tcp包
绑定自己已有的域名或子域名
更多用法详情请访问官网。
windows用户
由于这个命令是用ssh来生成的,因此只适用于类unix系统,如linux和mac。
但是window用户也不是没法使用,只是得走些弯路(经网友提醒,win10已自带OpenSSH,这里一并讨论)。
win10默认自带OpenSSH,如果cmd无法识别ssh命令,那可能是此功能未启用,需要配置启用一下。
启用方法:
安装成功之后,在cmd命令提示符窗口中即可运行ssh命令。
微软的Powershell团队已将OpenSSH进行开源,大家可以到github上下载,请戳这里。或者笔者也将早前下载的上传了度盘,下载请戳这里。
下载解压后将解压目录添加进PATH环境变量或者进入解压目录启动cmd即可进行ssh操作。
Git for Windows 提供了一个仿真环境,这样我们可以通过git bash执行ssh命令。
其它问题
使用了webpack-dev-server的前端项目进行内网穿透的时候,浏览器显示Invalid Host Header。
原因:webpack-dev-server出于安全考虑,默认检查hostname,如果hostname不是配置内的,将中断访问。
解决办法:设置 webpack-dev-server 的配置项 disableHostCheck 为 true 以禁用这一检测。