实现钉钉扫码登陆

news2025/1/16 17:31:37

在钉钉开放平台查看:实现登录第三方网站 - 钉钉开放平台

1、在开发者后台创建应用,创建完应用之后,拿到应用的AppKey和AppSecret。

2、添加接口权限

3、配置frp内网穿透:(当第四步使用回调域名的重定向地址时,这一步可以省略)

使用frp内网穿透工具生成一个公网域名用于教程测试

内网穿透:让内网或私有网络的服务能够被公网访问

FRP:帮助内网中的服务通过公网服务器进行转发,实现内网穿透。

4、在应用中的分享设置中,通过设置第三方网站的回调域名,设置一下重定向的地址

5、官网上说是搭建后端服务,我前端就没看,忽略

6、实现登录第三方网站,我是使用钉钉提供的页面进行登录授权的,根据钉钉提供的第三方网站访问地址来登录。
https://login.dingtalk.com/oauth2/auth?
redirect_uri=https%3A%2F%2Fwww.aaaaa.com%2Fauth
&response_type=code        //固定值为code,授权通过后返回authCode
&client_id=dingxxxxxxx   //应用的AppKey 
&scope=openid   //此处的openId保持不变,授权后可获得用户userid
&state=dddd
&prompt=consent


代码实现:

实现思路:1、设置根据钉钉提供的第三方网站访问地址定义的重定向地址,得到浏览器网址,

2、然后获取地址栏的参数authcode,然后把authcode作为参数调用后端接口,从而获取数据res,

3、并且把数据存储在localstorage中。

1、首先根据钉钉提供的第三方网站访问地址,设置重定向的地址,(这部分是钉钉提供的固定部分)。得到浏览器网址,并且赋值给浏览器
//获取要重定向的地址
redirectToDingTalk() {
      var redirectUrl =
        'https://login.dingtalk.com/oauth2/challenge.htm?                
         redirect_uri=http%3A%2F%2F127.0.0.1%3A8080%2F%23%2F
         &response_type=code
         &client_id=dinglyjekzn80ebnlyge
         &scope=openid
         &state=dddd
         &prompt=consent'
//在浏览器中进行页面重定向
      window.location.href = redirectUrl
    },

 

2、定义一个获取地址栏参数的方法,用于拿到调用接口所需要的数据authCode
    // 获取地址栏参数
    getUrlParam(name) {
      var temp = window.location.href.split('?')[1]
      var pram = new URLSearchParams('?' + temp)
      return pram.get(name)
    },
