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})