慕工程0101907
我花了很多时间寻找解决方案,但没有具体的,总是代码复杂而混乱,最后我用干净的代码开发了一个实用的解决方案。1 - 首先,需要将 laravel 集中在一个域中,然后您必须将其他域指向主域,您可以访问您的 dns 管理器并为此使用 CNAME 记录。2 - 在 Laravel 中,您必须在主页上创建一个控制器,其中包含以下内容,替换必要的内容:/** * Display a listing of the resource. * * @return \Illuminate\Http\Response */public function index(Request $request){ $origin = array("mydomain.com", "mydomain2.com"); $domain = parse_url(request()->root())['host']; if (in_array($domain, $origin)) { if ($domain === 'mydomain.com') { return view('myview')); } if ($domain === 'mydomain2.com') { return view('myview2')); } } else{ return view('unauthorized'); } }3 - 最后(可选),创建一个包含只能由该域访问的 url 的路由,执行以下操作:Route::group(array('domain' => 'mydomain.com'), function () { /* routes here */ Route::get('/', 'YouController@index');});Route::group(array('domain' => 'mydomain2.com'), function () { /* routes here */ Route::get('/', 'YouController@index');});您必须将 mydomain.com 和 mydomain2.com 更改为您想要的域,否则您必须将未经授权的视图替换为有效视图,这是当域未列出时会出现的内容,如果您愿意,您也可以执行 o 服务器什么也没显示。