>PHP 프레임워크 >Laravel >laravel은 앱 측 로그인을 구현합니다

laravel은 앱 측 로그인을 구현합니다

王林
王林원래의
2023-05-26 11:43:071038검색

스마트폰 애플리케이션이 증가함에 따라 모바일 애플리케이션 개발에 대한 요구가 날로 증가하고 있습니다. 사용자 로그인은 사용자 정보의 보안을 보호할 뿐만 아니라 모바일 애플리케이션에서도 매우 중요한 기능 중 하나가 되었습니다. 사용자가 다양한 시간에 로그인하여 자신의 장치에 있는 정보에 빠르게 액세스할 수 있습니다. Laravel은 개발자가 APP 측의 로그인 기능을 포함하여 애플리케이션의 다양한 기능을 구현하는 데 도움이 되는 많은 내장 기능과 확장 패키지를 제공하는 인기 있는 PHP 프레임워크입니다. 이번 글에서는 Laravel을 사용하여 APP 로그인 기능을 구현하는 방법을 소개하겠습니다.

1. Laravel 설치 및 구성

Laravel에서 APP 로그인 기능을 구현하기 전에 Laravel 환경을 설치하고 구성해야 합니다. 먼저 Composer 도구(https://getcomposer.org/)를 설치했는지 확인하세요. 그런 다음, 다음 명령을 실행하여 컴퓨터에 Laravel을 설치하세요.

composer create-project --prefer-dist laravel/laravel myapp

여기서 "myapp"은 생성하려는 Laravel 애플리케이션의 이름입니다.

설치가 완료된 후 myapp 디렉터리로 이동하여 다음 명령을 실행하여 로컬 개발 서버를 시작할 수 있습니다.

php artisan serve

Laravel 시작 페이지를 보려면 http://localhost:8000을 방문하세요. 다음으로, APP 측에서 로그인 기능을 지원하도록 Passport 확장 패키지를 설치하고 구성해야 합니다.

다음 명령을 실행하여 Passport 확장 팩을 설치합니다.

composer require laravel/passport

설치가 완료된 후 다음 명령을 실행하여 필요한 Passport 키를 생성합니다.

php artisan passport:keys

다음으로 다음 명령을 실행하여 Passport의 데이터베이스 마이그레이션을 생성합니다.

php artisan migrate

II. APP 측 로그인 기능 구현

  1. 사용자 모델 및 컨트롤러 생성

먼저 애플리케이션이 사용자를 관리할 수 있도록 사용자 모델을 생성해야 합니다. 다음 명령을 실행하여 User라는 모델을 만듭니다.

php artisan make:model User

다음으로 AuthController라는 컨트롤러를 만들고 여기에 다음 코드를 추가합니다.

<?php

namespace AppHttpControllers;

use AppModelsUser;
use IlluminateHttpRequest;
use IlluminateSupportFacadesAuth;
use Validator;

class AuthController extends Controller
{
    public function register(Request $request)
    {
        $validator = Validator::make($request->all(), [
            'name' => 'required',
            'email' => 'required|email|unique:users',
            'password' => 'required',
        ]);

        if ($validator->fails()) {
            return response()->json(['error' => $validator->errors()], 401);
        }

        $user = new User;
        $user->name = $request->name;
        $user->email = $request->email;
        $user->password = bcrypt($request->password);
        $user->save();

        $token = $user->createToken('MyApp')->accessToken;

        return response()->json(['token' => $token], 200);
    }

    public function login(Request $request)
    {
        $validator = Validator::make($request->all(), [
            'email' => 'required|email',
            'password' => 'required',
        ]);

        if ($validator->fails()) {
            return response()->json(['error' => $validator->errors()], 401);
        }

        $credentials = $request->only('email', 'password');

        if (Auth::attempt($credentials)) {
            $user = Auth::user();
            $token = $user->createToken('MyApp')->accessToken;
            return response()->json(['token' => $token], 200);
        } else {
            return response()->json(['error' => 'Unauthorized'], 401);
        }
    }
}

위 코드에서 등록 메소드를 사용하면 사용자가 등록하고 로그인할 수 있습니다. 로그인할 사용자입니다. 사용자가 성공적으로 등록하거나 로그인하면 액세스 토큰이 반환되어 후속 사용자 요청에 사용됩니다.

  1. API 경로 생성

다음으로 사용자 로그인 및 등록 요청을 처리하기 위해 해당 API 경로를 생성해야 합니다. 경로/api.php 파일에 다음 코드를 추가합니다.

<?php

use IlluminateHttpRequest;
use IlluminateSupportFacadesRoute;
use AppHttpControllersAuthController;

Route::post('/register', [AuthController::class, 'register']);
Route::post('/login', [AuthController::class, 'login']);

위 코드는 등록 및 로그인 요청을 AuthController 컨트롤러의 해당 메서드에 매핑합니다.

3. 로그인 기능 테스트

이제 모든 코드가 준비되었으므로 다음 URL에 접속하여 로그인 및 등록 기능을 테스트할 수 있습니다.

  • POST /api/register

    • 새 사용자를 등록하세요. 매개변수: 이름, 이메일, 비밀번호.
  • POST /api/login

    • 사용자 로그인용. 매개변수: 이메일, 비밀번호.

사용자가 성공적으로 로그인하면 토큰이 반환됩니다. 이 토큰은 사용자를 인증하기 위한 후속 API 요청을 만드는 데 사용될 수 있습니다.

$token = 'Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6ImZlYTcwMDU3NzhlZWUyMTU3MzliNTM3ODQyNTI0NWJiMGM5YjA3ZWIyMWNlMDhhMDM5ODUyYjczMzVjNWE1NjJlN2UwMGU4ZTQ5MjhhNzg1In0.eyJhdWQiOiIxMSIsImp0aSI6ImZlYTcwMDU3NzhlZWUyMTU3MzliNTM3ODQyNTI0NWJiMGM5YjA3ZWIyMWNlMDhhMDM5ODUyYjczMzVjNWE1NjJlN2UwMGU4ZTQ5MjhhNzg1IiwiaWF0IjoxNjMwMzkwNTM3LCJuYmYiOjE2MzAzOTA1MzcsImV4cCI6MTYzMDM5NDAzNywiZGF0YSI6eyJ1c2VyIjp7ImlkIjoiMSJ9fX0.XsIFsVCc3N1oZ70vzWn4wHQSv3Q-JVdlfu4LJkUPL0he_53bpgJrq5jw8mHygB-1-kpq62N7eG_r08fXKkmbiqeITmUiaGKa0prKzXCoexuYKuxYqG8j-HY2UyDp5g_TE6M4eW5FrcDpTJ0WcQ5ShDhdszUFQUH_qR52ypeEUmsF6CFwx1YJt4AmCFEy2CjsKOMl9K9o0mV_ytvBZ9drY6w6HTRfYfU7q5yuM-W3Qp6bbS-ljzY_2M0RWzwZJm6QvO3Byjhw1TNUrPHFs6xGlY4M7zgkDZxas5srQgpFjKof2LztN7QAJaiT_d6XAKpS24JA2-v2U7x3g';
$response = $this->withHeaders([
    'Authorization' => $token,
])->json('GET', '/api/user');

이 예에서는 토큰을 사용하여 /api/user에 GET 요청을 보내면 사용자 정보가 반환됩니다. 로그인에 실패하면 API는 401 오류 코드를 반환합니다. 로그인에 성공하면 사용자 정보가 반환됩니다.

Laravel의 Passport 확장 패키지를 사용하여 APP 측에서 로그인 기능을 구현하는 것은 매우 쉽습니다. 해당 확장 패키지를 설치하고 구성하기만 하면 됩니다. 이 기사에서는 Laravel을 사용하여 완전한 앱 측 로그인 기능을 완성하고 사용자를 위한 빠른 로그인 및 보안 보호를 달성하는 방법을 보여줍니다.

위 내용은 laravel은 앱 측 로그인을 구현합니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.