Django項(xiàng)目中實(shí)現(xiàn)使用qq第三方登錄功能
使用qq登錄的前提是已經(jīng)在qq互聯(lián)官網(wǎng)創(chuàng)建網(wǎng)站應(yīng)用并獲取到QQ互聯(lián)中網(wǎng)站應(yīng)用的APP ID和APP KEY
1,建路由
# qq登錄 path('loginQq/',qq.loginQq,name='loginQq/'), path('returns/',qq.returns,name='returns/'),
2,前端頁面寫qq登錄的鏈接,本文沒有用圖標(biāo),暫時使用a鏈接請求。
<a data-wow-delay=".5s" href="/blog/loginQq/" rel="external nofollow" > » QQ登錄</a>
3,在項(xiàng)目的應(yīng)用下創(chuàng)建utils文件夾并創(chuàng)建function.py用于封裝函數(shù),封裝的函數(shù)用于從返回?cái)?shù)據(jù)中提取openid(騰訊公司數(shù)據(jù)庫里面的用戶id)
封裝的函數(shù)內(nèi)容如下;
import re def parse_jsonp(jsonp_str): try: return re.search('^[^(]*?\((.*)\)[^)]*$', jsonp_str).group(1) except: raise ValueError('無效數(shù)據(jù)!')
4,后臺代碼
from django.shortcuts import render,redirect,HttpResponse,HttpResponseRedirect from blog.models import Member from urllib import parse from urllib import request as req import re import json import random from blog.utils import function def loginQq(request): state = str(random.randrange(100000,999999)) # 定義一個隨機(jī)狀態(tài)碼,防止跨域偽造攻擊。 request.session['state'] = state # 將隨機(jī)狀態(tài)碼存入Session,用于授權(quán)信息返回時驗(yàn)證。 client_id = '101716344' # QQ互聯(lián)中網(wǎng)站應(yīng)用的APP ID。 # 對回調(diào)地址進(jìn)行編碼,用戶同意授權(quán)后將調(diào)用此鏈接。 callback = parse.urlencode({'redirect_uri':'http://127.0.0.1:8000/blog/returns'}) #redirect_uri=http%3A%2F%2F127.0.0.1%3A8000%2Fblog%2Freturns # 組織QQ第三方登錄鏈接 login_url = 'https://graph.qq.com/oauth2.0/authorize?response_type=code&client_id=%s&%s&state=%s'%(client_id,callback,state) return HttpResponseRedirect(login_url) # 重定向到QQ第三方登錄授權(quán)頁面 def returns(request): if request.session['state'] == request.GET['state']: # 驗(yàn)證狀態(tài)碼,防止跨域偽造攻擊。 code = request.GET['code'] # 獲取用戶授權(quán)碼 client_id = '101716344' # QQ互聯(lián)中網(wǎng)站應(yīng)用的APP ID。 client_secret = '7f42aaac69f866750078fbe1edd9d2a4' # QQ互聯(lián)中網(wǎng)站應(yīng)用的APP Key。 callback = parse.urlencode({'redirect_uri': 'http://127.0.0.1:8000/blog/returns'}) # 對回調(diào)地址進(jìn)行編碼,用戶同意授權(quán)后將調(diào)用此鏈接。 login_url = 'https://graph.qq.com/oauth2.0/token?grant_type=authorization_code&code=%s&client_id=%s&client_secret=%s&%s' % (code, client_id, client_secret, callback) # 組織獲取訪問令牌的鏈接 # return HttpResponse(login_url) response = req.urlopen(login_url).read().decode() # 打開獲取訪問令牌的鏈接 access_token:123456789& access_token = re.split('&', response)[0] # 獲取訪問令牌 access_token:123456789 res = req.urlopen('https://graph.qq.com/oauth2.0/me?' + access_token).read().decode() # 打開獲取openid的鏈接 openid = json.loads(function.parse_jsonp(res))['openid'] # 從返回?cái)?shù)據(jù)中獲取openid 410225632333335556566 userinfo = req.urlopen('https://graph.qq.com/user/get_user_info?oauth_consumer_key=%s&openid=%s&%s' % ( client_id, openid, access_token)).read().decode() # 打開獲取用戶信息的鏈接 # 打印查看獲取到的用戶信息 print(userinfo) userinfo = json.loads(userinfo) # 將返回的用戶信息數(shù)據(jù)(JSON格式)讀取為字典。 user = Member.objects.filter(member_qq_id=openid) # 查詢是否已存在用戶 if not user: # 如果不存在用戶 # 創(chuàng)建新用戶 member_obj = Member.objects.create(member_qq_id=openid,member_nickname=userinfo['nickname'],member_name=userinfo['nickname'],member_photo = userinfo['figureurl_qq_1']) # user = Member() # 創(chuàng)建新用戶 # user.member_qq_id = openid # 寫入用戶信息 # user.member_nickname = userinfo['nickname'] # 寫入用戶信息 # user.member_name = userinfo['nickname'] # 寫入用戶信息 # # user.gender = userinfo['gender'] # 寫入用戶信息 # user.member_photo = userinfo['figureurl_qq_1'] # 寫入用戶信息 # user.save() # 保存或更新用戶 request.session['member_id'] = member_obj.member_id # 將已登錄的用戶openid寫入Session request.session['member_name'] = userinfo['nickname'] # 返回路徑至網(wǎng)站首頁 return redirect('/blog/index/') else: return HttpResponse('授權(quán)失??!')
本文是在本地測試項(xiàng)目中的qq登錄功能,所以qq互聯(lián)官網(wǎng)中的回調(diào)地址需要修改為本地的地址,
5,啟動項(xiàng)目測試功能
6,查看數(shù)據(jù)庫會員表,會員信息已寫入。
總結(jié)
以上所述是小編給大家介紹的Django項(xiàng)目中實(shí)現(xiàn)使用qq第三方登錄功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
python selenium 執(zhí)行完畢關(guān)閉chromedriver進(jìn)程示例
今天小編就為大家分享一篇python selenium 執(zhí)行完畢關(guān)閉chromedriver進(jìn)程示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11python繪圖subplots函數(shù)使用模板的示例代碼
這篇文章主要介紹了python繪圖subplots函數(shù)使用模板的示例代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04Python實(shí)現(xiàn)字符串匹配的KMP算法
KMP算法的關(guān)鍵是利用匹配失敗后的信息,盡量減少模式串與主串的匹配次數(shù)以達(dá)到快速匹配的目的。這篇文章主要介紹了Python實(shí)現(xiàn)字符串匹配的KMP算法,需要的朋友可以參考下2019-04-04python實(shí)現(xiàn)文本去重且不打亂原本順序
這篇文章主要介紹了python實(shí)現(xiàn)文本去重且不打亂原本順序,需要的朋友可以參考下2016-01-01利用python檢查磁盤空間使用情況的代碼實(shí)現(xiàn)
本文將向讀者展示如何利用Python編寫自動化腳本,以檢查磁盤空間使用情況,無論你是經(jīng)驗(yàn)豐富的系統(tǒng)管理員,還是對Python自動化充滿興趣的開發(fā)者,本文都將為你提供實(shí)用的腳本示例和詳細(xì)的解析步驟,幫助你快速掌握磁盤空間監(jiān)控的自動化方法,需要的朋友可以參考下2024-08-08python相對包導(dǎo)入報(bào)“Attempted?relative?import?in?non-package”錯誤
這篇文章主要介紹了python相對包導(dǎo)入報(bào)“Attempted?relative?import?in?non-package”錯誤,本文要在原理上解決?python當(dāng)中相對包導(dǎo)入出現(xiàn)的問題,需要的朋友可以參考下2023-02-02Python Web項(xiàng)目Cherrypy使用方法鏡像
這篇文章主要介紹了Python Web項(xiàng)目Cherrypy使用方法鏡像,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-11-11