从一个 VM 实例到另一个 VM(Vagrant)的卷曲请求似乎不起作用

Curl request from one VM instance to another VM (Vagrant) doesn't appear to work

我有两个虚拟机 运行 一个 Scotchbox (Vagrant) 实例,本质上有 'frontend' 应用程序 (AngularJS) 和 'backend' 应用程序 ( Zend/PHP 等..)

我在两个单独的 Vagrant 实例上设置了它们,并且从下面的 IP 运行ning(将它们添加到我的 Windows 主机文件)所以我可以通过域名访问它们(而不是不仅仅是 IP 地址)

192.168.33.10 myappfront.local
192.168.33.11 myappback.local

在我的前端应用程序中,我 运行 使用 CURL 下面的 PHP 代码来在用户登录时基本验证令牌。

$ch = curl_init();
$parameters = $apiUrl . '/user/login/verify-new-ui?id='.$_REQUEST['id'].'&token='.$_REQUEST['token'].'&appid=3';

curl_setopt($ch, CURLOPT_URL, $parameters);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);

$data = json_decode(curl_exec($ch)); // always NULL??
curl_close($ch);

$parameters 变量将包含类似于此的 URL... https://myappback.local/user/login/verify-new-ui?id=1000001445&token=1shg7x1y7u53c1cppg36&appid=3

当我尝试 var_dump 输出 $data 变量时,它始终为 NULL - 我知道该函数有效(在我们的实时网站上 运行ning 很好)所以让我相信这一点与 Vagrant 相关吗?

在流浪者实例中是否与防火墙相关?谁能建议解决这个问题的最佳方法?

我的vagrantfile如下:

Vagrant.configure("2") do |config|

config.vm.box = "scotch/box"
config.vm.network "private_network", ip: "192.168.33.10"
config.vm.hostname = "scotchbox"
config.vm.synced_folder ".", "/var/www", :mount_options => ["dmode=777", "fmode=666"]
config.vm.box_download_insecure = false 

config.vm.provider "virtualbox" do |v|
    v.customize ["modifyvm", :id, "--natdnshostresolver1", "on"]
    v.customize ["modifyvm", :id, "--natdnsproxy1", "on"]
end

config.vm.provision :shell, :path => "bootstrap.sh"

end

// 另一个后端 vagrant box

Vagrant.configure("2") do |config|

config.vm.box = "scotch/box"
config.vm.network "private_network", ip: "192.168.33.11"
config.vm.hostname = "scotchbox"
config.vm.synced_folder ".", "/var/www", :mount_options => ["dmode=777", "fmode=666"]

结束

您应该将相同的记录添加到发出请求的 VM 中。如果您仅在本地主机上添加此记录 - 您可以测试任何请求,使用浏览器。