钉钉(DingTalk) 是阿里巴巴集团专为中国企业打造的免费沟通和协同的多端平台,提供PC版,Web版和手机版,支持手机和电脑间文件互传。

钉钉因中国企业而生,帮助中国企业通过系统化的解决方案(微应用),全方位提升中国企业沟通和协同效率。

这里我们使用Django来集成一下钉钉的三方账号登录,首先登录钉钉开发平台: https://open-dev.dingtalk.com/

在移动应用中选择登录

创建一个网站应用,其中有用的信息是appid,appsecret,还有回调网址

随后,查看官方文档,查看如何构造登录url: https://ding-doc.dingtalk.com/doc#/serverapi2/kymkv6

这里我们用django的视图来操作

# 构造钉钉登录url
def ding_url(request):
    appid = 'dingoaukgkwqknzjvamdqh'
    redirect_uri = 'http://localhost:8000/dingding_back/'

    return redirect('https://oapi.dingtalk.com/connect/qrconnect?appid=' + appid +'&response_type=code&scope=snsapi_login&state=STATE&redirect_uri=' + redirect_uri)

然后访问: http://localhost:8000/ding_url,就可以进行扫码

随后,钉钉会将code返回到回调网址中,查看官方文档,只有java和php的sdk,并没有python的

怎么办,没关系,自己写,逻辑很简单,将时间戳,秘钥进行hmac加密即可

import time
import hmac
import base64
from hashlib import sha256
import urllib
import json

# 构造钉钉回调方法
def ding_back(request):

    # 获取code
    code = request.GET.get("code")

    t = time.time()
    
    # 时间戳
    timestamp = str((int(round(t * 1000))))
    appSecret ='ly-AzMKMmCKQP3geaILT_An32kEfKO3HeOtApy5CgKwjytevVZC0WYsT2gxMB160'

    # 构造签名
    signature = base64.b64encode(hmac.new(appSecret.encode('utf-8'),timestamp.encode('utf-8'), digestmod=sha256).digest())
    
    # 请求接口,换取钉钉用户名
    payload = {'tmp_auth_code':code}
    headers = {'Content-Type': 'application/json'}
    res = requests.post('https://oapi.dingtalk.com/sns/getuserinfo_bycode?signature='+urllib.parse.quote(signature.decode("utf-8"))+"&timestamp="+timestamp+"&      accessKey=dingoaukgkwqknzjvamdqh",data=json.dumps(payload),headers=headers)

    res_dict = json.loads(res.text)
    print(res_dict)
    return HttpResponse(res.text)

访问一下,可以看到已经显示出了钉钉的用户名

就是这么简单,最后附上项目地址: https://gitee.com/TianShangXing/mydjango