Laravel5.1学习笔记6 响应

  • 基本响应
    • 附加头信息到响应
    • 附加Cookie到响应
  • 其他响应
    • View视图响应
    • JSON响应
    • File下载
  • 重定向
    • 重定向到命名路由
    • 重定向到控制器Action
    • 附带闪回Session数据重定向
  • 响应宏

 

#基本响应

从路由返回字串

最基本的响应就是从 Laravel 的路由返回字串:

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

建立自定义响应

但是以大部分的路由及控制器所执行的动作来说,你需要返回完整的 Illuminate\Http\Response 实例或是一个视图。返回一个完整的 Response 实例时,你能够自定义响应的 HTTP 状态码以及响应头。Response 实例继承了 Symfony\Component\HttpFoundation\Response 类,它提供了很多方法来建立 HTTP 响应。

use Illuminate\Http\Response;

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

为了方便起见,你可以使用辅助方法 response

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

提示: 有关 Response 方法的完整列表可以参照 API 文档 以及 Symfony API 文档.

 

#附加头信息到响应

要记住多数响应方法是链式调用的, 用以建立流畅的响应。如下:

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

#附加Cookie到响应 (这里省去不少废话,直接看代码理解,也不明白鬼佬的文档这么多废话)

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

withCookie 方法接受更多的可选引数,使你能够定制化Cookie的属性

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

默认所有cookies 都被Laravel加密和签名,这样它们不能被客户随意改变, 如果你不想加密某些Cookies, 你可以使用App\Http\Middleware\EncryptCookies中间件的$except 属性

/** * The names of the cookies that should not be encrypted. * * @var array */protected $except = [    ‘cookie_name‘,];

#其他响应类型

使用辅助方法 response 可以轻松的产生其他类型的响应实例。当你调用辅助方法 response 且不带任何参数时,将会返回 Illuminate\Contracts\Routing\ResponseFactory Contract 的实现。这个Contract 提供了一些有用的方法来产生响应。

View响应

如果你需要控制响应状态和响应头,但也需要返回一个view作为响应内容,你可用view方法

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

如果不需要传送定制HTTP状态,或者定制头信息,你可以使用全局View辅助方法

 

建立 JSON 响应

json 方法会自动将响应头的 Content-Type 配置为 application/json, 同时转换给定的array数组到JSON,用json_encode PHP方法

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

建立 JSONP 响应

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

建立文件下载的响应

第一个参数是给定的下载目录,第二个是保存的文件名, 第三个是HTTP头信息

return response()->download($pathToFile);

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

return response()->download($pathToFile)->deleteFileAfterSend(true);

Note: Symfony HttpFoundation, which manages file downloads, requires the file being downloaded to have an ASCII file name.

 

 

#重定向

 

重定向响应通常是类 Illuminate\Http\RedirectResponse 的实例,并且包含用户要重定向至另一个 URL 所需的响应头。有很多种方法来产生重定向RedirectResponse实例, 最简单的方法是使用全局redirect辅助方法

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

有时候,你希望把用户重定向到它之前的位置, 比如表单提交失败,你可以用全局 back 辅助方法

Route::post(‘user/profile‘, function () {    // Validate the request...

    return back()->withInput();});

返回重定向

有几种方法可以产生 RedirectResponse 的实例,最简单的方式就是透过辅助方法 redirect。当在测试时,建立一个模拟重定向响应的测试并不常见,所以使用辅助方法通常是可行的:

return redirect(‘user/login‘);

返回根据路由名称的重定向

当你调用辅助方法 redirect 且不带任何参数时,将会返回 Illuminate\Routing\Redirector 的实例,你可以对该实例调用任何的方法。举个例子,要产生一个 RedirectResponse 到一个路由名称,你可以使用 route 方法:

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

 

若你的路由有参数, 可以将其作为第二个引数传给route 方法

// For a route with the following URI: profile/{id}

return redirect()->route(‘profile‘, [1]);

 

如果你要重定向到一个其ID参数是包含在一个Eloquent 模型中的路由, 你可以传递Model本身,其ID会自动抽出。

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

返回根据控制器动作的重定向

既然可以产生 RedirectResponse 的实例并重定向至路由名称,同样的也可以重定向至控制器动作

return redirect()->action(‘App\Http\Controllers\[email protected]‘);

提示: 如果你已经通过 URL::setRootControllerNamespace 注册了根控制器的命名空间,那么就不需要对action() 方法内的控制器指定完整的命名空间。action() 方法内的控制器指定完整的命名空间。

