如何配置&使用单个Laravel代码实例运行具有相应数据库的多个网站

时间:2016-09-02 06:43:31

标签: php mysql laravel laravel-5.1 laravel-routing

我想在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域时,我想与数据库db_abc建立联系,并在ABC theme/template中加载数据。类似于点击/访问xyz.com时,应使用db_xyz进行数据库连接,并将数据加载到theme/template XYZ个文件中。

请帮助我。

谢谢。

1 个答案:

答案 0 :(得分:1)

首先,您需要将所有域指向一个项目。

之后,您可以使用路由组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')];