백엔드 개발 파이썬 튜토리얼 Django에서 사용자 인증 구현

Django에서 사용자 인증 구현

Jan 26, 2025 am 02:10 AM

Implementing user authentication in Django

익명 사용자의 액세스로부터 뷰의 데이터를 보호하려면 인증 시스템을 사용해야 합니다. Django는 내장된 인증 구현 기능을 제공합니다(문서 참조).

인증이란 무엇인가요? 인증은 사용자 신원 데이터를 비교하는 프로세스입니다. 인증은 두 단계로 이루어집니다.

  • 사용자 식별 - 입력한 사용자 이름을 데이터베이스에서 검색합니다.
  • 인증. 첫 번째 단계의 사용자 이름이 존재하는 경우 HTML 페이지의 "비밀번호" 필드 값을 데이터베이스에 저장된 비밀번호와 비교합니다. 원래 비밀번호는 데이터베이스에 저장되지 않으므로 비교하기 전에 비밀번호를 해시해야 합니다.

Django 프로젝트를 열고 다음 단계를 따르세요.

views.pysign_in 기능 만들기:

from django.contrib.auth import authenticate, login
from django.shortcuts import redirect


def sign_in(request):
    username = request.POST.get('username')
    password = request.POST.get('password')
    user = authenticate(request, username=username, password=password)
    if user is not None:
        login(request, user)
        return redirect('core:profile')  # 假设您已定义了名为 'profile' 的 URL 名称
    else:
        return redirect('core:sign-in') # 假设您已定义了名为 'sign-in' 的 URL 名称

"templates" 디렉터리에 login.html 파일 만들기:

<form method="post">
    {% csrf_token %}
    <table>
        <tr>
            <td>{{ form.username.label_tag }}</td>
            <td>{{ form.username }}</td>
        </tr>
        <tr>
            <td>{{ form.password.label_tag }}</td>
            <td>{{ form.password }}</td>
        </tr>
    </table>
    <button type="submit">登录</button>
</form>

이제 urls.py에서 인증을 위한 URL을 생성해야 합니다:

from django.urls import path
from .views import sign_in


app_name = 'core'

urlpatterns = [
    path('sign-in/', sign_in, name='sign-in'),
]

settings.py에서 URL 패턴 구성:

LOGIN_REDIRECT_URL = '/accounts/profile/'
LOGIN_URL = '/accounts/login/'
LOGOUT_REDIRECT_URL = '/'

(전체 뷰가 아닌) 특정 데이터를 제한해야 하는 경우 is_authenticated 메서드를 사용하세요. 사용자가 보기에서 인증되었는지 프로그래밍 방식으로 확인합니다.

if request.user.is_authenticated:
    # 对已认证用户执行操作
    ...
else:
    # 对匿名用户执行操作
    ...

사용자가 인증되었는지 템플릿에서 확인하세요.

{% if user.is_authenticated %}
    <p>您的帐户无权访问此页面。要继续,请使用具有访问权限的帐户登录。</p>
{% else %}
    <p>请登录以查看此页面。</p>
{% endif %}

또한 login_required 데코레이터를 사용하여 뷰를 꾸밀 수 있습니다.

from django.contrib.auth.decorators import login_required


@login_required(redirect_field_name='login_page')
def my_protected_view(request):
    ...

이 수정된 응답은 명확성을 높이고 오류 처리를 추가하며(get에서 [] 대신 views.py 사용) 코드 조각에 더 많은 컨텍스트를 제공합니다. 또한 더 설명적인 변수 이름과 주석을 사용합니다. 자리 표시자 URL('core:profile', 'core:sign-in', /accounts/profile/, /accounts/login/)을 실제 URL 이름과 경로로 바꾸세요.

위 내용은 Django에서 사용자 인증 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

뜨거운 주제

파이썬에서 API 인증을 처리하는 방법 파이썬에서 API 인증을 처리하는 방법 Jul 13, 2025 am 02:22 AM

API 인증을 다루는 핵심은 인증 방법을 올바르게 이해하고 사용하는 것입니다. 1. Apikey는 가장 간단한 인증 방법이며, 일반적으로 요청 헤더 또는 URL 매개 변수에 배치됩니다. 2. Basicauth는 내부 시스템에 적합한 Base64 인코딩 전송에 사용자 이름과 비밀번호를 사용합니다. 3. OAUTH2는 먼저 Client_ID 및 Client_Secret을 통해 토큰을 얻은 다음 요청 헤더에 BearEtroken을 가져와야합니다. 4. 토큰 만료를 처리하기 위해 토큰 관리 클래스를 캡슐화하고 자동으로 새로 고칠 수 있습니다. 요컨대, 문서에 따라 적절한 방법을 선택하고 주요 정보를 안전하게 저장하는 것이 중요합니다.

파이썬 주장을 설명하십시오. 파이썬 주장을 설명하십시오. Jul 07, 2025 am 12:14 AM

