// +---------------------------------------------------------------------- use think\facade\Route; use app\model\Model; $model = Model::where('status', '>', 0)->field(['id', 'name'])->select()->toArray(); foreach ($model as $value) { Route::rule('/admin/' . $value['name'] . '/:function', 'admin.content/:function')->append(['name'=>$value['name'], 'model_id' => $value['id']]); Route::rule($value['name'] . '/index', 'front.content/index')->append(['name'=>$value['name'], 'model_id' => $value['id']]); Route::rule($value['name'] . '/list/:id', 'front.content/lists')->append(['name'=>$value['name'], 'model_id' => $value['id']]); Route::rule($value['name'] . '/detail-:id', 'front.content/detail')->append(['name'=>$value['name'], 'model_id' => $value['id']]); Route::rule('/user/' . $value['name'] . '/:function', 'user.content/:function')->append(['name'=>$value['name'], 'model_id' => $value['id']]); } Route::rule('/', 'front.Index/index'); Route::rule('search', 'front.Content/search'); Route::rule('category', 'front.Content/category'); Route::rule('topic-:id', 'front.Content/topic'); Route::rule('form/:id/[:name]', 'front.Form/index'); Route::rule('front/:controller/:function', 'front.:controller/:function'); Route::group('admin', function () { Route::rule('/', 'admin.Index/index'); Route::rule('login', 'admin.Index/login'); Route::rule('logout', 'admin.Index/logout'); Route::rule('upload/:function', 'Upload/:function')->append(['from'=>'admin']); Route::rule(':controller/:function', 'admin.:controller/:function'); }); Route::group('user', function () { Route::rule('/', 'user.Index/index'); Route::rule('login', 'user.Index/login'); Route::rule('logout', 'user.Index/logout'); Route::rule('register', 'user.Index/register'); Route::rule('upload/:function', 'Upload/:function')->append(['from'=>'user']); Route::rule(':controller/:function', 'user.:controller/:function'); }); Route::group('api', function () { Route::rule('/', 'api.Index/index'); Route::rule('login', 'api.Login/index'); Route::rule('register', 'api.Login/register'); Route::rule('logout', 'api.Login/logout'); Route::rule('upload/:function', 'Upload/:function')->append(['from'=>'api']); Route::rule(':controller/:function', 'api.:controller/:function'); })->allowCrossDomain([ 'Access-Control-Allow-Origin' => '*', 'Access-Control-Allow-Credentials' => 'true', 'Access-Control-Allow-Headers' => 'authorization, token, Content-Type, If-Match, If-Modified-Since, If-None-Match, If-Unmodified-Since, X-Requested-With', ]); Route::miss('front.Index/miss');