一直在尝试使用与 Laravel Valet 一起运行的临时 URL https://xxxxx.ngrok.io共享本地站点。当我运行代客 1.1.22 版时:
valet --version
Laravel Valet version 1.1.22
安全地 ngrok url 导致连接被拒绝。当它不安全时,它也会导致连接被拒绝(404 仅在辅助机器上运行代客,因为在那里找不到它)。或者是我稍后提到的 DNS 解析问题。
在我的 wifi 网络和 PC 上本地工作得很好。访问日志告诉我:
127.0.0.1 - [03/Oct/2016:08:57:06 +0300] "POST /server.php?doing_wp_cron=1475474226.5450510978698730468750 HTTP/1.1" 200 0
127.0.0.1 - [03/Oct/2016:08:57:07 +0300] "POST /server.php HTTP/1.1" 200 47
127.0.0.1 - [03/Oct/2016:08:59:09 +0300] "POST /server.php?doing_wp_cron=1475474348.8563120365142822265625 HTTP/1.1" 200 0
127.0.0.1 - [03/Oct/2016:08:59:10 +0300] "POST /server.php HTTP/1.1" 200 47
在 ~/.valet/Log/access.log 的此日志中仍然看不到与拒绝连接相关的错误。错误日志显示与此问题无关的旧错误。终端中的 Ngrook 窗口在我刚刚尝试的两个负载上显示 301 Moved Permanently。Ngrok 状态站点http://localhost:4040/status向我展示了:
GET / HTTP/1.1
Host: site.dev
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/601.7.8 (KHTML, like Gecko) Version/9.1.3 Safari/601.7.8
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Encoding: gzip, deflate
Accept-Language: en-us
X-Forwarded-For: xx.xx.xx.xxx
X-Forwarded-Proto: https
X-Original-Host: xxxxxx.ngrok.io
然后重定向:
HTTP/1.1 301 Moved Permanently
Content-Type: text/html; charset=UTF-8
Location: http://mysite.dev/
Server: Caddy
Status: 301 Moved Permanently
X-Powered-By: PHP/7.0.11
X-Ua-Compatible: IE=edge
Date: Mon, 03 Oct 2016 06:14:10 GMT
Content-Length: 0
Caddyfile 在这里完成(由 Valet 生成):
import /Users/jasper/.valet/Caddy/*
:80 {
fastcgi / 127.0.0.1:9000 php {
index server.php
}
rewrite {
to /server.php?{query}
}
log /Users/jasper/.valet/Log/access.log {
rotate {
size 10
age 3
keep 1
}
}
errors {
log /Users/jasper/.valet/Log/error.log {
size 10
age 3
keep 1
}
}
}
Ngrok 也在运行(在 tld 域更改为 .localhost 后添加):
ps aux | grep ngrok
jasper 1260 0.0 0.2 556735952 28692 s001 S+ 10:23AM 1:27.14 /Users/jasper/.composer/vendor/laravel/valet/bin/ngrok http -host-header=rewrite site.localhost:80
root 1254 0.0 0.1 2463108 8964 s001 S+ 10:23AM 0:00.01 sudo -u jasper /Users/jasper/.composer/vendor/laravel/valet/bin/ngrok http -host-header=rewrite site.localhost:80
jasper 3557 0.0 0.0 2432804 2096 s000 S+ 2:36PM 0:00.00 grep ngrok
所以它确实命中了 Caddy 服务器,并且 ngrok 状态确实显示了这一点。但它随后会进行重定向,从而转化为连接被拒绝或浏览器的 DNS 解析问题。那么这里的问题是什么?