您好,登錄后才能下訂單哦!
django-allauth是集成的Django應(yīng)用程序,用于解決網(wǎng)站身份驗(yàn)證,用戶的注冊登錄及賬戶管理,以及第三方(社交)賬戶的身份驗(yàn)證。
既然你知道并準(zhǔn)備使用django-allauth,所以本文假定你已經(jīng)掌握了基本的django知識(比如會用django搭建Web App,甚至是一個小型博客網(wǎng)站)。
安裝與基本配置
安裝
pip install django-allauth
基本配置
1.在你項目的settings.py里 加上 以下相對應(yīng)的代碼
TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [], 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.request', ], }, }, ] AUTHENTICATION_BACKENDS = ( 'django.contrib.auth.backends.ModelBackend', 'allauth.account.auth_backends.AuthenticationBackend', ) INSTALLED_APPS = ( # 這兩個django本身的app也是需要的,但不需要重復(fù)添加 'django.contrib.auth', 'django.contrib.sites', 'allauth', 'allauth.account', 'allauth.socialaccount', # 下面是django-allauth目前支持的社交賬號,加上你需要的就行了,不用全加上: 'allauth.socialaccount.providers.amazon', # 亞馬遜 'allauth.socialaccount.providers.angellist', 'allauth.socialaccount.providers.asana', 'allauth.socialaccount.providers.auth0', 'allauth.socialaccount.providers.authentiq', 'allauth.socialaccount.providers.baidu', # 百度 'allauth.socialaccount.providers.basecamp', 'allauth.socialaccount.providers.bitbucket', 'allauth.socialaccount.providers.bitbucket_oauth3', 'allauth.socialaccount.providers.bitly', 'allauth.socialaccount.providers.coinbase', 'allauth.socialaccount.providers.dataporten', 'allauth.socialaccount.providers.daum', 'allauth.socialaccount.providers.digitalocean', 'allauth.socialaccount.providers.discord', 'allauth.socialaccount.providers.douban', # 豆瓣 'allauth.socialaccount.providers.draugiem', 'allauth.socialaccount.providers.dropbox', 'allauth.socialaccount.providers.dwolla', 'allauth.socialaccount.providers.edmodo', 'allauth.socialaccount.providers.eveonline', 'allauth.socialaccount.providers.evernote', 'allauth.socialaccount.providers.facebook', 'allauth.socialaccount.providers.feedly', 'allauth.socialaccount.providers.fivehundredpx', 'allauth.socialaccount.providers.flickr', 'allauth.socialaccount.providers.foursquare', 'allauth.socialaccount.providers.fxa', 'allauth.socialaccount.providers.github', # GitHub 'allauth.socialaccount.providers.gitlab', 'allauth.socialaccount.providers.google', 'allauth.socialaccount.providers.hubic', 'allauth.socialaccount.providers.instagram', 'allauth.socialaccount.providers.kakao', 'allauth.socialaccount.providers.line', 'allauth.socialaccount.providers.linkedin', 'allauth.socialaccount.providers.linkedin_oauth3', 'allauth.socialaccount.providers.mailru', 'allauth.socialaccount.providers.mailchimp', 'allauth.socialaccount.providers.meetup', 'allauth.socialaccount.providers.naver', 'allauth.socialaccount.providers.odnoklassniki', 'allauth.socialaccount.providers.openid', 'allauth.socialaccount.providers.orcid', 'allauth.socialaccount.providers.paypal', 'allauth.socialaccount.providers.persona', 'allauth.socialaccount.providers.pinterest', 'allauth.socialaccount.providers.reddit', 'allauth.socialaccount.providers.robinhood', 'allauth.socialaccount.providers.shopify', 'allauth.socialaccount.providers.slack', 'allauth.socialaccount.providers.soundcloud', 'allauth.socialaccount.providers.spotify', 'allauth.socialaccount.providers.stackexchange', 'allauth.socialaccount.providers.stripe', 'allauth.socialaccount.providers.trello', 'allauth.socialaccount.providers.tumblr', 'allauth.socialaccount.providers.twentythreeandme', 'allauth.socialaccount.providers.twitch', 'allauth.socialaccount.providers.twitter', 'allauth.socialaccount.providers.untappd', 'allauth.socialaccount.providers.vimeo', 'allauth.socialaccount.providers.vk', 'allauth.socialaccount.providers.weibo', # 新浪微博 'allauth.socialaccount.providers.weixin', # 微信 'allauth.socialaccount.providers.windowslive', 'allauth.socialaccount.providers.xing', ) SITE_ID = 1 # 不要漏了這句哦
2.在項目的urls.py(即與setting.py在同一文件夾的urls.py)里 加上 下面這句:
urlpatterns = [ url(r'^accounts/', include('allauth.urls')), ]
溫馨提示:
如果你了解或者用過 django.contrib.auth.urls 這個模塊的話,那么用了django-allauth后你就可以用由 allauth 提供的 account_login , account_logout , account_set_password ......這些URLs來替代原先的 login , logout , password_change ......
3.在項目的根目錄(即manage.py所在文件夾)里執(zhí)行以下命令:
python manage.py migrate
4.重啟服務(wù)器。
添加社交賬號登錄
后臺設(shè)置
注意:因?yàn)樽鼍W(wǎng)站一般有兩種環(huán)境:開發(fā)環(huán)境(即網(wǎng)站在本地主機(jī)上開發(fā))和生產(chǎn)環(huán)境(即網(wǎng)站部署在服務(wù)器),而開發(fā)環(huán)境網(wǎng)站主頁一般為: http://127.0.0.1:8000 ,生產(chǎn)環(huán)境則類似為 http://www.honkerzhou.com ,為簡單描述,所以下文我會直接用 你的域名 代替你的網(wǎng)站主頁地址,故請分清自己的網(wǎng)站主頁地址,以免混淆。
獲取第三方應(yīng)用的Client id和Secret key
1.GitHub
登錄GitHub后 --> 進(jìn)入Settings --> 進(jìn)入Developer settings --> 在OAuth Apps下進(jìn)入New OAuth App --> 然后按步驟填寫信息 --> 進(jìn)入下一步后就可以看到Client id和Secret key了。
注意:
驗(yàn)證和初步使用
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。