我正在尝试从一个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>";
有没有人遇到过这样的事情?
答案 0 :(得分:4)
当我在同一台服务器上运行两个Laravel项目时,修复此问题的方法是更改.env文件中的环境变量名称。
DB_DATABASE=XXXX
变为
XXX_DB_DATABASE=XXXX
这需要在其中一个Laravel设置上完成,然后才能正常工作。
答案 1 :(得分:0)
您可以像这样更改默认的数据库连接运行时:
所以,假设你有
您使用安全数据库登录,并根据用户将默认数据库更改为数据数据库。
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';
}