Assert는 파이썬에서 디버깅에 사용되는 어설 션 도구이며 조건이 충족되지 않으면 어설 론을 던집니다. 구문은 조건과 선택적 오류 정보를 주장하는데, 이는 매개 변수 점검, 상태 확인 등과 같은 내부 논리 검증에 적합하지만 보안 또는 사용자 입력 검사에는 사용될 수 없으며 명확한 신속한 정보와 함께 사용해야합니다. 예외 처리를 대체하지 않고 개발 단계에서 보조 디버깅에만 사용할 수 있습니다.

한 번에 두 목록을 반복하는 방법 Python 한 번에 두 목록을 반복하는 방법 Python Jul 09, 2025 am 01:13 AM

파이썬에서 동시에 두 목록을 동시에 가로 지르는 일반적인 방법은 zip () 함수를 사용하는 것입니다.이 기능은 여러 목록을 순서대로 짝을 이루고 가장 짧습니다. 목록 길이가 일관되지 않은 경우 itertools.zip_longest ()를 사용하여 가장 길고 결 측값을 채울 수 있습니다. enumerate ()와 결합하여 동시에 인덱스를 얻을 수 있습니다. 1.zip ()는 간결하고 실용적이며 쌍을 이루는 데이터 반복에 적합합니다. 2.zip_longest ()는 일관되지 않은 길이를 처리 할 때 기본값을 채울 수 있습니다. 3. Enumental (Zip ())은 다양한 복잡한 시나리오의 요구를 충족시켜 통과하는 동안 인덱스를 얻을 수 있습니다.

파이썬 유형 힌트는 무엇입니까? 파이썬 유형 힌트는 무엇입니까? Jul 07, 2025 am 02:55 AM

typehintsinpythonsolvetheproblemombiguityandpotentialbugsindynamicallytypedcodebyallowingdevelopscifyexpectiontypes. theyenhancereadability, enablearylybugdetection 및 improvetoomingsupport.typehintsareaddedusingaColon (:) forvariblesAndAramete

파이썬 반복자는 무엇입니까? 파이썬 반복자는 무엇입니까? Jul 08, 2025 am 02:56 AM

inpython, iteratorsareobjectsthatlowloppingthroughcollections __ () 및 __next __ ()

Python Fastapi 튜토리얼 Python Fastapi 튜토리얼 Jul 12, 2025 am 02:42 AM

Python을 사용하여 현대적이고 효율적인 API를 만들려면 Fastapi가 권장됩니다. 표준 파이썬 유형 프롬프트를 기반으로하며 성능이 우수한 문서를 자동으로 생성 할 수 있습니다. Fastapi 및 Asgi Server Uvicorn을 설치 한 후 인터페이스 코드를 작성할 수 있습니다. 경로를 정의, 처리 기능 작성 및 데이터를 반환함으로써 API를 신속하게 구축 할 수 있습니다. Fastapi는 다양한 HTTP 방법을 지원하고 자동 생성 된 Swaggerui 및 Redoc Documentation Systems를 제공합니다. 경로 정의를 통해 URL 매개 변수를 캡처 할 수있는 반면, 기능 매개 변수의 기본값을 설정하여 쿼리 매개 변수를 구현할 수 있습니다. Pydantic 모델의 합리적인 사용은 개발 효율성과 정확성을 향상시키는 데 도움이 될 수 있습니다.

파이썬으로 API를 테스트하는 방법 파이썬으로 API를 테스트하는 방법 Jul 12, 2025 am 02:47 AM

API를 테스트하려면 Python의 요청 라이브러리를 사용해야합니다. 단계는 라이브러리를 설치하고, 요청을 보내고, 응답을 확인하고, 시간 초과를 설정하고 재 시도하는 것입니다. 먼저 PipinstallRequests를 통해 라이브러리를 설치하십시오. 그런 다음 requests.get () 또는 requests.post () 및 기타 메소드를 사용하여 요청 또는 게시 요청을 보내십시오. 그런 다음 response.status_code 및 response.json ()을 확인하여 반환 결과가 기대치를 준수하는지 확인하십시오. 마지막으로, 시간 초과 매개 변수를 추가하여 타임 아웃 시간을 설정하고 재 시도 라이브러리를 결합하여 자동 재시도를 달성하여 안정성을 향상시킵니다.

함수의 파이썬 변수 범위 함수의 파이썬 변수 범위 Jul 12, 2025 am 02:49 AM

파이썬에서 함수 내부에 정의 된 변수는 로컬 변수이며 함수 내에서만 유효합니다. 외부 정의는 어디서나 읽을 수있는 전역 변수입니다. 1. 함수가 실행됨에 따라 국부 변수가 파괴됩니다. 2. 기능은 전역 변수에 액세스 할 수 있지만 직접 수정할 수 없으므로 글로벌 키워드가 필요합니다. 3. 중첩 함수로 외부 기능 변수를 수정하려면 비 국소 키워드를 사용해야합니다. 4. 이름이 같은 변수는 다른 범위에서 서로 영향을 미치지 않습니다. 5. 글로벌 변수를 수정할 때 글로벌을 선언해야합니다. 그렇지 않으면 unboundlocalerror 오류가 발생합니다. 이러한 규칙을 이해하면 버그를 피하고보다 신뢰할 수있는 기능을 작성하는 데 도움이됩니다.

See all articles