Laravel Guzzle 请求得到错误的数据库连接



我正在尝试从一个Laravel项目向另一个项目发出请求。我遇到的问题是第二个Laravel正在使用第一个Laravel数据库连接。所以它抱怨表不存在。

这是我正在使用的代码。

$data = ['test' => 'foobar'];
$client = new GuzzleHttpClient();
$url = getenv('API_BASE') . 'stock-list';
$res = $client->request('POST', $url, [
    'headers' => [
        'X-Public' => getenv('API_PUBLIC'),
        'X-Hash' => ApiService::Encrypt(getenv('API_PRIVATE'), json_encode($data)),
    ],
    'json' => $data,
    'http_errors' => false,
]);
echo "<pre>" . print_r($res->getBody()->getContents(), true) . "</pre>";

有没有人遇到过这样的事情?

当我在同一

台服务器上运行两个Laravel项目时,解决此问题的方法是更改.env文件中的环境变量名称。

DB_DATABASE=XXXX

成为

XXX_DB_DATABASE=XXXX

这需要在其中一个Laravel设置上完成,然后一切正常。

您可以像这样更改默认的数据库连接运行时:

所以假设你有

  • 1 个安全数据库,其凭据是默认数据库设计时。
  • 1 个或多个
  • 数据库,包含 1 个或多个用户的数据。

您使用安全数据库登录,并根据用户将默认数据库更改为数据数据库。

    config(['database.connections.data' => array(
                'driver'    => 'sqlsrv',
                'host' => $connection['Database_Server'],
                'database' => $connection['Database_Name'],
                'username' => $connection['Database_User'],
                'password' => $connection['Database_Password']
            )]);
            DB::setDefaultConnection('data');

如果您不需要这种灵活性,则可以为每个模型定义连接:

class A extends Model {
    protected $connection = 'security';
    protected $table = 'A';
}

最新更新