Heim  >  Artikel  >  Backend-Entwicklung  >  Laravel 5. Beispiele für Middleware und Ansichten sowie die Blade-Template-Engine

Laravel 5. Beispiele für Middleware und Ansichten sowie die Blade-Template-Engine

黄舟
黄舟Original
2017-09-11 10:06:391695Durchsuche

1. Middleware

Die HTTP-Middleware von Laravel bietet eine Filter- und Schutzebene für das Routing. Lassen Sie uns die Verwendung von Middleware simulieren, um die Hintergrundanmeldung zu überprüfen.

1. Middleware erstellen

cmd-Fenster und geben Sie das Projektverzeichnis ein, verwenden Sie den Befehl artisan, um


php artisan make:middleware AdminLoginVerify

zu erstellen in App/ Http/Middleware-Verzeichniserstellungs-Middleware AdminLoginVerify

Verifizierungslogik in der handle()-Methode der AdminLoginVerify-Klasse hinzufügen:


<?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);
    }
}

ok, erstellen und definieren Sie jetzt die Anmeldeverifizierungs-Middleware AdminLoginVerify

2. Die Registrierungs-Middleware

befindet sich in der Datei app/Http/Kernel.php protected $routeMiddleware-Attribut, fügen Sie unser 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,
    ];

3 hinzu Weiterleitung zur PHP-Datei:


// 后台首页路由、退出登录路由
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;);
});
Dies ist der Code des Index-Controllers im Hintergrund-Admin-Verzeichnis:


<?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;;
    }
}
4. Anmeldung simulieren

Öffnen Sie den Browser und besuchen Sie die Hintergrund-Anmeldeseite

Okay Ja, besuchen Sie die Hintergrund-Homepage

Jetzt melden wir uns ab

Im abgemeldeten Zustand greifen wir zu Die Startseite wird umgeleitet. Gehen Sie zur Anmeldeseite.

2. Ansicht

1. Rendern Sie die Ansicht und weisen Sie Daten zu

Methode 1. Zuordnung von Array-Schlüssel-Wert-Paaren


Methode 2. mit Methodenkettenzuordnung

// 在控制器中
$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;?>


// 在控制器中
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;?>
Methode 3. Verwendung von compact() Funktionszuweisung


Unter diesen ist der erste Parameter my_laravel der Funktion view() der Name der Ansichtsvorlage, der sich im Ansichtsverzeichnis resources/views befindet, und Das Suffix der Vorlagendatei lautet .blade .php, wobei die Blade-Vorlagen-Engine verwendet wird.

// 在控制器中
$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; ?>

3. Blade-Vorlagen-Engine

1. Ausgabevariablen


2 🎜>

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

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

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

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

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

3. Vorlagenlayout und Unteransichten

@include-Datei enthält Anweisungen.
// 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

@extends Template-Vererbungsanweisung.

@yield Slice-Definitionsbefehl (Slice-Anzeigeposition definieren).

@section Slice stellt Anweisungen bereit (definiert die Details des Slice).

@endsection Das End-Tag von @section.

@show Das End-Tag von @section stellt den Slice-Inhalt bereit und zeigt gleichzeitig das Slice an.

@parent @section Content-Tag zeigt die Slices der übergeordneten Vorlage an.

@include:

Beinhaltet Unteransichten, also die Dateieinbindung. Wenn mehrere Webseiten einer Website gemeinsame Teile haben, wie z. B. die obere Navigation, Empfehlungen in der Seitenleiste und das Urheberrecht unten. Um die spätere Wartung und Änderung zu erleichtern, können die öffentlichen Teile dieser Webseiten als separate Dateien extrahiert, im gemeinsamen Ordner unter dem Ansichtsverzeichnis abgelegt und mit den Namen top.balde.php, aside.blade.php und bottom.blade benannt werden bzw. .php . Dann können Sie in jeder unserer Ansichtsvorlagen die Vorlage

verwenden. Wenn Sie Variablen übergeben müssen, können Sie Parameter

@include(&#39;common.top&#39;) // 将顶部导航包含进来,其他公共部分同样处理。

@extends:

hinzufügen Vererbung, Vererbung Das Layout der übergeordneten Vorlage.
 @include(&#39;common.top&#39;, [&#39;location&#39; => &#39;首页&#39;])

In der @include-Direktive wird der extrahierte Vorlagenteil einbezogen. Die @extends-Direktive erbt ein vorhandenes Hauptvorlagenlayout.

Jetzt gibt es unter dem Ansichtsverzeichnis ein Layoutverzeichnis und unter dem Verzeichnis eine Mastervorlage master.blade.php mit dem folgenden Layout:

@ Die yield('title', 'Home')-Direktive definiert die Anzeige des Webseitentitels im b2386ffb911b14667cb8f0f91ea547a7

@yield('main') definiert die Anzeige von der Hauptinhalt zwischen der oberen und der seitlichen Spalte.
<!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>

Wo sind also der Titel und der Hauptinhalt? Dies erfordert Untervorlagen.

Jetzt erstellen wir im Ansichtsverzeichnis eine neue Untervorlage child.blade.php mit folgendem Inhalt:

 

Definition Gute Weiterleitung zur Master-Hauptvorlagenansicht und zur untergeordneten Untervorlagenansicht
@extends(&#39;layouts.master&#39;)

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

@section(&#39;main&#39;)
    <p class="main">【关于页】主内容</p>
@endsection

im Browser. Wir sehen, dass die untergeordnete Untervorlage den Inhalt der Master-Hauptvorlage erbt: oben, Seitenleiste, unten

同时,child 子模板也显示了自己的网页标题 “关于页” 和主内容 “【关于页】主内容”

这就是 master 主模板中切片定义者 @yield 和 child 子模板中切片提供者 @section@endsection 的功劳了。

 

@yield、@section: 定义切片和提供切片。

@yield('main') 指令定义一段HTML切片,它指示了在这个位置显示一个名为'main'的切片

@section('main')@endsection 指令提供了一段HTML切片,它为@yield('main') 定义的'mian'切片提供了详细的内容。

那么有了切片的显示位置,有了切片的详细内容,就可以显示出一个详细的HTML切片了。

 

应该注意到了,在主模板 master 中有这么一个


@yield(&#39;title&#39;, &#39;首页&#39;)

它指示了 'title' 切片的默认值。就是说,如果没有子模板继承主模板,或者继承了但没有用@section('title')@endsection 指令提供 'title' 切片,它将显示一个默认值 '首页' 。

现在,直接访问主模板看看

没错,没有子模板用 @section('title')@endsection 来提供标题, @yield('title', '首页') 显示了 'title' 切片的默认值 '首页'。

那么,主模板作为网站首页的话,它的主内容呢?如果要显示的话,难道又要写一个子模板来继承它,再用 @section@endsection 提供主内容?可不可以直接在主模板里写一个类似@yield('title', '首页') 提供的默认值呢?

当然可以,下面来重写主模板





    @yield(&#39;title&#39;, &#39;首页&#39;)


    

顶部

@section('main')

【首页】主内容

@show

侧栏

底部

@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

 

访问子模板

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

Das obige ist der detaillierte Inhalt vonLaravel 5. Beispiele für Middleware und Ansichten sowie die Blade-Template-Engine. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn