vue+Django接入钉钉登录

前端处理

复制代码
 dingtalkLogin() {
      let url = `https://login.dingtalk.com/oauth2/auth?redirect_uri=${this.dingRedirectUrl}&response_type=code&client_id=${this.appKey}&scope=openid&state=STATE&prompt=consent`
      window.location.href = url;
    },

后端处理

复制代码
def dingtalk_auth(request):
    try:
        code = request.GET['code']
        logger.info('钉钉临时授权码获取 ----{}'.format(code))

        token = get_user_token(code)  # oauth2/userAccessToken
        
        logger.info('根据钉钉临时授权码获取token ----{}'.format(token))
        user_resp = get_user_info(token)  # /contact/users/{}
        logger.info('根据获取用户信息 ----{}'.format(user_resp))

        user = User.objects.filter(username=user_resp['mobile']).first()

        if user:
            user.email = user_resp.get('email', '')
            user.save()
        else:
            params = {
                'username': user_resp.get('mobile'),
                'first_name': user_resp.get('nick'),
                'dingtalk_name': user_resp.get('nick'),
                'dingtalk_avatar': user_resp.get('avatarUrl'),
                'mobile_phone': user_resp.get('mobile'),
                'email': user_resp.get('email'),
                'is_superuser': False
            }
            user = User.objects.create(**params)

        logger.info('根据用户信息 ----{}'.format(user.username))
        if not user.is_staff:
            print("----校验用户登录权限{}----".format(user.is_staff))
            return JsonResponse(
                {'code': 204, "msg": '请确认您是否有此网站的登录权限'})
        refresh = RefreshToken.for_user(user)
       # 生成一个Django自己的token
        result = {'code': 200, "username": user.username, "token": str(refresh.access_token)}
        print("----校验用户获取返回值为{}----".format(result))

        return JsonResponse(result)
    except Exception as e:
        print(e)
        print(traceback.format_exc())
        logger.info('钉钉登录报错 ----{}'.format(traceback.format_exc()))

        return JsonResponse({'code': 400, 'errmsg': str(e)})

参考

https://developer.aliyun.com/article/1488636

https://open.dingtalk.com/document/orgapp-server/use-dingtalk-account-to-log-on-to-third-party-websites-1?spm=a2c6h.12873639.article-detail.7.5d622205VHxpO0#title-fre-oe4-zqn

相关推荐
毕设源码-邱学长20 小时前
【开题答辩全过程】以 基于VUE的藏品管理系统的设计与实现为例,包含答辩的问题和答案
前端·javascript·vue.js
学习CS的小白1 天前
跨域问题详解
vue.js·后端
周星星日记1 天前
5.为什么vue中使用query可以保留参数
前端·vue.js
+VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue作业管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Tzarevich1 天前
现代前端开发工程化:从 Vite 到 Vue 3 多页面应用实战
vue.js·vite
luoluoal1 天前
基于python的RSA算法的数字签名生成软件(源码+文档)
python·mysql·django·毕业设计
JIngJaneIL1 天前
基于java+ vue办公管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
小北方城市网1 天前
第4 课:Vue 3 路由与状态管理实战 —— 从单页面到多页面应用
前端·javascript·vue.js
ohyeah1 天前
用 Vue3 + Coze API 打造冰球运动员 AI 生成器:从图片上传到风格化输出
前端·vue.js·coze
掘金安东尼1 天前
React 已经改变了,你的 Hooks 也应该改变
前端·vue.js·github