Laravel 5 基础(十二)- 认证
Laravel 出厂已经带有了用户认证系统,我们来看一下 routes.php
,如果删除了,添加上:
<code>Route::controllers([ 'auth' => 'Auth\AuthController', 'password' => 'Auth\PasswordController' ]);</code>
可以使用 php artisan route:list
查看一下。浏览器中访问 /auth/login
,可以看到登陆界面,最好把系统默认的 app.blade.php
中关于 google 的东西注释起来,要不然你会疯掉的。
你可以使用 register、login甚至 forget password。
实际注册一个用户,提交后失败了,实际上没有失败,只是larave自动跳转到了 /home
,我们已经删除了这个控制器。你可以使用 tinker
看一下,用户已经建立了。
在 Auth\AuthController
中实际上使用了 trait
,什么是 triat?well,php只支持单继承,在php5.4中添加了trait,一个trait实际上是一组方法的封装,你可以把它包含在另一个类中。像是抽象类,你不能直接实例化他。
在 Auth\AuthController
中有对 trait 的引用:
<code>use AuthenticatesAndRegistersUsers;</code>
让我们找到他,看一下注册后是怎么跳转的。他隐藏的挺深的,在 vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesAndregistersUsers.php
,wow。
<code> public function redirectPath() { if (property_exists($this, 'redirectPath')) { return $this->redirectPath; } //如果用户设置了 redirectTo 属性,则跳转到用户设置的属性,否则到home return property_exists($this, 'redirectTo') ? $this->redirectTo : '/home'; } </code>
OK,我们知道了,只要设定 redirectTo
这个属性就可以自定义注册后的跳转了。我们在 Auth\AuthContotroller
中修改:
<code> protected $redirectTo = 'articles';</code>
我们先使用 /auth/logout
确保我们退出,如果出错了不要害怕,我们没有默认的主页,重新访问:auth/register
新建一个用户,这次应该ok了。
再次logout,然后使用 login 登陆一下。
现在我们可以删除 form_partial
中临时设置的隐藏字段了,然后修改控制器:
<code> public function store(Requests\ArticleRequest $request) { //你可以这样 //$request = $request->all(); //$request['user_id'] = Auth::id(); //更简单的方法 $article = Article::create($request->all()); //laravel 自动完成外键关联 Auth::user()->articles()->save($article); return redirect('articles'); }</code>
添加一个文章,然后使用 tinker
查看一下。
中间件
我们当然不希望任何人都能发布文章,至少是登陆用才可以。我们在控制器中添加保护:
<code> public function create() { if (Auth::guest()) { return redirect('articles'); } return view('articles.create'); }</code>
上面的代码可以工作,有一个问题,我们需要在每一个需要保护的方法中都进行上面的处理,这样做太傻了,幸好我们有中间件。
中间件可以理解为一个处理管道,中间件在管道中的某一时刻进行处理,这个时刻可以是请求也可以是响应。依据中间件的处理规则,可能将请求重定向,也可能通过请求。
在 app/http/middleware
中包含了三个中间件,名字就可以看出是干什么,好好查看一下,注意,Closure $next
代表了下一个中间件。
在 app/http/kernel.php
中对中间件进行登记。$middleware
段声明了对所有http都进行处理的中间件,$routeMiddleware
仅仅对路由进行处理,而且你必须显示的声明要使用这其中的某一个或几个中间件。
假设我们想对整个的 ArticlesController
进行保护,我们直接在构造函数中添加中间件:
<code> public function __construct() { $this->middleware('auth'); }</code>
现在,任何方法都收到了保护。
但我们可能不想整个控制器都受到保护,如果只是其中的一两个方法呢?我们可以这样处理:
<code> public function __construct() { $this->middleware('auth', ['only' => 'create']); //当然可以反过来 //$this->middleware('auth', ['except' => 'index']); }</code>
我们不一定在控制器的构造函数中引入中间件,我们可以直接在路由中声明:
<code>Route::get('about', ['middleware' => 'auth', 'uses' => 'PagesController@about']);</code>
在 kernel.php
中提供的系统中间件,比如 'Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode'
是可以让我们进入到维护模式,比如系统上线了,但现在需要临时关闭一段时间进行处理,我们可以在命令行进行处理,看一下这个中间件的工作:
<code>php artisan down</code>
访问一下网站,可以看到任何 url 的请求都是马上回来。网站上线:
<code>php artisan up</code>
我们来做一个自己的中间件:
<code> php artisan make:middleware Demo</code>
然后添加代码:
<code> public function handle($request, Closure $next) { //如果请求中含有 foo,我们就回到控制器首页 if ($request->has('foo')) { return redirect('articles'); } return $next($request); }</code>
如果希望在全部的请求使用中间件,需要在 kernel.php
中的 $middleware
中登记:
<code> protected $middleware = [ ... 'App\Http\Middleware\Demo', ];</code>
现在我们可以测试一下,假设我们访问 /articles/create?foo=bar
,我们被重定向到了首页。
让我们去除这个显示中间件,我们来创建一个真正有用的中间件。假设我们想保护某个页面,这个页面必须是管理者才能访问的。
<code>php artisan make:middleware RedirectIfNotAManager</code>
我们来添加处理代码:
<code> public function handle($request, Closure $next) { if (!$request->user() || !$request->user()->isATeamManager()) { return redirect('articles'); } return $next($request); }</code>
下面修改我们的模型:
<code> public function isATeamManager() { return false; }</code>
简单起见,我们直接返回false。这次我们把中间件放置在 kernel.php
中的$routeMiddleware
中。
<code> protected $routeMiddleware = [ ... 'manager' => 'App\Http\Middleware\RedirectIfNotAManager', ];</code>
我们做一个测试路由测试一下:
<code>Route::get('foo', ['middleware' => 'manager', function() { return 'This page may only be viewed by manager'; }]);</code>
guest身份访问或者登录身份访问都会返回主页,但是如果修改 isATeamManager()
返回 true
,登录身份访问可以看到返回的信息。
以上就介绍了Laravel 5 基础(十二)- 认证,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

L'utilisation de return en langage C est la suivante : 1. Pour les fonctions dont le type de valeur de retour est void, vous pouvez utiliser l'instruction return pour terminer l'exécution de la fonction plus tôt. 2. Pour les fonctions dont le type de valeur de retour n'est pas void, la fonction de ; l'instruction return sert à terminer l'exécution de la fonction.Le résultat est renvoyé à l'appelant ;3. Terminer l'exécution de la fonction plus tôt que prévu.À l'intérieur de la fonction, nous pouvons utiliser l'instruction return pour terminer l'exécution de la fonction plus tôt. si la fonction ne renvoie pas de valeur.

La signification chinoise de request est "request". Il s'agit d'une variable globale en PHP et c'est un tableau contenant "$_POST", "$_GET" et "$_COOKIE". La variable "$_REQUEST" peut obtenir des données et des informations COOKIE soumises par POST ou GET.

Code source : publicclassReturnFinallyDemo{publicstaticvoidmain(String[]args){System.out.println(case1());}publicstaticintcase1(){intx;try{x=1;returnx;}finally{x=3;}}}# Sortie La sortie du code ci-dessus peut simplement conclure : return est exécuté avant finalement. Jetons un coup d'œil à ce qui se passe au niveau du bytecode. Ce qui suit intercepte une partie du bytecode de la méthode case1 et compare le code source pour annoter la signification de chaque instruction dans

L'objet Request en PHP est un objet utilisé pour gérer les requêtes HTTP envoyées par le client au serveur. Grâce à l'objet Request, nous pouvons obtenir les informations de demande du client, telles que la méthode de demande, les informations d'en-tête de demande, les paramètres de demande, etc., afin de traiter et de répondre à la demande. En PHP, vous pouvez utiliser des variables globales telles que $_REQUEST, $_GET, $_POST, etc. pour obtenir les informations demandées, mais ces variables ne sont pas des objets, mais des tableaux. Afin de traiter les informations demandées de manière plus flexible et plus pratique, vous pouvez

Comment utiliser la fonction urllib.request.urlopen() dans Python3.x pour envoyer une requête GET En programmation réseau, nous avons souvent besoin d'obtenir des données d'un serveur distant en envoyant une requête HTTP. En Python, nous pouvons utiliser la fonction urllib.request.urlopen() dans le module urllib pour envoyer une requête HTTP et obtenir la réponse renvoyée par le serveur. Cet article explique comment utiliser

Dans le développement de logiciels modernes, l’authentification de l’identité est une mesure de sécurité très importante. Auth0 est une société qui fournit des services d'authentification d'identité. Elle peut aider les développeurs à mettre en œuvre rapidement plusieurs méthodes d'authentification d'identité (y compris OAuth2, OpenIDConnect, etc.) et à fournir des services d'authentification sûrs et fiables. Dans cet article, nous présenterons comment utiliser Auth0 pour l'authentification dans le développement JavaAPI. Étape 1 : Créez un compte Auth0 et enregistrez l'application. Tout d'abord, nous devons.

Le rôle et l'importance de Request en PHP Dans la programmation PHP, Request est un mécanisme d'envoi de requêtes au serveur Web. Il joue un rôle essentiel dans le développement Web. La requête est principalement utilisée pour obtenir des données envoyées par le client, telles que la soumission d'un formulaire, une requête GET ou POST, etc. Grâce à la requête, les données saisies par l'utilisateur peuvent être obtenues et les données peuvent être traitées et traitées. Cet article présentera le rôle et l'importance de Request en PHP et donnera des exemples de code spécifiques.

1. Créez un nouveau fichier appelé request.js et importez Axios : importaxiosfrom'axios' ; 2. Créez une fonction appelée request et exportez-la : Cela créera une fonction appelée request et l'exportera. Configurez une nouvelle instance Axios avec une URL de base. . Pour ajouter des paramètres de délai d'attente dans une instance Axios encapsulée, vous pouvez transmettre l'option de délai d'attente lors de la création de l'instance Axios. exportconstrequest=axios.create({baseURL:'https://example.
