Laravel Guzzle请求错误DB连接

时间:2017-02-02 14:15:15

标签: php laravel laravel-5 guzzle

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

以下是我正在使用的代码。

$data = ['test' => 'foobar'];
$client = new \GuzzleHttp\Client();
$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>";

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

2 个答案:

答案 0 :(得分:4)

当我在同一台服务器上运行两个Laravel项目时,修复此问题的方法是更改​​.env文件中的环境变量名称。

DB_DATABASE=XXXX

变为

XXX_DB_DATABASE=XXXX

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

答案 1 :(得分:0)

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

所以,假设你有

  • 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';
}