php - 如何使用单个 Laravel 代码实例配置和运行具有各自数据库的多个网站

标签 php mysql laravel laravel-5.1 laravel-routing

我有一个想在 Laravel 中实现的场景。

我已经在自定义 PHP 中实现了这种方法。但是这一次,我想把所有的网站都转移到一个框架(Laravel)上。

我为不同地区实现了多个域(本地化),每个域都有自己的数据库,所有数据库表结构都相同,只是数据不同。

现在我想使用单个 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 主题中加载数据/模板。类似地,当 xyz.com 被点击/访问时,数据库连接应该使用 db_xyz 并且数据应该加载到 theme/template XYZ 个文件。

请在这方面帮助我。

谢谢。

最佳答案

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

之后,您可以使用路由组捕获域:

Route::group(['domain' => 'abc.com'], function() {
    Route::get('/', 'SomeController@someAction');
});

要使用多个数据库,您可以使用 connection() :

$users = DB::connection('foo')->select(...);

如果这些是具有相似结构的相似网站,我建议将数据保存在单个数据库中(甚至可能在同一个表中)。

如果你想对所有站点使用相同的路由,你可以在配置文件中保留数据库和 View 配置,并在中间件中检查当前域:

if (strpos(request()->server('HTTP_HOST'), 'abc.com')) {
    session(['site' => 'abc']);
}

并从配置中获取数据:

$currentDb = config('sites.db')[session('site')];
$currentViewsDir = config('sites.views')[session('site')];

关于php - 如何使用单个 Laravel 代码实例配置和运行具有各自数据库的多个网站,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39285887/

相关文章:

php - 此查询是否获取不必要的信息?我应该更改查询吗?

javascript - codeigniter 中的依赖下拉列表

MySQL 将 2 个查询连接到同一个表

mysql - 多个数据库中表之间的关系

php - 419 页面在 Laravel 中过期即使在添加 CSRF token 之后

laravel - https 请求 "invalid request (unsupported ssl request)"

php - Braintree金库问题中双重客户输入

php - PDO 3,多次运行:错误:17数据库架构已更改

php - 在不创建新表的情况下为 WordPress 插件存储变量

php - Laravel mysql_query 错误异常