Le middleware HTTP de Laravel fournit une couche de filtrage et de protection pour le routage. Simulons en utilisant un middleware pour vérifier la connexion en arrière-plan.
cmd et entrez dans le répertoire du projet, utilisez la commande artisan pour créer
php artisan make:middleware AdminLoginVerify
Ce sera dans le middleware de création de répertoire app/ Http/Middleware AdminLoginVerify
Ajouter une logique de vérification dans la méthode handle() de la classe AdminLoginVerify :
<?php namespace App\Http\Middleware; use Closure; class AdminLoginVerify { public function handle($request, Closure $next) { if(!session('admin')){ // 如果没有登录则定向到登录页 return redirect('admin/login'); } return $next($request); } }
ok, maintenant créez et définissez le middleware AdminLoginVerify
se trouve dans le fichier app/Http/Kernel.php protected $ attribut routeMiddleware, ajoutez notre AdminLoginVerify
protected $routeMiddleware = [ 'auth' => \App\Http\Middleware\Authenticate::class, 'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class, 'can' => \Illuminate\Foundation\Http\Middleware\Authorize::class, 'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class, 'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class, // 自定义中间件 'adminLoginVerify' => \App\Http\Middleware\AdminLoginVerify::class, ];
dans app/Http/routes. le fichier php :
// 后台首页路由、退出登录路由 Route::group(['prefix' => 'admin', 'namespace' => 'Admin', 'middleware' => 'adminLoginVerify'], function(){ Route::get('index', 'IndexController@index'); Route::get('logout', 'IndexController@logout'); }); // 后台登录路由 Route::group(['middleware' => 'web'], function(){ Route::get('admin/login', 'Admin\IndexController@login'); });
Voici le code du contrôleur Index dans le répertoire Admin en arrière-plan :
<?php namespace App\Http\Controllers\Admin; use App\Http\Controllers\Controller; class IndexController extends Controller{ // 后台首页 public function index(){ return '<h1>欢迎你,' . session('admin') . '</h1>'; } // 后台登录 public function login(){ session(['admin' => 'mingc']); return '<h1>后台登录</h1>'; } // 退出登陆 public function logout(){ session(['admin' => null]); return '<h1>退出登录</h1>'; } }
Ouvrez le navigateur et visitez la page de connexion en arrière-plan
D'accord Oui, visitez la page d'accueil en arrière-plan
Maintenant, nous nous déconnectons
Dans l'état déconnecté, accédez à la page d'accueil redirigera Accédez à la page de connexion.
Méthode 1. Allocation de paire clé-valeur de tableau
// 在控制器中 $data = array( 'title' => 'Laravel', 'subTitle' => '高效快捷的PHP框架' ); return view('my_laravel', $data); // 在模板中 <?php echo $title;?> <?php echo $subTitle;?>
Méthode 2. avec allocation de chaîne de méthodes
// 在控制器中 return view('my_laravel')->with('title', 'Laravel')->with('subTitle', '高效快捷的PHP框架'); // 在模板中(和上面的一样) <?php echo $title;?> <?php echo $subTitle;?>
Méthode 3. Utilisation de compact() allocation de fonction
// 在控制器中 $data = array( 'title' => 'Laravel', 'subTitle' => '高效快捷的PHP框架' ); $content = 'Laravel 5.2 在 5.1 基础上继续改进和优化,添加了许多新的功能特性...'; return view('my_laravel', compact('data', 'content')); // 在模板中(和前两个不太一样) <?php echo $data['title'] ; ?> <?php echo $data['subTitle']; ?> <?php echo $content; ?>
Parmi eux, le premier paramètre my_laravel de la fonction view() est le nom du modèle de vue, qui se trouve dans le répertoire de vue ressources/vues, et le suffixe du fichier modèle est .blade .php, utilisant le moteur de modèle Blade.
// 输出单个变量 {{ $var }} // 保留双大括号,编译为{{ var }} @{{ var }} // 可以输出默认值 {{ $var or '我是默认值' }} {{ isset($var) ? $var : '我是默认值' }} // Blade 注释 {{-- 这个注释不会输出到页面中 --}} // 忽略字符实体化,输出 JS 或 HTML {!! $var !!} // 注: 因为 Blade 模板引擎默认对{{}}语句进行了 htmlentities 字符实体化,所以要输出JS或HTML代码时,应使用上述语法
// if 语句 @if($var == 'laravel') I am laravel @elseif($var == 'yii') I am yii @else I don’t know what I am. @endif // 循环 @for ($i = 0; $i < 10; $i++) The current value is {{ $i }} @endfor @foreach ($array as $v) <p>我是数组成员 {{$v}}</p> @endforeach @forelse ($users as $v) <li>我的名字是{{ $v->name }}</li> @empty <p>我没有名字</p> @endforelse @while (true) <p>我一直在循环...</p> @endwhile // 可以嵌套 @for($i = 0; $i < 10; $i++) @if($i > 5) I am {{$i}} > 5 @endif @endfor
@include : Inclut les sous-vues, c'est-à-dire l'inclusion de fichiers.
Si plusieurs pages Web d'un site Web ont des parties communes, telles que la navigation supérieure, les recommandations de la barre latérale et les droits d'auteur inférieurs. Afin de faciliter la maintenance et la modification ultérieures, les parties publiques de ces pages Web peuvent être extraites sous forme de fichiers séparés, placés dans le dossier commun sous le répertoire view et nommés top.balde.php, side.blade.php et bottom.blade. respectivement. .php . Ensuite, dans chacun de nos modèles de vue, vous pouvez utiliser@include('common.top') // 将顶部导航包含进来,其他公共部分同样处理。
@include('common.top', ['location' => '首页'])
@extends: modèle héritage, héritage La disposition du modèle parent.
Dans la directive @include, il inclut la partie modèle extraite. La directive @extends hérite d'une mise en page de modèle principale existante. Il y a maintenant un répertoire de mises en page sous le répertoire de vue, et il y a un modèle principal master.blade.php sous le répertoire, avec la disposition suivante :<!DOCTYPE html> <html> <head> <title>@yield('title', '首页')</title> </head> <body> <p class="top">顶部</p> @yield('main') <p class="aside">侧栏</p> <p class="bottom">底部</p> </body> </html>
@extends('layouts.master') @section('title') 关于页 @endsection @section('main') <p class="main">【关于页】主内容</p> @endsection
Définition Bon routage vers la vue du modèle principal principal et la vue du sous-modèle enfant dans le navigateur. On voit que le sous-modèle enfant hérite du contenu du modèle principal maître : haut, barre latérale, bas
同时,child 子模板也显示了自己的网页标题 “关于页” 和主内容 “【关于页】主内容”
这就是 master 主模板中切片定义者 @yield 和 child 子模板中切片提供者 @section@endsection 的功劳了。
@yield、@section: 定义切片和提供切片。
@yield('main') 指令定义一段HTML切片,它指示了在这个位置显示一个名为'main'的切片
@section('main')@endsection 指令提供了一段HTML切片,它为@yield('main') 定义的'mian'切片提供了详细的内容。
那么有了切片的显示位置,有了切片的详细内容,就可以显示出一个详细的HTML切片了。
应该注意到了,在主模板 master 中有这么一个
@yield('title', '首页')
它指示了 'title' 切片的默认值。就是说,如果没有子模板继承主模板,或者继承了但没有用@section('title')@endsection 指令提供 'title' 切片,它将显示一个默认值 '首页' 。
现在,直接访问主模板看看
没错,没有子模板用 @section('title')@endsection 来提供标题, @yield('title', '首页') 显示了 'title' 切片的默认值 '首页'。
那么,主模板作为网站首页的话,它的主内容呢?如果要显示的话,难道又要写一个子模板来继承它,再用 @section@endsection 提供主内容?可不可以直接在主模板里写一个类似@yield('title', '首页') 提供的默认值呢?
当然可以,下面来重写主模板
@yield('title', '首页') 顶部
@section('main')【首页】主内容
@show侧栏
底部
@section('main')@show 可以提供 'main' 切片并显示出来。
现在访问主模板看看,首页主内容出来了。
并且,如果有子模板继承,并用 @section('main')@endsection 中也提供了一段'main'切片的话,这将覆 盖 主模板中的 'main'切片,而只显示自己定义的。类似于面向对象的重写。
在重写了主模板后,再访问子模板看看
因为子模板中 @sectioin('main')@endsection 提供了'main'切片,所以覆盖了父级中的'main'。
有时候可能需要子模板中重写但不覆盖主模板的切片内容,那么可以在子模板中使用 @parent 来显示主模板中的切片
@extends('layouts.master') @section('title') 关于页 @endsection @section('main') @parent <p class="main">【关于页】主内容</p> @endsection
访问子模板
显示子模板主内容的同时,也显示了主模板的主内容。
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!