3、给定一个按钮,绑定点击事件scanLogin()
// 扫码登陆
    scanLogin() {
      //获取充定向的地址
      this.redirectToDingTalk();

      // 获取地址栏参数
      let authCode = this.getUrlParam('authCode')
      if (authCode) {
        // 调用跳转接口
        reqRedirect(authCode).then((res) => {
          if (res.code == 0) {
            console.log(res, '扫码登陆')
            localStorage.setItem('authCode', authCode)
            localStorage.setItem('name', res.data.name)
            //把token也进行存储
            localStorage.setItem('token',res.data.auth_token)
            this.$router.push('/home/robotManage')
          } else {
            window.location.href = 'http://localhost:8080/#/'
          }
        })
      }
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1812768.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

关于flutter 启动 页面加载空白(三四秒空白页面)

一:可以在 对应的xml配置启动动画 <item><bitmapandroid:gravity"center"android:src"mipmap/ic_launcher" /></item> 二&#xff1a;以下是对应的文件目录 注意事项&#xff1a;俩处xml都配置一下&#xff0c;配置一样就可以了

那些年我看过的技术书(持续更新,大佬的成长之路)

作为一个技术人啊&#xff0c;要学会多看书&#xff0c;发展自己。哦也&#xff01;你可以不关注&#xff0c;就把文章点个收藏吧&#xff0c;万一以后想看书了呢&#xff1f; 网络安全 CTF篇 入门篇 《极限黑客攻防&#xff1a;CTF赛题揭秘》 Web篇 Reserve篇 《IDApro…

小白学RAG:大模型 RAG 技术实践总结

节前&#xff0c;我们组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、今年参加社招和校招面试的同学。 针对大模型技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备面试攻略、面试常考点等热门话题进行了深入的讨论。 汇总合集…

【人工智能基础学习】Andrew Ng-机器学习基础笔记

⭐️我叫忆_恒心&#xff0c;一名喜欢书写博客的研究生&#x1f468;‍&#x1f393;。 如果觉得本文能帮到您&#xff0c;麻烦点个赞&#x1f44d;呗&#xff01; 近期会不断在专栏里进行更新讲解博客~~~ 有什么问题的小伙伴 欢迎留言提问欧&#xff0c;喜欢的小伙伴给个三连支…

Python实现音乐播放器 -----------内附源码

Python做一个简易的音乐播放器 简易音乐播放器 import time import pygamefile r歌曲路径 pygame.mixer.init() print(正在播放,file) track pygame.mixer.music.load(file) pygame.mixer.music.play() time.sleep(130) pygame.mixer.music.stop()运行效果&#xff1a; 开始…

档案数字化扫描录入整理流程

档案数字化扫描录入整理流程可以分为以下几个步骤&#xff1a; 1. 确定扫描设备和软件&#xff1a;选择适合的扫描设备和软件&#xff0c;确保扫描质量和效率。 2. 准备档案文件&#xff1a;将待扫描的档案文件按照一定的分类和顺序进行整理和准备&#xff0c;如编号、分类、日…

数值计算精度问题(浮点型和双整型累加精度测试)

这篇博客介绍双整型和浮点数累加精度问题,运动控制轨迹规划公式有大量对时间轴的周期累加过程,如果我们采用浮点数进行累加,势必会影响计算精度。速度的不同 进一步影响位置积分运算。轨迹规划相关问题请参考下面系列文章,这里不再赘述: 1、博途PLC 1200/1500PLC S型速度曲…

英伟达SSD视觉算法分类代码解析

一、官方原代码 #!/usr/bin/env python3 # # Copyright (c) 2020, NVIDIA CORPORATION. All rights reserved. # # Permission is hereby granted, free of charge, to any person obtaining a # copy of this software and associated documentation files (the "Softwa…

计算机毕业设计 | SSM 校园线上订餐系统 外卖购物网站(附源码)

1&#xff0c; 概述 1.1 项目背景 传统的外卖方式就是打电话预定&#xff0c;然而&#xff0c;在这种方式中&#xff0c;顾客往往通过餐厅散发的传单来获取餐厅的相关信息&#xff0c;通过电话来传达自己的订单信息&#xff0c;餐厅方面通过电话接受订单后&#xff0c;一般通…

UPerNet 统一感知解析:场景理解的新视角 Unified Perceptual Parsing for Scene Understanding

论文题目&#xff1a;统一感知解析&#xff1a;场景理解的新视角 Unified Perceptual Parsing for Scene Understanding 论文链接&#xff1a;http://arxiv.org/abs/1807.10221(ECCV 2018) 代码链接&#xff1a;https://github.com/CSAILVision/unifiedparsing 一、摘要 研究…

Java多线程之不可变对象(Immutable Object)模式

简介 多线程共享变量的情况下&#xff0c;为了保证数据一致性&#xff0c;往往需要对这些变量的访问进行加锁。而锁本身又会带来一些问题和开销。Immutable Object模式使得我们可以在不加锁的情况下&#xff0c;既保证共享变量访问的线程安全&#xff0c;又能避免引入锁可能带…

如何用二维码进行来访登记?这个模板帮你轻松实现!

在工厂、学校、写字楼、建筑工地等人员出入频繁的场所&#xff0c;使用传统的纸质登记方法容易造成数据丢失&#xff0c;而且信息核对过程繁琐&#xff0c;效率低下。 可以用二维码代替纸质登记本&#xff0c;访客进入时扫码就能登记身份信息&#xff0c;能够提高门岗访客管理…

微生信神助力:在线绘制发表级主成分分析(PCA)图

主成分分析&#xff08;Principal components analysis&#xff0c;PCA&#xff09;是一种线性降维方法。它利用正交变换对一系列可能相关的变量的观测值进行线性变换&#xff0c;从而投影为一系列线性不相关变量的值&#xff0c;这些不相关变量称为主成分&#xff08;Principa…

JMH309【亲测】典藏3D魔幻端游【剑踪3DⅢ】GM工具+开区合区工具+PC客户端+配置修改教程+Win一键服务端+详细外网视频教程

资源介绍&#xff1a; 经典不错的一款端游 GM工具开区合区工具PC客户端配置修改教程Win一键服务端详细外网视频教程 资源截图&#xff1a; 下载地址

数字化医疗:揭秘物联网如何提升医院设备管理效率!

在当今数字化时代&#xff0c;医疗领域正迎来一场技术变革的浪潮&#xff0c;而基于物联网的智慧医院医疗设备管理体系正是这场变革的闪耀之星。想象一下&#xff0c;医院里的每一台医疗设备都能像一位精密的工匠一样&#xff0c;自动监测、精准诊断&#xff0c;甚至在发生故障…

GitLab教程(三):多人合作场景下如何pull代码和处理冲突

文章目录 1.拉取别人同步的代码到本地的流程2.push冲突发生场景情景模拟简单的解决方法 在这一章中&#xff0c;为了模拟多人合作的场景&#xff0c;我需要一个人分饰两角。 执行git clone xx远端仓库地址 xx文件夹命令&#xff0c;在clone代码时指定本地仓库的文件夹名&#…

33.星号三角阵(二)

上海市计算机学会竞赛平台 | YACSYACS 是由上海市计算机学会于2019年发起的活动,旨在激发青少年对学习人工智能与算法设计的热情与兴趣,提升青少年科学素养,引导青少年投身创新发现和科研实践活动。https://www.iai.sh.cn/problem/742 题目描述 给定一个整数 𝑛,输出一个…

解决:RuntimeError: “slow_conv2d_cpu“ not implemented for ‘Half‘的方法之一

1. 问题描述 今天跑实验的时候&#xff0c;代码报错&#xff1a; RuntimeError: "slow_conv2d_cpu" not implemented for Half 感觉有点莫名奇妙&#xff0c;经检索&#xff0c;发现将fp16改为fp32可以解决我的问题&#xff0c;但是运行速度太慢了。后来发现&…

基于WPF技术的换热站智能监控系统02--标题栏实现

1、布局划分 2、准备图片资源 3、界面UI控件 4、窗体拖动和关闭 5、运行效果 走过路过不要错过&#xff0c;点赞关注收藏又圈粉&#xff0c;共同致富&#xff0c;为财务自由作出贡献

理解线程安全:保护你的代码免受并发问题困扰

目录 前言 一、什么是线程安全&#xff1f; 二、为什么需要线程安全&#xff1f; 三、实现线程安全的方法 四、synchronized 使用 synchronized 关键字时&#xff0c;需要注意以下几点&#xff1a; 五、Demo讲解 前言 在现代软件开发中&#xff0c;尤其是在多线程编程中&…