Laravel 5. Exemples de middleware et de vues et moteur de modèles Blade

黄舟
Libérer: 2023-03-15 21:54:01
original
1760 Les gens l'ont consulté

1. Middleware

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.

1. Créez une fenêtre middleware

cmd et entrez dans le répertoire du projet, utilisez la commande artisan pour créer


php artisan make:middleware AdminLoginVerify
Copier après la connexion

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(&#39;admin&#39;)){ // 如果没有登录则定向到登录页
            return redirect(&#39;admin/login&#39;);
        }
        return $next($request);
    }
}
Copier après la connexion

ok, maintenant créez et définissez le middleware AdminLoginVerify

2. Le middleware d'enregistrement

se trouve dans le fichier app/Http/Kernel.php protected $ attribut routeMiddleware, ajoutez notre AdminLoginVerify


protected $routeMiddleware = [
        &#39;auth&#39; => \App\Http\Middleware\Authenticate::class,
        &#39;auth.basic&#39; => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
        &#39;can&#39; => \Illuminate\Foundation\Http\Middleware\Authorize::class,
        &#39;guest&#39; => \App\Http\Middleware\RedirectIfAuthenticated::class,
        &#39;throttle&#39; => \Illuminate\Routing\Middleware\ThrottleRequests::class,
         // 自定义中间件
        &#39;adminLoginVerify&#39; => \App\Http\Middleware\AdminLoginVerify::class,
    ];
Copier après la connexion

3. Ajouter un itinéraire

dans app/Http/routes. le fichier php :


