99re热这里只有精品视频,7777色鬼xxxx欧美色妇,国产成人精品一区二三区在线观看,内射爽无广熟女亚洲,精品人妻av一区二区三区

基礎(chǔ) ―― HTTP 響應(yīng)

2018-02-24 15:38 更新

基礎(chǔ) —— HTTP 響應(yīng)

1、基本響應(yīng)

所有路由和控制器都會(huì)返回某種被發(fā)送到用戶瀏覽器的響應(yīng),Laravel提供了多種不同的方式來返回響應(yīng),最基本的響應(yīng)就是從路由或控制器返回一個(gè)簡(jiǎn)單的字符串:

Route::get('/', function () {
    return 'Hello World';
});

給定的字符串會(huì)被框架自動(dòng)轉(zhuǎn)化為HTTP響應(yīng)。

但是大多數(shù)路由和控制器動(dòng)作都會(huì)返回一個(gè)完整的Illuminate\Http\Response實(shí)例或視圖,返回一個(gè)完整的Response實(shí)例允許你自定義響應(yīng)的HTTP狀態(tài)碼和頭信息,Response實(shí)例繼承自Symfony\Component\HttpFoundation\Response類,該類提供了一系列方法用于創(chuàng)建HTTP響應(yīng):

use Illuminate\Http\Response;

Route::get('home', function () {
    return (new Response($content, $status))
                  ->header('Content-Type', $value);
});

為方便起見,還可以使用幫助函數(shù)response

Route::get('home', function () {
    return response($content, $status)
                  ->header('Content-Type', $value);});

注意:查看完整的Response方法列表,請(qǐng)移步相應(yīng)的API文檔以及Symfony API文檔

1.1 添加響應(yīng)頭

大部分響應(yīng)方法都是可以鏈?zhǔn)秸{(diào)用的,從而使得可以平滑的構(gòu)建響應(yīng)。例如,可以使用header方法來添加一系列響應(yīng)頭:

return response($content)
            ->header('Content-Type', $type)
            ->header('X-Header-One', 'Header Value')
            ->header('X-Header-Two', 'Header Value');

1.2 添加Cookies

使用response實(shí)例的幫助函數(shù)withCookie可以輕松添加cookie到響應(yīng),比如,可以使用withCookie方法來生成cookie并將其添加到response實(shí)例:

return response($content)->header('Content-Type', $type)
                 ->withCookie('name', 'value');

withCookie方法接收額外的可選參數(shù)從而允許對(duì)cookie屬性更多的自定義:

->withCookie($name, $value, $minutes, $path, $domain, $secure, $httpOnly)

默認(rèn)情況下,Laravel框架生成的cookies經(jīng)過加密和簽名,所以在客戶端不能進(jìn)行修改,如果你想要將特定的cookies子集在生成時(shí)取消加密,可以使用中間件App\Http\Middleware\EncryptCookies$except屬性:

/**
 * 需要被加密的cookies名稱
 *
 * @var array
 */
protected $except = [
    'cookie_name',
];

2、其它響應(yīng)類型

幫助函數(shù)response可以用來方便地生成其他類型的響應(yīng)實(shí)例,當(dāng)無參數(shù)調(diào)用response時(shí)會(huì)返回Illuminate\Contracts\Routing\ResponseFactory契約的一個(gè)實(shí)現(xiàn),該契約提供了一些有用的方法來生成響應(yīng)。

2.1?視圖響應(yīng)

如果你需要控制響應(yīng)狀態(tài)和響應(yīng)頭,還需要返回一個(gè)視圖作為響應(yīng)內(nèi)容,可以使用view方法:

return response()->view('hello', $data)->header('Content-Type', $type);

當(dāng)然,如果你不需要傳遞一個(gè)自定義的HTTP狀態(tài)碼或者自定義頭,只需要簡(jiǎn)單使用全局的幫助函數(shù)view即可。

2.2?JSON響應(yīng)

json方法會(huì)自動(dòng)將Content-Type頭設(shè)置為application/json,并使用PHP函數(shù)json_encode方法將給定數(shù)組轉(zhuǎn)化為JSON:

return response()->json(['name' => 'Abigail', 'state' => 'CA']);

如果你想要?jiǎng)?chuàng)建一個(gè)JSONP響應(yīng),可是添加setCallbackjson方法后面:

return response()->json(['name' => 'Abigail', 'state' => 'CA'])
                 ->setCallback($request->input('callback'));

2.3?文件下載

download方法用于生成強(qiáng)制用戶瀏覽器下載給定路徑文件的響應(yīng)。download方法接受文件名作為第二個(gè)參數(shù),該參數(shù)決定用戶下載文件的顯示名稱,你還可以將HTTP頭信息作為第三個(gè)參數(shù)傳遞到該方法:

