我有一个场景,我想在Laravel中实现.
@H_502_7@
@H_502_7@我已经在自定义PHP中实现了这种方法.但这次,我想将所有网站转移到一个框架(Laravel).
@H_502_7@我实现了不同区域的多个域(Localization),每个域都有自己的数据库,所有数据库表结构都相同,只是数据不同.
@H_502_7@现在我想使用单个Laravel代码实例,能够连接多个域的多个数据库,每个域都有自己的主题文件.
@H_502_7@让我们假设:我有一些域名
@H_502_7@
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@H_301_20@ @H_502_7@当点击/访问abc.com域时,我想连接DB db_abc并在ABC主题/模板中加载数据.类似地,当命中/访问xyz.com时,应该使用db_xyz建立数据库连接,并且应该将数据加载到主题/模板XYZ文件中. @H_502_7@请帮助我这方面. @H_502_7@谢谢.
解决方法
首先,您需要将所有域指向单个项目.
@H_502_7@
@H_502_7@之后,您可以使用路由组捕获域:
@H_502_7@
Route::group(['domain' => 'abc.com'],function() { Route::get('/','SomeController@someAction'); });@H_301_20@ @H_502_7@要使用多个数据库,可以使用connection()
: @H_502_7@$users = DB::connection('foo')->select(...);@H_301_20@ @H_502_7@如果这些是类似结构的类似网站,我建议将数据保存在单个数据库中(甚至可能在同一个表中). @H_502_7@如果要对所有站点使用相同的路由,可以在配置文件中保留DB和视图配置,并检查中间件中的当前域: @H_502_7@if (strpos(request()->server('HTTP_HOST'),'abc.com')) { session(['site' => 'abc']); }@H_301_20@ @H_502_7@并从配置中获取数据: @H_502_7@$currentDb = config('sites.db')[session('site')]; $currentViewsDir = config('sites.views')[session('site')];@H_301_20@