// 后台首页路由、退出登录路由
Route::group([&#39;prefix&#39; => &#39;admin&#39;, &#39;namespace&#39; => &#39;Admin&#39;, &#39;middleware&#39; => &#39;adminLoginVerify&#39;], function(){
    Route::get(&#39;index&#39;, &#39;IndexController@index&#39;);
    Route::get(&#39;logout&#39;, &#39;IndexController@logout&#39;);
});

// 后台登录路由
Route::group([&#39;middleware&#39; => &#39;web&#39;], function(){
    Route::get(&#39;admin/login&#39;, &#39;Admin\IndexController@login&#39;);
});
Copier après la connexion

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 &#39;<h1>欢迎你,&#39; . session(&#39;admin&#39;) . &#39;</h1>&#39;;
    }

    // 后台登录
    public function login(){
        session([&#39;admin&#39; => &#39;mingc&#39;]);
        return &#39;<h1>后台登录</h1>&#39;;
    }

    // 退出登陆
    public function logout(){
        session([&#39;admin&#39; => null]);
        return &#39;<h1>退出登录</h1>&#39;;
    }
}
Copier après la connexion

4. Simuler la connexion

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.

2. Vue

1. Rendre la vue et allouer les données

Méthode 1. Allocation de paire clé-valeur de tableau


// 在控制器中
$data = array(
    &#39;title&#39; => &#39;Laravel&#39;,
    &#39;subTitle&#39; => &#39;高效快捷的PHP框架&#39;
);
return view(&#39;my_laravel&#39;, $data);

// 在模板中
<?php echo $title;?>
<?php echo $subTitle;?>
Copier après la connexion

Méthode 2. avec allocation de chaîne de méthodes


// 在控制器中
return view(&#39;my_laravel&#39;)->with(&#39;title&#39;, &#39;Laravel&#39;)->with(&#39;subTitle&#39;, &#39;高效快捷的PHP框架&#39;);

// 在模板中(和上面的一样)
<?php echo $title;?>
<?php echo $subTitle;?>
Copier après la connexion

Méthode 3. Utilisation de compact() allocation de fonction


// 在控制器中
$data = array(
    &#39;title&#39; => &#39;Laravel&#39;,
    &#39;subTitle&#39; => &#39;高效快捷的PHP框架&#39;
);
$content = &#39;Laravel 5.2 在 5.1 基础上继续改进和优化,添加了许多新的功能特性...&#39;;
return view(&#39;my_laravel&#39;, compact(&#39;data&#39;, &#39;content&#39;));

// 在模板中(和前两个不太一样)
<?php echo $data[&#39;title&#39;] ; ?>
<?php echo $data[&#39;subTitle&#39;]; ?>
<?php echo $content; ?>
Copier après la connexion

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.

3. Moteur de modèle de lame

1. Variables de sortie


// 输出单个变量
{{ $var }}

// 保留双大括号,编译为{{ var }}
@{{ var }}

// 可以输出默认值
{{ $var or &#39;我是默认值&#39; }}
{{ isset($var) ? $var : &#39;我是默认值&#39; }}

// Blade 注释
{{-- 这个注释不会输出到页面中 --}}

// 忽略字符实体化,输出 JS 或 HTML
{!! $var !!}
// 注: 因为 Blade 模板引擎默认对{{}}语句进行了 htmlentities 字符实体化,所以要输出JS或HTML代码时,应使用上述语法
Copier après la connexion

2. 🎜>


// if 语句
@if($var == &#39;laravel&#39;)
    I am laravel
@elseif($var == &#39;yii&#39;)
    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
Copier après la connexion
3. Disposition du modèle et sous-vues

Le fichier @include contient des instructions.

@extends Directive d'héritage de modèle.

@yield Commande de définition de tranche (définir la position d'affichage de la tranche).

@section Slice fournit des instructions (définissant les détails de la tranche).

@endsection La balise de fin de @section.

@show La balise de fin de @section fournit le contenu de la tranche et affiche la tranche en même temps.

La balise de contenu @parent @section affiche des tranches du modèle parent.

@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(&#39;common.top&#39;) // 将顶部导航包含进来,其他公共部分同样处理。
Copier après la connexion
Si vous devez transmettre des variables, vous pouvez ajouter des paramètres

 @include(&#39;common.top&#39;, [&#39;location&#39; => &#39;首页&#39;])
Copier après la connexion

@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(&#39;title&#39;, &#39;首页&#39;)</title>
</head>
<body>
    <p class="top">顶部</p>
    @yield(&#39;main&#39;)
    <p class="aside">侧栏</p>
    <p class="bottom">底部</p>
</body>
</html>
Copier après la connexion
@ La directive rendement('title', 'Home') définit l'affichage du titre de la page web dans la balise <p></p>@yield('main') définit l'affichage de le contenu principal entre les colonnes du haut et du côté. <p></p> <p></p>Alors où sont le titre et le contenu principal ? Cela nécessite des sous-modèles. <p></p>Maintenant, nous créons un nouveau sous-modèle child.blade.php dans le répertoire de vue, avec le contenu suivant : <p></p><p class="cnblogs_Highlighter"><br/></p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;gutter:true;">@extends(&#39;layouts.master&#39;) @section(&#39;title&#39;) 关于页 @endsection @section(&#39;main&#39;) <p class="main">【关于页】主内容</p> @endsection</pre><div class="contentsignin">Copier après la connexion</div></div> <p> </p>Définition Bon routage vers la vue du modèle principal principal et la vue du sous-modèle enfant <p></p><p><img src="https://img.php.cn/upload/article/000/000/194/7fe0e7a2b6084928ac5070d2f267c408-3.png" alt=""/></p> <p></p> 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 <p><p>同时,child 子模板也显示了自己的网页标题 “关于页” 和主内容 “【关于页】主内容”</p><p>这就是 master 主模板中切片定义者 @yield 和 child 子模板中切片提供者 @section@endsection 的功劳了。</p><p> </p><p><strong>@yield、@section: 定义切片和提供切片。</strong></p><p>@yield('main') 指令定义一段HTML切片,它指示了在这个位置显示一个名为'main'的切片</p><p>@section('main')@endsection 指令提供了一段HTML切片,它为@yield('main') 定义的'mian'切片提供了详细的内容。</p><p>那么有了切片的显示位置,有了切片的详细内容,就可以显示出一个详细的HTML切片了。</p><p> </p><p>应该注意到了,在主模板 master 中有这么一个</p><p class="cnblogs_Highlighter"><br/></p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;gutter:true;">@yield(&#39;title&#39;, &#39;首页&#39;)</pre><div class="contentsignin">Copier après la connexion</div></div><p>它指示了 'title' 切片的默认值。就是说,如果没有子模板继承主模板,或者继承了但没有用@section('title')@endsection 指令提供 'title' 切片,它将显示一个默认值 '首页' 。</p><p>现在,直接访问主模板看看</p><p><img src="https://img.php.cn/upload/article/000/000/194/7fe0e7a2b6084928ac5070d2f267c408-4.png" alt=""/></p><p>没错,没有子模板用 @section('title')@endsection 来提供标题, <span class="cnblogs_code">@yield(&#39;title&#39;, &#39;首页&#39;)</span> 显示了 'title' 切片的默认值 '首页'。</p><p>那么,主模板作为网站首页的话,它的主内容呢?如果要显示的话,难道又要写一个子模板来继承它,再用 @section@endsection 提供主内容?可不可以直接在主模板里写一个类似@yield(&#39;title&#39;, &#39;首页&#39;) 提供的默认值呢?</p><p>当然可以,下面来重写主模板</p><p class="cnblogs_Highlighter"><br/></p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:html;gutter:true;"><!DOCTYPE html> <html> <head> <title>@yield(&#39;title&#39;, &#39;首页&#39;)

顶部

@section('main')

【首页】主内容

@show

侧栏

底部

Copier après la connexion

@section('main')@show 可以提供 'main' 切片并显示出来。

现在访问主模板看看,首页主内容出来了。

并且,如果有子模板继承,并用 @section('main')@endsection 中也提供了一段'main'切片的话,这将覆 盖 主模板中的 'main'切片,而只显示自己定义的。类似于面向对象的重写。

在重写了主模板后,再访问子模板看看

因为子模板中 @sectioin('main')@endsection 提供了'main'切片,所以覆盖了父级中的'main'。

有时候可能需要子模板中重写但不覆盖主模板的切片内容,那么可以在子模板中使用 @parent 来显示主模板中的切片


@extends(&#39;layouts.master&#39;)

@section(&#39;title&#39;)
    关于页
@endsection

@section(&#39;main&#39;)    @parent
    <p class="main">【关于页】主内容</p>
@endsection
Copier après la connexion

 

访问子模板

显示子模板主内容的同时,也显示了主模板的主内容。

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Recommandations populaires
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal