>PHP 프레임워크 >Laravel >laravel_admin 등록 기능 구현 방법

laravel_admin 등록 기능 구현 방법

PHPz
PHPz원래의
2023-04-12 09:12:40669검색

Laravel_admin은 프런트엔드와 백엔드를 분리하는 백엔드 관리 시스템입니다. Laravel_admin에서 등록 기능을 구현하려면 프런트엔드 페이지 디자인과 백엔드 로직 작성의 두 가지 측면이 필요합니다. 이 기사에서는 이 두 가지 측면의 구현 프로세스를 각각 소개합니다.

1. 프론트엔드 인터페이스 구현

Laravel_admin에서 등록 기능을 구현하려면 사용자가 관련 정보를 입력하고 제출할 수 있는 프론트엔드 페이지를 디자인해야 합니다. 먼저 등록 페이지의 HTML 코드를 배치하기 위해 뷰 레이어에 Register.blade.php 파일을 생성합니다. 코드는 다음과 같습니다.

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>Register page</title>
</head>
<body>
    <form method="post" action="{{ route(&#39;register&#39;) }}">
        {{ csrf_field() }}
        <label for="name">Username:</label>
        <input type="text" name="name" id="name"><br>
        <label for="email">Email:</label>
        <input type="email" name="email" id="email"><br>
        <label for="password">Password:</label>
        <input type="password" name="password" id="password"><br>
        <label for="password_confirmation">Confirm Password:</label>
        <input type="password" name="password_confirmation" id="password_confirmation"><br>
        <button type="submit">Submit</button>
    </form>
</body>

위 코드는 기본 등록 양식입니다. 폼에는 사용자 이름, 이메일, 비밀번호, 비밀번호 확인 등의 필드가 제공되며, Laravel_admin에서 제공하는 라우팅 기능을 통해 폼이 제출되는 경로를 지정합니다. 동시에 데이터 보안을 보장하기 위해 Laravel_admin에서 제공하는 csrf_field 함수를 양식에 사용하여 숨겨진 _token 양식 필드를 생성합니다.

2. 백엔드 로직 작성

프론트 페이지 디자인이 완료되면 컨트롤러 작성이 포함된 백엔드 로직 프로그램을 작성해야 합니다. Laravel_admin에서 컨트롤러 클래스는 일반적으로 app/Http/Controllers 디렉터리에 저장됩니다.

컨트롤러 파일에서는 showRegistrationForm과 Register라는 두 가지 메소드를 구현해야 합니다.

  1. showRegistrationForm 메소드

이 메소드는 등록 양식 페이지를 렌더링하는 데 사용되며 코드는 다음과 같습니다.

public function showRegistrationForm()
{
    return view('auth.register');
}

이 메소드는 단순히 템플릿 이름이 auth.register인 보기 템플릿을 반환합니다. 이 템플릿 이름에 해당하는 뷰 템플릿은 앞서 정의한 Register.blade.php 파일입니다.

  1. 등록 방법

이 방법은 양식을 통해 제출된 데이터를 처리하고 해당 데이터를 데이터베이스에 저장하는 데 사용됩니다. 코드는 다음과 같습니다:

public function register(Request $request)
{
    $validator = Validator::make($request->all(), [
        'name' => 'required|string|max:255|unique:users',
        'email' => 'required|string|email|max:255|unique:users',
        'password' => 'required|string|min:6|confirmed',
    ]);

    if ($validator->fails()) {
        return redirect('register')
                    ->withErrors($validator)
                    ->withInput();
    }

    $this->create($request->all());

    return redirect('login');
}

protected function create(array $data)
{
    return User::create([
        'name' => $data['name'],
        'email' => $data['email'],
        'password' => bcrypt($data['password']),
    ]);
}

이 방법에서는 먼저 Laravel_admin에 내장된 유효성 검사기를 사용하여 제출된 데이터를 확인하여 중복된 사용자 이름이나 이메일이 없는지 확인하세요. 확인에 실패하면 사용자가 제출한 오류 메시지와 양식 데이터(withInput())가 프런트엔드 페이지로 반환되어 사용자에게 오류 메시지를 표시하고 사용자 수정을 용이하게 하기 위해 양식 데이터를 다시 채웁니다.

인증에 성공하면 create 메소드가 호출되어 사용자 정보를 데이터베이스에 저장합니다. create 메소드에서 laravel의 내장 User 모델 클래스의 create 메소드를 호출하여 사용자 이름, 이메일, 비밀번호와 같은 필드를 데이터베이스에 저장합니다. 데이터 보안을 보장하려면 비밀번호를 bcrypt 방식으로 암호화해야 합니다.

마지막으로 논리 처리가 완료된 후 사용자를 로그인 페이지로 리디렉션하여 등록 프로세스가 완료되었는지 확인하세요.

3. 라우팅 설정

위의 구현 프로세스 외에도 등록 페이지 및 등록 양식 제출 처리에 해당하는 라우팅 파일에 두 개의 경로도 추가해야 합니다. Routes/web.php에 다음 코드를 추가하세요:

Route::get('register', 'Auth\RegisterController@showRegistrationForm')->name('register');
Route::post('register', 'Auth\RegisterController@register');

위 코드는 showRegistrationForm과 Register라는 두 가지 메소드에 해당합니다. 그 중 get 메소드는 등록 페이지에 대한 요청을 처리하고, post 메소드는 등록 양식에서 제출된 요청을 처리합니다.

이제 Laravel_admin에서 등록 기능 구현이 완료되었습니다. 프로세스 전반에 걸쳐 주의가 필요한 문제는 다음과 같습니다. 프런트엔드 페이지에 csrf_field 양식 필드가 있어야 하며, 양식으로 제출된 데이터를 등록 방법에서 확인하고 해당 정보를 표시해야 하며, 사용자 비밀번호를 암호화해야 합니다. 생성 방법 등 이러한 세부 사항을 올바르게 처리해야만 등록 프로세스의 안정성과 건전한 운영이 보장될 수 있습니다.

위 내용은 laravel_admin 등록 기능 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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