action() 方法内的控制器指定完整的命名空间。

 

返回根据控制器动作的重定向,并给予参数赋值

return redirect()->action(‘[email protected]‘, [1]);

返回根据控制器动作的重定向,并给予特定名称参数赋值

return redirect()->action(‘App\Http\Controllers\[email protected]‘, [‘user‘ => 1]);

返回重定向并且加上快闪数据( Flash Data )

通常重定向至新的 URL 时会一并将数据存进一次性 Session。所以为了方便,你可以利用方法连接的方式创建一个 RedirectResponse 的实例并将数据存进一次性 Session:

Route::post(‘user/profile‘, function () {    // Update the user‘s profile...

    return redirect(‘dashboard‘)->with(‘status‘, ‘Profile updated!‘);});
 
时间: 2024-11-10 01:38:50

Laravel5.1学习笔记6 响应的相关文章

Laravel5.1 学习笔记2, 路由

安装的说明请看文档, laravel 安装 #基本路由 你将在 app/Http/routes.php 文件定义大部分路由, 这些路由将被App\Providers\RouteServiceProvider 类所装载. 最基本的laravel路由仅仅包含一个URI和 闭包. Route::get('/', function () { return 'Hello World';}); Route::post('foo/bar', function () { return 'Hello World'

Laravel5.1学习笔记3 HTTP中间件

HTTP 中间件 简介 建立中间件 注册中间件 可终止中间件 简介 HTTP 中间件提供一个方便的机制来过滤进入应用程序的 HTTP 请求,例如,Laravel 默认包含了一个中间件来检验用户身份验证,如果用户没有经过身份验证,中间件会将用户导向登录页面,然而,如果用户通过身份验证,中间件将会允许这个请求进一步继续前进. 当然,除了身份验证之外,中间件也可以被用来执行各式各样的任务,CORS 中间件负责替所有即将离开程序的响应加入适当的响应头,一个日志中间件可以记录所有传入应用程序的请求. La

Laravel5.1学习笔记19 EloquentORM 入门

Eloquent:入门 简介 定义模型(model) Eloquent Model Conventions Retrieving Multiple Models Retrieving Single Models / Aggregates Retrieving Aggregates Inserting & Updating Models Basic Inserts Basic Updates Mass Assignment Deleting Models Soft Deleting Queryin

Laravel5.1学习笔记23 Eloquent 序列化

Eloquent: Serialization Introduction Basic Usage Hiding Attributes From JSON Appending Values To JSON Introduction When building JSON APIs, you will often need to convert your models and relationships to arrays or JSON. Eloquent includes convenient m

Laravel5.1学习笔记20 EloquentORM 关系

Eloquent: Relationships Introduction Defining Relationships One To One One To Many Many To Many Has Many Through Polymorphic Relations Many To Many Polymorphic Relations Querying Relations Eager Loading Constraining Eager Loads Lazy Eager Loading Ins

Laravel5.1学习笔记22 Eloquent 调整修改

Eloquent: Mutators Introduction Accessors & Mutators Date Mutators Attribute Casting Introduction Accessors and mutators allow you to format Eloquent attributes when retrieving them from a model or setting their value. For example, you may want to us

Laravel5.1学习笔记21 EloquentORM 集合

Eloquent: Collections Introduction Available Methods Custom Collections Introduction All multi-result sets returned by Eloquent are an instance of theIlluminate\Database\Eloquent\Collection object, including results retrieved via the get method or ac

Laravel5.1学习笔记7 视图

视图 (View) 基本用法 传递数据到视图 在多个视图中分享数据 视图组件   #基本用法 视图里面包含了你应用程序所提供的 HTML 代码,并且提供一个简单的方式来分离控制器和网页呈现上的逻辑.视图被保存在 resources/views 文件夹内. 一个简单的视图看起来可能像这样: <!-- 视图被保存在 resources/views/greeting.php --> <html> <body> <h1>Hello, <?php echo $n

Laravel5.1 学习笔记1, 目录结构和命名空间(待修)

自从用 Laravel4做了个小网站,使用了数据库ORM Eloquent, 就放下了一段时间,想不到这个与Asp.net MVC 有着异曲同工之妙的框架已经出了下个版本,而且还有不小的改动,因此不得不从头过一次,顺便更新一下知识点. 下面内容摘自Laravel 5.0 系列, 目录结构和命名空间 Laravel从4升级到5 ,改变的不只是文件的组织方式,而且是思想上的重大转变. 废话不多说, 新版本的目录. app Console Commands Events Exceptions Http