Laravel 5. 미들웨어 및 뷰와 블레이드 템플릿 엔진의 예
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('admin')){ // 如果没有登录则定向到登录页 return redirect('admin/login'); } return $next($request); } }
이제 로그인 확인 미들웨어 AdminLoginVerify
를 만들고 정의하세요.
2 미들웨어를 등록하고
app/Http/Kernel에서 보호된 $를 찾으세요. .php 파일 RouteMiddleware 속성에 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, ];
3을 추가합니다. 경로 추가
app/Http/routes.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'); });
이것은 아래의 Index 컨트롤입니다. 배경 관리 디렉터리 장치 코드: re
<?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>'; } }
브라우저를 열고 배경의 배경 페이지를 방문하세요
2. 뷰
1. 뷰 렌더링 및 데이터 할당
방법 1. 배열 키-값 쌍 할당
// 在控制器中
$data = array(
'title' => 'Laravel',
'subTitle' => '高效快捷的PHP框架'
);
return view('my_laravel', $data);
// 在模板中
<?php echo $title;?>
<?php echo $subTitle;?>
로그인 후 복사
방법 2. 메소드 체인 할당// 在控制器中 $data = array( 'title' => 'Laravel', 'subTitle' => '高效快捷的PHP框架' ); return view('my_laravel', $data); // 在模板中 <?php echo $title;?> <?php echo $subTitle;?>
// 在控制器中 return view('my_laravel')->with('title', 'Laravel')->with('subTitle', '高效快捷的PHP框架'); // 在模板中(和上面的一样) <?php echo $title;?> <?php echo $subTitle;?>
방법 3. Compact() 함수를 사용하여
// 在控制器中 $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; ?>
3. 블레이드 템플릿 엔진
1. 출력 변수
// 输出单个变量
{{ $var }}
// 保留双大括号,编译为{{ var }}
@{{ var }}
// 可以输出默认值
{{ $var or '我是默认值' }}
{{ isset($var) ? $var : '我是默认值' }}
// Blade 注释
{{-- 这个注释不会输出到页面中 --}}
// 忽略字符实体化,输出 JS 或 HTML
{!! $var !!}
// 注: 因为 Blade 模板引擎默认对{{}}语句进行了 htmlentities 字符实体化,所以要输出JS或HTML代码时,应使用上述语法
로그인 후 복사
2. 프로세스 제어 // 输出单个变量 {{ $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
@extends 템플릿 상속 지시문.
@yield 슬라이스 정의 지침(슬라이스 표시 위치 정의).
@section Slice에서는 지침을 제공합니다(슬라이스의 세부 사항 정의).
@endsection @section의 끝 태그입니다.
@show @section의 끝 태그는 슬라이스 내용을 제공하는 동시에 슬라이스를 표시합니다.
@parent @section 콘텐츠 태그는 상위 템플릿의 조각을 표시합니다.
@include:
하위 뷰, 즉 파일 포함을 포함합니다.
웹사이트의 여러 웹페이지에 상단 탐색, 사이드바 추천, 하단 저작권 등 공통된 부분이 있는 경우. 나중에 유지 관리 및 수정을 용이하게 하기 위해 이러한 웹 페이지의 공개 부분을 별도의 파일로 추출하여 보기 디렉터리 아래의 공통 폴더에 배치하고 이름을 top.balde.php, side.blade.php 및 Bottom.blade로 지정할 수 있습니다. 각각 .php . 그런 다음 각 뷰 템플릿에서 @include('common.top') // 将顶部导航包含进来,其他公共部分同样处理。
@include('common.top', ['location' => '首页'])
템플릿 상속을 추가하여 상위 템플릿의 레이아웃을 상속할 수 있습니다.
@include 지시문에는 추출된 템플릿 부분이 포함되어 있습니다.
@extends 지시문은 기존 기본 템플릿 레이아웃을 상속합니다. 이제 view 디렉토리 아래에 레이아웃 디렉토리가 있고 디렉토리에 마스터 템플릿 master.blade.php가 있습니다. 레이아웃은 다음과 같습니다:
<!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>
그럼 제목이랑 본문은 어디있나요? 이를 위해서는 하위 템플릿이 필요합니다.
이제 뷰 디렉토리에 새로운 하위 템플릿 child.blade.php를 생성합니다. 내용은 다음과 같습니다:
@extends('layouts.master') @section('title') 关于页 @endsection @section('main') <p class="main">【关于页】主内容</p> @endsection
을 상속하는 것을 볼 수 있습니다.
同时,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
访问子模板
显示子模板主内容的同时,也显示了主模板的主内容。
위 내용은 Laravel 5. 미들웨어 및 뷰와 블레이드 템플릿 엔진의 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Laravel - Artisan Commands - Laravel 5.7은 새로운 명령을 처리하고 테스트하는 새로운 방법을 제공합니다. 여기에는 장인 명령을 테스트하는 새로운 기능이 포함되어 있으며 데모는 아래에 언급되어 있습니다.

