首页 > 其他分享 >9. Laravel 内置 web 认证

9. Laravel 内置 web 认证

时间:2023-02-28 11:47:44浏览次数:60  
标签:Laravel web 内置 function Auth 认证 user password email

Laravel 内置 web 认证

配套视频地址:https://www.bilibili.com/video/av74879198/

原理

  1. 注册:用户注册成功后。在服务器端生成 session 文件。给用户传递 session (文件名)。
  2. 登陆:用户使用账号密码登陆成功。在服务器端生成 session 文件。给用户传递 session (文件名)。
  3. 认证:将用户传来的 session 作为文件名去查找文件,找到了就认证成功,否则失败。

准备

composer create-project --prefer-dist laravel/laravel laravel6
下载 node   https://nodejs.org/en/
composer require laravel/ui
php artisan ui vue --auth
npm install cnpm -g --registry=https://registry.npm.taobao.org
cnpm install
cnpm run prod
php artisan migrate
访问 http://your-app.dev/register

如果不需要注册,可以路由中指定下,Auth::routes(['register' => false]);。

使用

修改跳转地址

// LoginController,  RegisterController, ResetPasswordController, ConfirmPasswordController and  VerificationController
protected $redirectTo = '/';
# 方法的优先级高于属性定义
protected function redirectTo()
{
    // 可以写一些逻辑
    return '/path';
    // return route('login');
}

认证字段修改

public function username(){
    return 'name';  // 默认 email
}

// $request->validate([
//     $this->username() => 'required|string',
//     'password' => 'required|string',
// ]);

获取登陆后的信息

$user = Auth::user();
$id = Auth::id();
if (Auth::check()) // 最好使用中间件!

$request->user()   // use \Illuminate\Http\Request;

添加认证条件

Route::get('profile', function () {
    // Only authenticated users may enter...
})->middleware('auth');

public function __construct()
{
    $this->middleware('auth');
}
Route::get('/settings/security', function () {
    // Users must confirm their password before continuing...
})->middleware('password.confirm');

如果登录失败次数过多,会禁止登录一段时间。默认五次。禁止登陆一分钟。
判断的标准是 username 方法返回值和 ip 。

登出

Auth::logout();

过期时间

// 默认过期时间是 env('SESSION_LIFETIME', 120);    120 分钟从最后一次访问服务器开始算。
// 'expire_on_close' => false                     如果是 true,关闭浏览器就过期

手动认证用户

# 当你不喜欢自带的控制器去认证用户,你可以移除这些控制器,
# 引入 Auth facade,利用 attempt 手动认证
class LoginController extends Controller
{
    public function authenticate(Request $request)
    {
        $credentials = $request->only('email', 'password');

        if (Auth::attempt($credentials)) {
            // Authentication passed...
            return redirect('/some/url');
        }
    }
}

// Route::post('/authenticate', 'Auth\LoginController@authenticate')->name('authenticate');

if (Auth::attempt(['email' => $email, 'password' => $password, 'active' => 1])) {
    // 字段 active 必须是 1
}

记住用户 (无限期)

# $remember 是个 bool 值
if (Auth::attempt(['email' => $email, 'password' => $password], $remember)) {
    // The user is being remembered... 内置的 LoginController 已经实现 remember
}
Auth::login($user);
Auth::login($user, true);  // 记住用户 (无限期)
Auth::loginUsingId(1);
Auth::loginUsingId(1, true);
Auth::once($credentials); // 临时认证,无状态的。

无登录页面, 利用弹窗请求认证用户

Route::get('profile', function(){
    // ...
})->middleware('auth.basic');

单设备登录

// 取消登陆在别的设备上的认证
// 取消注释:\Illuminate\Session\Middleware\AuthenticateSession::class,
Auth::logoutOtherDevices($password);

标签:Laravel,web,内置,function,Auth,认证,user,password,email
From: https://www.cnblogs.com/fuqian/p/17163468.html

相关文章

  • 10. Laravel api 认证
    Laravelapi认证配套视频地址:https://www.bilibili.com/video/av74879198?p=3原理注册:用户注册成功后,随机生成长字符串作为token,原生token返回给用户。哈希后的......
  • 12. Laravel Passport 授权码模式
    LaravelPassport授权码模式配套视频地址:https://www.bilibili.com/video/av74879198?p=7哔哩哔哩提供一个“微信登陆”的链接,用户点击跳转到微信授权服务器。用户......
  • 11. Laravel Passport 密码模式
    LaravelPassport密码模式配套视频地址:https://www.bilibili.com/video/av74879198?p=5准备工作composercreate-project--prefer-distlaravel/laravellaravel6.......
  • Websocket 60秒断开,连接不稳定
    本地测试都是正常的,线上测试总是过一会就断开...线上新增了https协议,导致页面中的链接必须也是sslWebsocket链接地址从ws://ws.xxx.com改成了wss://ws.xxx.com最开始htt......
  • Web 缓存欺骗总结
    Web缓存欺骗总结Web缓存欺骗(WCD)是一种攻击,在这种攻击中,攻击者欺骗缓存代理,使其不正确地存储通过Internet发送的私人信息并获得对该缓存数据的未授权访问。它是由......
  • 跟女朋友介绍十个常用的 Python 内置函数,她夸了我一整天
    内置函数是什么了解内置函数之前,先来了解一下什么是函数 将使用频繁的代码段进行封装,并给它起一个名字,当我们使用的时候只需要知道名字就行函数就是一段封装好的、可......
  • 使用MetaWeblog api自动上传文章图片到cnblog
    由于我日常习惯用Typora来写笔记和博客,文章中的图片保存在本地,在发布文章到cnblog之前,希望能有一个自动化工具可以自动上传文章引用的图片到cnblog,获取图片链接,替换掉......
  • JavaWeb 读资源的问题-2023-2-27
    1、db.properties文件中读取username和password2、getResourceAsStream("/web-inf/classes/db.properties")3、properties.getProperty("username")publicclass......
  • Web开发的常用攻击和防御方式
    一、XSS主要利用:1.盲目相信用户提交的内容2.直接把用户的字符串转化成DOM分类:1.存储型XSS,恶意脚本存在数据库中,所有访问页面的用户都会被攻击2.反射型XSS,脚本写在URL......
  • web自动化--等待
    一、常用知识:一、强制等待time.sleep(3)二、隐式等待语法:driver.implicitly_wait(s)1、整个会话只执行一次,全局起作用,后面的每一次元素查找都会进行等待,在设置的时......