这很容易首先 – 不要将.htaccess文件从Laravel提供的默认文件中更改.默认情况下,您的域的所有请求将被路由到您的index.PHP文件,这正是我们想要的.
然后在您的routes.PHP文件中,只需使用’before’过滤器,在其他任何操作完成之前,该过滤器将过滤对应用程序的所有请求.
Route::filter('before',function()
{
// Check if we asked for a user
$server = explode('.',Request::server('HTTP_HOST'));
if (count($server) == 3)
{
// We have 3 parts of the domain - therefore a subdomain was requested
// i.e. user.domain.com
// Check if user is valid and has access - i.e. is logged in
if (Auth::user()->username === $server[0])
{
// User is logged in,and has access to this subdomain
// DO WHATEVER YOU WANT HERE WITH THE USER PROFILE
echo "your username is ".$server[0];
}
else
{
// Username is invalid,or user does not have access to this subdomain
// SHOW ERROR OR WHATEVER YOU WANT
echo "error - you do not have access to here";
}
}
else
{
// Only 2 parts of domain was requested - therefore no subdomain was requested
// i.e. domain.com
// Do nothing here - will just route normally - but you could put logic here if you want
}
});
编辑:如果您有国家/地区扩展程序(即domain.com.au或domain.com.eu),那么您将要更改计数($server)以检查4,而不是3