Laravel 9 및 CodeIgniter 4의 최신 버전은 업데이트된 기능과 개선 사항을 제공합니다. Laravel9은 MVC 아키텍처를 채택하여 데이터베이스 마이그레이션, 인증, 템플릿 엔진 등의 기능을 제공합니다. CodeIgniter4는 HMVC 아키텍처를 사용하여 라우팅, ORM 및 캐싱을 제공합니다. 성능면에서는 Laravel9의 서비스 제공자 기반 디자인 패턴과 CodeIgniter4의 경량 프레임워크가 뛰어난 성능을 제공합니다. 실제 애플리케이션에서 Laravel9은 유연성과 강력한 기능이 필요한 복잡한 프로젝트에 적합한 반면, CodeIgniter4는 빠른 개발 및 소규모 애플리케이션에 적합합니다.

Laravel과 CodeIgniter의 데이터 처리 기능을 비교해 보세요. ORM: Laravel은 클래스-객체 관계형 매핑을 제공하는 EloquentORM을 사용하는 반면, CodeIgniter는 데이터베이스 모델을 PHP 클래스의 하위 클래스로 표현하기 위해 ActiveRecord를 사용합니다. 쿼리 빌더: Laravel에는 유연한 체인 쿼리 API가 있는 반면, CodeIgniter의 쿼리 빌더는 더 간단하고 배열 기반입니다. 데이터 검증: Laravel은 사용자 정의 검증 규칙을 지원하는 Validator 클래스를 제공하는 반면, CodeIgniter는 내장된 검증 기능이 적고 사용자 정의 규칙을 수동으로 코딩해야 합니다. 실제 사례: 사용자 등록 예시에서는 Lar를 보여줍니다.

Java 프레임워크는 다음 전략을 포함하여 미들웨어 재사용 및 리소스 공유를 지원합니다. 연결 풀을 통해 사전 설정된 미들웨어 연결 관리. 스레드 로컬 스토리지를 활용하여 미들웨어 연결을 현재 스레드와 연결합니다. 스레드 풀을 사용하여 재사용 가능한 스레드를 관리합니다. 로컬 또는 분산 캐시를 통해 자주 액세스하는 데이터의 복사본을 저장합니다.

대규모 프로젝트를 위한 프레임워크를 선택할 때 Laravel과 CodeIgniter는 각각 고유한 장점을 가지고 있습니다. Laravel은 엔터프라이즈급 애플리케이션을 위해 설계되었으며 모듈식 디자인, 종속성 주입 및 강력한 기능 세트를 제공합니다. CodeIgniter는 속도와 사용 편의성을 강조하여 중소 규모 프로젝트에 더 적합한 경량 프레임워크입니다. 요구 사항이 복잡하고 사용자 수가 많은 대규모 프로젝트의 경우 Laravel의 성능과 확장성이 더 적합합니다. 간단한 프로젝트나 리소스가 제한된 상황에서는 CodeIgniter의 가볍고 빠른 개발 기능이 더 이상적입니다.

초보자의 경우 CodeIgniter는 학습 곡선이 더 완만하고 기능이 적지만 기본적인 요구 사항을 충족합니다. Laravel은 더 넓은 기능 세트를 제공하지만 학습 곡선이 약간 더 가파릅니다. 성능면에서는 Laravel과 CodeIgniter 모두 좋은 성능을 보입니다. Laravel은 보다 광범위한 문서와 적극적인 커뮤니티 지원을 제공하는 반면 CodeIgniter는 더 간단하고 가벼우며 강력한 보안 기능을 갖추고 있습니다. 블로그 애플리케이션을 구축하는 실제 사례에서 Laravel의 EloquentORM은 데이터 조작을 단순화하는 반면 CodeIgniter는 더 많은 수동 구성이 필요합니다.

Laravel의 Blade와 CodeIgniter의 Twig 템플릿 엔진을 비교해 보면 프로젝트 요구 사항과 개인 선호도에 따라 선택하십시오. Blade는 MVC 구문을 기반으로 하므로 좋은 코드 구성과 템플릿 상속을 장려합니다. Twig는 유연한 구문, 강력한 필터, 확장된 지원 및 보안 샌드박스를 제공하는 타사 라이브러리입니다.

소규모 프로젝트의 경우 Laravel은 강력한 기능과 보안이 필요한 대규모 프로젝트에 적합합니다. CodeIgniter는 가볍고 사용하기 쉬운 매우 작은 프로젝트에 적합합니다.
