如何使用单个 Laravel 代码实例配置 & 运行 具有各自数据库的多个网站
How to configure & run multiple websites with respective databases with single Laravel code instance
我有一个想在 Laravel 中实现的场景。
我已经在自定义 PHP 中实现了这种方法。但是这一次,我想把所有的网站都转移到一个框架中(Laravel)。
我为不同地区实施了多个域(Localization
),每个域都有自己的数据库,所有数据库表结构都相同,只是数据不同。
现在我想使用单个 Laravel 代码实例,能够将多个数据库与多个域连接起来,并且每个域都有自己的主题文件。
假设:我有一些域
1. abc.com and it has database with name of db_abc with theme/template ABC
2. xyz.com and it has database with name of db_xyz with theme/template XYZ
当 abc.com
域为 hit/accessed 时,我想连接数据库 db_abc
并在 ABC
theme/template
中加载数据。与 xyz.com
为 hit/accessed 时类似,应使用 db_xyz
建立数据库连接,并将数据加载到 theme/template
XYZ
文件中。
请在这方面帮助我。
谢谢。
首先,您需要将所有域指向一个项目。
之后您可以 catch
具有路由组的域:
Route::group(['domain' => 'abc.com'], function() {
Route::get('/', 'SomeController@someAction');
});
要使用多个数据库,您可以使用 connection()
:
$users = DB::connection('foo')->select(...);
如果这些是具有相似结构的相似网站,我建议将数据保存在单个数据库中(甚至可能在同一个表中)。
如果你想对所有站点使用相同的路由,你可以在配置文件中保留数据库和视图配置,并在中间件中检查当前域:
if (strpos(request()->server('HTTP_HOST'), 'abc.com')) {
session(['site' => 'abc']);
}
并从配置中获取数据:
$currentDb = config('sites.db')[session('site')];
$currentViewsDir = config('sites.views')[session('site')];
我有一个想在 Laravel 中实现的场景。
我已经在自定义 PHP 中实现了这种方法。但是这一次,我想把所有的网站都转移到一个框架中(Laravel)。
我为不同地区实施了多个域(Localization
),每个域都有自己的数据库,所有数据库表结构都相同,只是数据不同。
现在我想使用单个 Laravel 代码实例,能够将多个数据库与多个域连接起来,并且每个域都有自己的主题文件。
假设:我有一些域
1. abc.com and it has database with name of db_abc with theme/template ABC
2. xyz.com and it has database with name of db_xyz with theme/template XYZ
当 abc.com
域为 hit/accessed 时,我想连接数据库 db_abc
并在 ABC
theme/template
中加载数据。与 xyz.com
为 hit/accessed 时类似,应使用 db_xyz
建立数据库连接,并将数据加载到 theme/template
XYZ
文件中。
请在这方面帮助我。
谢谢。
首先,您需要将所有域指向一个项目。
之后您可以 catch
具有路由组的域:
Route::group(['domain' => 'abc.com'], function() {
Route::get('/', 'SomeController@someAction');
});
要使用多个数据库,您可以使用 connection()
:
$users = DB::connection('foo')->select(...);
如果这些是具有相似结构的相似网站,我建议将数据保存在单个数据库中(甚至可能在同一个表中)。
如果你想对所有站点使用相同的路由,你可以在配置文件中保留数据库和视图配置,并在中间件中检查当前域:
if (strpos(request()->server('HTTP_HOST'), 'abc.com')) {
session(['site' => 'abc']);
}
并从配置中获取数据:
$currentDb = config('sites.db')[session('site')];
$currentViewsDir = config('sites.views')[session('site')];