"회원관리 3-1. 회원정보 수정"의 두 판 사이의 차이

Pywiki
둘러보기로 가기 검색하러 가기
 
49번째 줄: 49번째 줄:
 
</syntaxhighlight>
 
</syntaxhighlight>
 
=커스텀 폼을 사용하는 경우=
 
=커스텀 폼을 사용하는 경우=
 +
사실, 유저객체를 얻고 비밀번호만 바꿀거라면 다음의 코드로 간단하게 변경된다.
 +
 +
<code>user.set_password(password)</code>
 +
 +
그래도 폼을 사용해 보겠다면 아래와 같이 사용이 가능하겠다.
 +
 
===Form 추가===
 
===Form 추가===
 
장고에서 제공하는 UserChangeForm을 상속할 필요는 없다. 기본 폼이 난 맘에 안들어.<syntaxhighlight lang="python3">
 
장고에서 제공하는 UserChangeForm을 상속할 필요는 없다. 기본 폼이 난 맘에 안들어.<syntaxhighlight lang="python3">

2022년 12월 15일 (목) 09:45 기준 최신판

1 유저 정보 수정[편집 | 원본 편집]

1.1 url만들기[편집 | 원본 편집]

다음 url 추가.

path('update/', views.update, name='update'),

2 장고 제공 폼 사용[편집 | 원본 편집]

가장 간편한 방법이다.

2.1 form 추가[편집 | 원본 편집]

from django.contrib.auth.forms import UserChangeForm  # 제공하는 폼이 있다.
from django.contrib.auth import get_user_model  # 장고에 커스텀으로 등록한 모델을 불러온다.

class User_update_form(UserChangeForm):
    class Meta:
        model = get_user_model()  #  설정된 커스텀모델
        fields = ["nickname", "email"]  # password1,2 필드는 자동추가된다.

2.2 view 추가[편집 | 원본 편집]

from .forms import UserUpdateForm
def update(request):
    if request.method == "POST":
        form = UserUpdateForm(request.POST, instance=request.user)  # 이게 없으면 수정할 때마다 새로운 계정을 만든다.
        if form.is_valid():
            form.save()  # 폼값을 불러오고 저장
            return redirect('membership:profile')
    else:
        form = UserUpdateForm(instance=request.user)
    return render(request, 'user_update.html', {'form': form})

2.3 template 추가[편집 | 원본 편집]

회원정보 수정에서 쓰이는 탬플릿은 회원가입에서도 쓰일 수 있으니... 따로 만들어두어 양쪽에서 함께 사용할 수 있게 배치하면 좋겠다.

from .forms import UserUpdateForm
def update(request):
    if request.method == "POST":
        form = UserUpdateForm(request.POST, instance=request.user)  # 이게 없으면 수정할 때마다 새로운 계정을 만든다.
        if form.is_valid():
            print(request.POST['nickname'])
            print(request.POST['email'])
            form.save()  # 폼값을 불러오고 저장
            return redirect('membership:profile')
    else:
        form = UserUpdateForm(instance=request.user)
    return render(request, 'user_update.html', {'form': form})

3 커스텀 폼을 사용하는 경우[편집 | 원본 편집]

사실, 유저객체를 얻고 비밀번호만 바꿀거라면 다음의 코드로 간단하게 변경된다.

user.set_password(password)

그래도 폼을 사용해 보겠다면 아래와 같이 사용이 가능하겠다.

3.1 Form 추가[편집 | 원본 편집]

장고에서 제공하는 UserChangeForm을 상속할 필요는 없다. 기본 폼이 난 맘에 안들어.

class UserUpdateForm(forms.ModelForm):
    class Meta:
        model = get_user_model()
        fields = ['username', 'email', 'nickname']

3.2 비밀번호 수정, 비밀번호 바꾸기[편집 | 원본 편집]

커스텀 폼의 경우 패스워드에 대해 따로 처리해주어야 한다.

3.3 url 추가[편집 | 원본 편집]

path('password/', views.password, name='password'),

3.4 view 추가[편집 | 원본 편집]

폼을 건들 필요 없이, 뷰에서 바로 제공하는 폼을 사용하면 된다.(키 이름은 password1, 2 이니, 탬플릿에선 적당히 고쳐 사용할 것.)

from django.contrib.auth.forms import PasswordChangeForm
from django.contrib.auth import update_session_auth_hash

@login_required
def password(request):
    if request.method == 'POST':
        form = PasswordChangeForm(user=request.user, data=request.POST)
        if form.is_valid():
            user = form.save()
            # 비밀번호를 바꾸면 기존 세션과 일치하지 않게 되어 로그아웃된다. 이를 방지하기 위한 auth_hash 갱신.
            update_session_auth_hash(request, user)  
            return redirect('membership:profile')
    
    else:
        form = PasswordChangeForm(request.user)
    return render(request, 'user_update_password.html',{'form':form})