ホームページ >バックエンド開発 >PHPチュートリアル >Laravel 5. ミドルウェアとビュー、および Blade テンプレート エンジンの例

Laravel 5. ミドルウェアとビュー、および Blade テンプレート エンジンの例

黄舟
黄舟オリジナル
2017-09-11 10:06:391769ブラウズ

1. ミドルウェア

Laravel の HTTP ミドルウェアは、ルーティングのフィルタリングと保護の層を提供します。ミドルウェアを使用してバックグラウンド ログインを検証するシミュレーションをしてみましょう。

1. ミドルウェアの作成

cmd ウィンドウでプロジェクト ディレクトリに入り、artisan コマンドを使用して


php artisan make:middleware AdminLoginVerify

これにより、app/Http/Middleware ディレクトリにミドルウェア AdminLoginVerify が作成されます

handle() 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);
    }
}

さて、ログイン ミドルウェア AdminLoginVerify

を作成して定義します

2. ミドルウェア

を登録し、app/Http/Kernel で protected $ を見つけます。 php ファイルの RouteMiddleware 属性に 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. ルートを追加します

app/Http/routes.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;);
});

これは背景の下にある Index コントロールです。管理ディレクトリ デバイスのコード: re

<?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. シミュレーションログイン


ブラウザを開き、背景の背景ページにアクセスします

、背景のホームページにアクセスします

ここでログインを終了します

ログアウト状態でホームページにアクセスすると、ログインページにリダイレクトされます。

2. ビュー

1. ビューをレンダリングしてデータを割り当てる

方法 1. 配列のキーと値のペアの割り当て

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

方法 2. メソッドチェーンの割り当てを使用する


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

方法3. Compact() 関数を使用して


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

を割り当てます。このうち、view() 関数の最初のパラメータである my_laravel は、resources/views ビュー ディレクトリにあります。ファイルのサフィックスは .blade.php で、ブレード テンプレート エンジンを使用します。


3. ブレード テンプレート エンジン

1. 出力変数

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

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

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

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

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

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

3. ファイルには命令が含まれています。

@extends テンプレート継承ディレクティブ。


@yield スライス定義指示(スライスの表示位置を定義します)。

@section スライスは命令を提供します (スライスの詳細を定義します)。

@endsection @section の終了タグ。

@show @section の終了タグはスライスの内容を提供し、同時にスライスを表示します。

@parent @section コンテンツ タグは、親テンプレートのスライスを表示します。

@include:

サブビュー、つまりファイルのインクルードを含みます。

Web サイト内の複数の Web ページに、上部のナビゲーション、サイドバーの推奨事項、下部の著作権などの共通部分がある場合。後のメンテナンスと変更を容易にするために、これらの Web ページの公開部分を個別のファイルとして抽出し、ビュー ディレクトリの下の共通フォルダーに配置し、top.balde.php、side.blade.php、bottom.blade という名前を付けることができます。それぞれ.php。次に、各ビュー テンプレートで

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

を使用できます。変数を渡す必要がある場合は、パラメーター

 @include(&#39;common.top&#39;, [&#39;location&#39; => &#39;首页&#39;])
@extends: テンプレートの継承を追加して、親テンプレートのレイアウトを継承できます。

@include ディレクティブには、抽出したテンプレート部分をインクルードします。

@extends ディレクティブは、既存のメイン テンプレート レイアウトを継承します。

ビューディレクトリの下にレイアウトディレクトリがあり、そのディレクトリにマスターテンプレートmaster.blade.phpがあります。レイアウトは次のとおりです:

<!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>

@yield('title', 'Homepage' ) ディレクティブは 1f2121e51168fe07e3cb8c828fc28d77 で定義されています。

@yield('main') は、トップ列とサイド列の間に表示されるメイン コンテンツを定義します。


それでは、タイトルとメインコンテンツはどこにあるのでしょうか?これにはサブテンプレートが必要です。

ここで、ビューディレクトリに新しいサブテンプレート child.blade.php を作成します。内容は次のとおりです:

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

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

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

マスターのメインテンプレートビューと子のサブテンプレートを指すルートを定義します表示し、ブラウザで子サブテンプレートにアクセスします View


子サブテンプレートがマスターメインテンプレートのコンテンツを継承していることがわかります: トップ、サイドバー、ボトム

同时,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

 

访问子模板

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

以上がLaravel 5. ミドルウェアとビュー、および Blade テンプレート エンジンの例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。