欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Laravel5笔记--路由

程序员文章站 2022-08-27 11:43:26
路由:简单讲就是定义URL请求转向某个业务逻辑(一般是控制器方法)的方法。 1、路由定义文件: /routes/web.php //定义web访问的路由 /routes/api.php //定义api访问的路由,此路由定义的url都要加/api前缀 怎么增加路由文件: 笨方法就直接在/routes/ ......

路由:简单讲就是定义URL请求转向某个业务逻辑(一般是控制器方法)的方法。

1、路由定义文件:

/routes/web.php   //定义web访问的路由

/routes/api.php    //定义api访问的路由,此路由定义的url都要加/api前缀

怎么增加路由文件:

笨方法就直接在/routes/下添加文件后,再在web.php下添加require引用。

优雅的方法:(参考:https://laravel-china.org/articles/4400/laravel54-add-routing-file)

举例:添加一/routes/admin.php文件,作为定义后台管理的路由文件。

修改/app/Providers/RouteServiceProvider.php服务提供者文件:

添加一方法:

 /**
     * 定义管理后台的路由文件
     */
    protected function mapAdminRoutes()
    {
        Route::prefix('admin')  //添加admin前缀(可选)
            ->middleware('web') //使用web组别的中间件(可选)
            ->namespace($this->namespace . '\admin') //admin的命名空间(可选)
            ->group(base_path('routes/admin.php')); //引用admin.php文件
    }

然后修改map方法,添加一行执行以上方法代码:

    public function map()
    {
        $this->mapApiRoutes();

        $this->mapWebRoutes();

        $this->mapAdminRoutes(); //引用管理后台路由文件
    }

这样就能方便地在/routes/admin.php文件内定义后台路由了。

 

2、路由定义:

可定义的路由请求:

Route::get($uri, $callback);
Route::post($uri, $callback);
Route::put($uri, $callback);
Route::patch($uri, $callback);
Route::delete($uri, $callback);
Route::options($uri, $callback);

 

响应多个请求:

Route::match(['get', 'post'], '/', function () {
    //响应第一参数内的请求,第一参数为数组或字串,第二参数为uri
});

Route::any('foo', function () {
    //响应任意HTTp的请求,第一参数为uri
});

 

路由参数:

参数名在{}内,不能包含-符号。带?号表示可选参数。

//uri:  http://domain/user/1
Route::get('user/{id}', function ($id) {
    return 'User '.$id;
});

//uri: http://domain/posts/1/comments/1
Route::get('posts/{post}/comments/{comment}', function ($postId, $commentId) {
    //
});

//可选参数
Route::get('user/{name?}', function ($name = null) {
    return $name;
});

 可定义正则约束参数:

Route::get('user/{id}/{name}', function ($id, $name) {
    //
})->where(['id' => '[0-9]+', 'name' => '[a-z]+']);

//全局约束:修改/app/Providers/RouteServiceProvider.php文件的boot方法。这样对所有使用该参数的路由都起约束:
public function boot()
{
    Route::pattern('id', '[0-9]+');  //id参数的全局约束
    parent::boot();
}

 

 

路由命名:

Route::get('user/profile', function () {
    //
})->name('profile');

Route::get('user/profile', 'UserController@showProfile')->name('profile');

 

命名的好处:可使用命名来生成该链接或重定向等:

// 生成 URL,等效于route('user/profile')
$url = route('profile');

// 生成重定向...
return redirect()->route('profile');

//带参数的路由
Route::get('user/{id}/profile', function ($id) {
    //
})->name('profile');
$url = route('profile', ['id' => 1]);

//检查当前路由是否为某个name定义的:
if ($request->route()->named('profile')) {
        //常用于中间件检测
}

 

 

 路由组:用于大量路由*享路由属性,如中间件、命令空间。

Route::middleware(['first', 'second']) //按顺序使用first, second中间件
->namespace('Admin') //在 "App\Http\Controllers\Admin" 命名空间下的控制器
->prefix('admin') //匹配包含 "/admin/users" 的 URL
->name('admin.')  //添加路由名称前缀
->group(function () {
    Route::get('/', function () {
        // 
    });

    Route::get('user/profile', function () {
        // 
    });
    Route::get('users', function () {
        // 路由分配名称“admin.users”...
    })->name('users');
});

 

 

Route::domain('{account}.myapp.com')->group(function () {
    Route::get('user/{id}', function ($account, $id) {
        //子域名路由
    });
});

 

 

表单方法伪造: HTML 表单中调用定义了 PUTPATCH 或 DELETE 路由。

以下两段代码等效:

<form action="/foo/bar" method="POST">
    <input type="hidden" name="_method" value="PUT">
    <input type="hidden" name="_token" value="{{ csrf_token() }}">
</form>

<form action="/foo/bar" method="POST">
    @method('PUT')
    @csrf
</form>

 

 

访问当前路由:

$route = Route::current();

$name = Route::currentRouteName();

$action = Route::currentRouteAction();