钉钉登录
说明:目前使用的钉钉后台还在更新中,可能和文章展示的不同
1. 准备工作,首先需要有自己管理的部门
1. 进入开发者后台扫码登陆,如果是组织的管理者就直接选择进入
data:image/s3,"s3://crabby-images/4b929/4b929cacd8ec1b03960deea93d9902e4560e64d4" alt="在这里插入图片描述"
2. 不是组织管理者
首先注册 data:image/s3,"s3://crabby-images/50c4f/50c4fb6d4937608ec1d09e919556be3441c6ae00" alt="在这里插入图片描述"
创建团队
data:image/s3,"s3://crabby-images/3b37d/3b37d13b39d5a0ba15842d3e5a070629b1c8fb63" alt="在这里插入图片描述"
创建成功
data:image/s3,"s3://crabby-images/68941/68941a1d71c738a03905aef44df313a884ed6c9a" alt="在这里插入图片描述"
进入手机APP查看
data:image/s3,"s3://crabby-images/576e6/576e6ac8d3b53ca499d9e7102d807dea942898e0" alt="在这里插入图片描述"
3. 如果是管理者
- 扫码登陆选择组织
data:image/s3,"s3://crabby-images/b40fa/b40fa75896474e5f61b931cc767448a97f864ef7" alt="在这里插入图片描述" - 创建的个人团队目前只演示企业内部开发,创建应用为H5微应用或者小程序都可以
data:image/s3,"s3://crabby-images/59692/596927b568c00ca9a8ddf161ba9a33a433113b5f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/b4593/b4593cc58df464d922e87d418d91c012f9f8d3a1" alt="在这里插入图片描述" - 返回首页
data:image/s3,"s3://crabby-images/f2afb/f2afb0100711d7c23185e877398f337af393365d" alt="在这里插入图片描述" - 选择进入,添加回调域名,这里使用的是开发环境,所以添加了当前项目运行的地址和端口号
data:image/s3,"s3://crabby-images/597ab/597abd3994bdd5ec02b42f1822ee14302f6ef1e5" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/eafdc/eafdc6d2eda9c94a230dfd7cfa956935d6a5905f" alt="在这里插入图片描述" - 进入工作台
data:image/s3,"s3://crabby-images/d3c1b/d3c1b5daff810f110c34db28b50f485b5f275005" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/3a2ab/3a2ab215fb89400ad8a763070cb01ec90b39ce08" alt="在这里插入图片描述"
4.前端开发过程,不管是扫码登录还是使用钉钉的账号密码登录,都需要导入一个js 官方说明地址
- 在
index.html 中添加,window 就会挂载一个DDLogin 实例<script src="https://g.alicdn.com/dingding/dinglogin/0.0.5/ddLogin.js"></script>
data:image/s3,"s3://crabby-images/fd02b/fd02bd1b64a93aea8c557d48a91f3710513c7eae" alt="在这里插入图片描述"
- 初始化钉钉登录,
appid 是在工作台配置登录的时候生成的,url 中的回调地址也是在工作台中配置的,id 对应的html 中的标签 data:image/s3,"s3://crabby-images/57882/578822e63448d4943eba01e73eba226354c445f3" alt="在这里插入图片描述"
<template>
<div class="dd-scan-login">
<div id="dd-login"></div>
</div>
</template>
<script>
const appid = 'dingoapbicykzzeqxpelxy'
const url = encodeURIComponent('http://127.0.0.1:9527/login')
const goto = encodeURIComponent(`https://oapi.dingtalk.com/connect/oauth2/sns_authorize?appid=${appid}&response_type=code&scope=snsapi_login&state=STATE&redirect_uri=${url}`)
export default {
name: 'DDScanLogin',
data() {
return {}
},
created() {},
mounted() {
this.ddInit()
},
methods: {
ddInit() {
window.DDLogin({
id: 'dd-login',
goto,
style: 'border:none;background-color:#FFFFFF;',
width: '365',
height: '400'
})
}
}
}
</script>
页面的效果 data:image/s3,"s3://crabby-images/0922c/0922cb04a1807b6708d3b7fcf524a208063e0d7e" alt="在这里插入图片描述" 手机端扫描之后 data:image/s3,"s3://crabby-images/a0343/a0343c427b13a63a8cc50a6362f8bd38316ca2c9" alt="在这里插入图片描述"
- 获取临时授权码
loginTmpCode ,使用监听message ,这里获取到临时授权码之后,可以将loginTmpCode 传递给后台,后台处理之后,将数据返回
created() {
window.addEventListener('message', this.DDMessage, false)
},
methods: {
DDMessage(event) {
const origin = event.origin
if (origin === 'https://login.dingtalk.com') {
const loginTmpCode = event.data
console.log('loginTmpCode', loginTmpCode)
}
}
},
beforeDestroy() {
window.removeEventListener('message', this.DDMessage, false)
}
3. 钉钉账号密码登录
- 为了不让页面刷新,使用
iframe 标签,sandbox="allow-scripts allow-same-origin allow-popups" 可以阻止页面跳转
<iframe
:src="iframeSrc"
frameborder="0"
id="dd-account-iframe"
sandbox="allow-scripts allow-same-origin allow-popups"
></iframe>
<script>
const appid = 'dingoapbicykzzeqxpelxy'
const url = encodeURIComponent('http://127.0.0.1:9527/login')
export default {
data() {
return {}
},
computed: {
iframeSrc() {
return `https://oapi.dingtalk.com/connect/oauth2/sns_authorize?appid=${appid}&response_type=code&scope=snsapi_login&state=STATE&redirect_uri=${url}`
}
},
created() {},
mounted() {},
methods: {}
}
</script>
- 使用
onload ,获取
mounted() {
this.ddLoginInit()
},
methods: {
ddLoginInit () {
const that = this
document.getElementById('dd-account-iframe').onload = async function () {
try {
const getParams = this.contentWindow.location.href
const getIndex = getParams.indexOf('code=')
if (getIndex !== -1) {
const getCode = getParams.split('=')[1].split('&')[0]
console.log(getCode, 'getCode')
}
} catch (error) {
console.log(error)
} finally {
}
}
}
}
data:image/s3,"s3://crabby-images/4f41c/4f41c917cea09b83dc7b78406a063e5278c582d4" alt="在这里插入图片描述"
|