Django의 Google 인증 가장 간단한 방법
12792 단어 djangoallauthgoogleauthdjango
1. django 프로젝트 설정
django-admin startproject GoogleAuthentication
여기서 우리는 GoogleAuthentication이라는 django 프로젝트를 만들고 있습니다. 프로젝트 이름은 문자 그대로 무엇이든 될 수 있습니다.
2. django-allauth 패키지 설치
이제 Google 인증을 웹 애플리케이션에 추가하는 데 필요한 필수 패키지를 설치하겠습니다.
pip install django-allauth
3. settings.py에 인증 백엔드 추가
settings.py에서 AUTHENTICATION_BACKENDS 속성을 지정해야 합니다.
# settings.py
# all the below property in your settings.py file for django allauth to work
AUTHENTICATION_BACKENDS = [
# django's inbuild authentication backend
'django.contrib.auth.backends.ModelBackend',
# django's allauth authentication backend
'allauth.account.auth_backends.AuthenticationBackend',
]
4. settings.py에 필요한 앱 추가
다음 앱을 settings.py에 추가해야 합니다. django.contrib.sites가 없는 경우 INSTALLED_APPS에 추가해야 합니다.
# settings.py
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.sites', # <-- add the sites app here
# apps needed for django all auth
'allauth',
'allauth.account',
'allauth.socialaccount',
# add the below app for google authentication to work
'allauth.socialaccount.providers.google',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]
5. 기본 urls.py에 allauth URL 추가
아래 코드 스니펫을 사용하여 django의 allauth URL을 프로젝트에 포함합니다.
# main urls.py file
from django.contrib import admin
from django.urls import path, include
urlpatterns = [
path('admin/', admin.site.urls),
path('accounts/', include('allauth.urls')), # <- include the allauth urls here
]
6. 마이그레이션 실행
마이그레이션을 실행하려면 아래 두 명령을 사용하십시오.
python manage.py makemigrations
python manage.py migrate
7. 수퍼유저 생성
수퍼 유저를 생성하려면 다음 명령을 사용하십시오.
python manage.py createsuperuser
산출
Username (leave blank to use 'rohit'): admin
Email address: admin@admin.com
Password:
Password (again):
Superuser created successfully.
8. Google 클라이언트 ID 및 비밀번호 생성
이제 다음 링크를 방문하여 Google 개발자 대시보드를 방문하십시오. google api console
이제 검색창에서 Gmail을 검색하고 Market Place에서 Gmail API를 선택합니다.
data:image/s3,"s3://crabby-images/5f4b7/5f4b79ddf6774c3406688a0932742942faf22c3a" alt=""
이제 활성화 버튼을 클릭하면 Gmail API가 활성화됩니다.
data:image/s3,"s3://crabby-images/c0ed4/c0ed46c7fa35bedf64cf6dd49a169eaf12f9aab0" alt=""
이제 credentials 페이지를 방문하여 "+ CREATE CREDENTIALS "버튼을 클릭하고 "OAuth 클라이언트 ID"를 클릭하십시오.
data:image/s3,"s3://crabby-images/570ca/570caeb087a94af08a84be159735a2f839bd3a27" alt=""
이제 아래와 같이 응용 프로그램 유형을 웹으로 선택하십시오.
data:image/s3,"s3://crabby-images/5895d/5895d9dd822e04369eb75cba0fd0e2ef4e467d59" alt=""
이제 애플리케이션의 이름을 원하는 대로 지정합니다. Django Google Auth로 이름을 지정하고 있지만 명심해야 할 주요 사항은 리디렉션 URL과 자바스크립트 출처입니다.
# add the following to redirect urls
http://127.0.0.1:8000/accounts/google/login/callback/
http://localhost:8000/accounts/google/login/callback/
# add the following to javascript origins
http://127.0.0.1:8000
http://localhost:8000
위의 URL을 추가한 후 만들기 버튼을 클릭합니다.
data:image/s3,"s3://crabby-images/b0178/b01783452767439a12be94b7cbe8665a906d57a6" alt=""
화면에 나타나는 클라이언트 ID와 시크릿을 복사합니다.
9. 클라이언트 ID 및 암호 구성
settings.py에서 다음 코드 줄을 추가합니다.
# settings.py
SITE_ID = 1
이제 django 관리 페이지에 로그인하고 example.com 사이트를 localhost로 편집합니다.
data:image/s3,"s3://crabby-images/15a1f/15a1fe0eb7f1ef824cb1f8be0d4412c9487695dc" alt=""
이제 소셜 애플리케이션으로 이동하여 거기에 Google 클라이언트 ID와 비밀을 추가하십시오.
data:image/s3,"s3://crabby-images/80c5c/80c5cb443dd5a09d7e0a0cbc11d6f096e1a42ec0" alt=""
위에서 클라이언트 ID와 비밀을 추가한 방법을 볼 수 있으며 선택한 사이트에 localhost를 추가하는 것을 잊지 마십시오.
방문시 : http://127.0.0.1:8000/accounts/login/
Google로 로그인할 수 있는 링크를 볼 수 있습니다. 이제 링크를 클릭하면 Google을 사용하여 로그인할 수 있습니다.
로그인 페이지
data:image/s3,"s3://crabby-images/0a232/0a232e19f86d55b8b98bec83534fe12b5c75718a" alt=""
구글 인증
data:image/s3,"s3://crabby-images/fe9da/fe9da9eaea91d98bf8e2f089387c0ff0cb2c7218" alt=""
아래 코드 조각을 사용하여 사용자 지정 로그인 페이지를 만들 수 있습니다.
<html>
<head>
<!--Dont forget to replace with client id below-->
<meta name="google-signin-client_id" content="YOUR_CLIENT_ID.apps.googleusercontent.com">
</head>
<body>
<div id="my-signin2"></div>
<script>
function onSuccess(googleUser) {
console.log('Logged in as: ' + googleUser.getBasicProfile().getName());
}
function onFailure(error) {
console.log(error);
}
function renderButton() {
gapi.signin2.render('my-signin2', {
'scope': 'profile email',
'width': 240,
'height': 50,
'longtitle': true,
'theme': 'dark',
'onsuccess': onSuccess,
'onfailure': onFailure
});
}
</script>
<script src="https://apis.google.com/js/platform.js?onload=renderButton" async defer></script>
</body>
</html>
Reference
이 문제에 관하여(Django의 Google 인증 가장 간단한 방법), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/rohit20001221/google-authentication-in-django-the-simplest-way-3982텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)