return response()->download($pathToFile);
return response()->download($pathToFile, $name, $headers);

注意:管理文件下載的Symfony HttpFoundation類要求被下載文件有一個(gè)ASCII文件名。

3、重定向

重定向響應(yīng)是Illuminate\Http\RedirectResponse類的實(shí)例,其中包含了必須的頭信息將用戶重定向到另一個(gè)URL,有很多方式來生成RedirectResponse實(shí)例,最簡(jiǎn)單的方法就是使用全局幫助函數(shù)redirect

Route::get('dashboard', function () {
    return redirect('home/dashboard');
});

有時(shí)候你想要將用戶重定向到前一個(gè)位置,比如,表單提交后,驗(yàn)證不通過,你就可以使用back幫助函數(shù)返回前一個(gè)URL:

Route::post('user/profile', function () {
    // 驗(yàn)證請(qǐng)求...
    return back()->withInput();
});

3.1 重定向到命名路由

如果調(diào)用不帶參數(shù)的redirect方法,會(huì)返回一個(gè)Illuminate\Routing\Redirector實(shí)例,從而可以調(diào)用該實(shí)例上的任何方法。比如,為了生成一個(gè)RedirectResponse到命名路由,可以使用route方法:

return redirect()->route('login');

如果路由中有參數(shù),可以將其作為第二個(gè)參數(shù)傳遞到route方法:

// For a route with the following URI: profile/{id}
return redirect()->route('profile', [1]);

如果要重定向到帶ID參數(shù)的路由,并從Eloquent模型中取數(shù)據(jù)填充表單,可以傳遞模型本身,ID會(huì)被自動(dòng)解析出來:

return redirect()->route('profile', [$user]);

3.2 重定向到控制器動(dòng)作

你還可以生成重定向到控制器動(dòng)作,只需簡(jiǎn)單傳遞控制器和動(dòng)作名到action方法即可。記住,你不需要指定控制器的完整命名空間,因?yàn)長(zhǎng)aravel的RouteServiceProvider將會(huì)自動(dòng)設(shè)置默認(rèn)的控制器命名空間:

return redirect()->action('HomeController@index');

當(dāng)然,如果控制器路由要求參數(shù),你可以將參數(shù)作為第二個(gè)參數(shù)傳遞給action方法:

return redirect()->action('UserController@profile', [1]);

3.3 帶一次性Session數(shù)據(jù)的重定向

重定向到一個(gè)新的URL并將數(shù)據(jù)存儲(chǔ)到一次性session中通常是同時(shí)完成的,為了方便,可以創(chuàng)建一個(gè)RedirectResponse實(shí)例然后在同一個(gè)方法鏈上將數(shù)據(jù)存儲(chǔ)到session,這種方式在action之后存儲(chǔ)狀態(tài)信息時(shí)特別方便:

Route::post('user/profile', function () {
    // 更新用戶屬性...
    return redirect('dashboard')->with('status', 'Profile updated!');
});

當(dāng)然,用戶重定向到新頁面之后,你可以從session中取出并顯示這些一次性信息,比如,使用Blade語法實(shí)現(xiàn)如下:

@if (session('status'))
    <div class="alert alert-success">
        {{ session('status') }}
    </div>
@endif

4、響應(yīng)宏

如果你想要定義一個(gè)自定義的響應(yīng)并且在多個(gè)路由和控制器中復(fù)用,可以使用Illuminate\Contracts\Routing\ResponseFactory實(shí)現(xiàn)上的macro方法。

比如,在一個(gè)服務(wù)提供者boot方法中:

<?php

namespace App\Providers;

use Illuminate\Support\ServiceProvider;
use Illuminate\Contracts\Routing\ResponseFactory;

class ResponseMacroServiceProvider extends ServiceProvider
{
    /**
     * Perform post-registration booting of services.
     *
     * @param  ResponseFactory  $factory
     * @return void
     */
    public function boot(ResponseFactory $factory)
    {
        $factory->macro('caps', function ($value) use ($factory) {
            return $factory->make(strtoupper($value));
        });
    }
}

micro方法接收響應(yīng)名稱作為第一個(gè)參數(shù),一個(gè)閉包函數(shù)作為第二個(gè)參數(shù),micro的閉包在從ResponseFactory實(shí)現(xiàn)或幫助函數(shù)response上調(diào)用macro名稱的時(shí)候被執(zhí)行:

return response()->caps('foo');

擴(kuò)展閱讀:實(shí)例教程——基本使用、生成Cookie、返回視圖、JSON/JSONP及文件下載

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)