本文實例講述了Laravel 框架控制器 Controller原理與用法。分享給大家供大家參考,具體如下:
一、控制器存在的意義
路由可以分發請求;
路由中還可以引入 html 頁面;
我們可以在 route/web.php 中搞定一切了;
但是如果把業務邏輯都寫入到路由中;
那路由將龐大的難以維護;
于是控制器就有了很明顯的存在價值;
把業務邏輯寫在控制器中;
路由只負責轉發請求到指定的控制器即可;
二、創建控制器
我們可以直接使用 Laravel 內置的命令生成很多代碼,例如控制器;
artisan 就是 laravel 的命令行接口;
就是根目錄下的 artisan 文件;
下面來使用命令創建一個控制器
1
|
php artisan make:controller ArticleController |
運行完成后會生成一個 app/Http/Controllers/ArticleController.php 文件
接下來就需要在新創建的控制器中寫各種方法,但是,只要在剛剛的命令中加入一個參數就可以自動生成一些方法
1
|
php artisan make:controller ArticleController --resource |
如果直接運行的話是會報錯的;
提示 Controller already exists!
;
因為我們剛已經創建過 ArticleController了;
所以我們需要先把 app/Http/Controllers/ArticleController.php 文件刪掉再運行;
那么會再次生成一個 app/Http/Controllers/ArticleController.php 文件;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; class ArticleController extends Controller { /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index() { // } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create() { // } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request ) { // } /** * Display the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function show( $id ) { // } /** * Show the form for editing the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function edit( $id ) { // } /** * Update the specified resource in storage. * * @param \Illuminate\Http\Request $request * @param int $id * @return \Illuminate\Http\Response */ public function update(Request $request , $id ) { // } /** * Remove the specified resource from storage. * * @param int $id * @return \Illuminate\Http\Response */ public function destroy( $id ) { // } } |
增刪改查的方法都定義好了;
連注釋都給寫好了;
這其實是按 RESTful 規范生成的格式;
除了 GET POST 它還包含了一大堆請求方式;
PUT 、 PATCH 、 DELETE 、HEAD 、OPTIONS;
也就是說 Route:: 后面還可以跟上面這些方法;
1
2
3
|
Route::put( 'article' , function () { return view( 'article' ); }); |
三、什么是 artisan
laravel 是一個現代化框架;
它對命令行有著非常好的支持;
artisan 就是 laravel 的命令行接口;
就是根目錄下的 artisan 文件;
我們可以把它理解為命令行級的單入口文件;
跟 index.php 文件的使命一樣;
所有的命令行都從它這走;
所以如果想使用命令行;
就需要 cd 到項目的根目錄下;
或者手動指定一長串路徑;
在命令行中以 php 開頭意思是用 php 來執行某個文件;
php index.php
意思就是使用 php 的命令行模式運行 index.php ;
命令行下是可以不需要文件后綴就能識別的;
你可以創建個 test 的文本文件,然后在里面寫一些php代碼,使用命令行 php test 也是可以正常運行的;
所以根目錄下的 artisan 文件并沒有帶上 .php ;
命令行主要有兩個方向的應用;
第一是生成文件;
第二是執行任務;
四、路由綁定控制器方法
在上面生成的控制器方法 index 中寫入如下代碼
然后寫一個路由綁定這個控制器方法,在 routes/web.php 中添加如下代碼
1
|
Route::get( 'article/index' , 'ArticleController@index' ); |
打開鏈接
http://127.0.0.1:8000/article/index
希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。
原文鏈接:https://www.cnblogs.com/ryanzheng/p/11787311.html