uniapp實(shí)現(xiàn)釘釘掃碼登錄示例代碼
由于uniapp暫無釘釘授權(quán)登錄所以本文將釘釘掃碼登錄作為網(wǎng)頁嵌入uniapp,最終實(shí)現(xiàn)釘釘掃碼登錄app
1. 用H5調(diào)起釘釘掃碼登錄
釘釘在網(wǎng)頁端的掃碼登錄可參考釘釘文檔:掃碼登錄第三方網(wǎng)站 - 釘釘開放平臺 (dingtalk.com)
// 釘釘掃碼登錄 dingLoginFn() { let dingData = { appid: OUT_LINK_CONFIG.dingAppid, state: "STATE", url: encodeURIComponent('登錄后的回調(diào)地址:可以是你的H5的一個(gè)頁面地址(href)') // 這個(gè)地址御用釘釘掃碼確認(rèn)后的路由重定向(會攜帶掃碼獲取的code值) }; let oauth = `https://oapi.dingtalk.com/connect/oauth2/sns_authorize?appid=${dingData.appid}&response_type=code&scope=snsapi_login&state=${dingData.state}&redirect_uri=${dingData.url}`; let goto = encodeURIComponent(oauth); DDLogin({ id: "loginContainer", //這里需要你在自己的頁面定義一個(gè)HTML標(biāo)簽并設(shè)置id,例如<div id="login_container"></div>或<span id="login_container"></span> goto: goto, style: "border:none;background-color:#FFFFFF;", width: "268" }); let handleMessage = (event) => { // 判斷是否來自ddLogin掃碼事件。 if (event.origin == "https://login.dingtalk.com" && event.data) { console.log("loginTmpCode", event.data); window.location.href = `${oauth}&loginTmpCode=${event.data}`; // 獲取到loginTmpCode后就可以在這里構(gòu)造跳轉(zhuǎn)鏈接進(jìn)行跳轉(zhuǎn)了 } }; if (typeof window.addEventListener != "undefined") { window.addEventListener("message", handleMessage, false); } else if (typeof window.attachEvent != "undefined") { window.attachEvent("onmessage", handleMessage); } }
2. 用于路由重定向的地址最好不要是調(diào)起釘釘二維碼的網(wǎng)頁地址(步驟1的地址)
因?yàn)樵趗niapp中如果兩個(gè)地址一樣會導(dǎo)致回傳code到登錄的過程再次展示一下二維碼頁面才跳轉(zhuǎn)到登錄成功界面。路由重定向頁面(本文采用Vue構(gòu)建),想要在H5中使用uni的API,需要在public/index.html中引入uni的jdk
<!DOCTYPE html> <html lang=""> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> <!-- 引入釘釘掃碼登錄的JDK --> <script src="https://g.alicdn.com/dingding/dinglogin/0.0.5/ddLogin.js"></script> <title></title> </head> <body> <noscript> <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong> </noscript> <div id="app"></div> <!-- built files will be auto injected --> </body> <!-- 引入uni API的JDK 注意:一定要在body后引入 在head中引入可能獲取失敗 --> <script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script> </html>
重定向頁面:
<template> <div></div> </template> <script> export default { name: "LoginCallback", mounted() { // 在mounted生命周期監(jiān)聽釘釘重定向后攜帶的參數(shù)并回傳uniapp document.addEventListener("plusready", () => { this.$nextTick(() => { // 待觸發(fā) `UniAppJSBridgeReady` 事件后,即可調(diào)用 uni 的 API。如果不是一打開頁面就調(diào)用 可以不用這個(gè)監(jiān)聽 document.addEventListener("UniAppJSBridgeReady", () => { // this.$toast("location.search:::", JSON.stringify(location.search)); if (location.search.includes("?code")) { console.log("getCode:::"); let code = location.search.split("?")[1].split("&")[0].split("=")[1]; // 這里獲取code后通過uni API 跳轉(zhuǎn)回uniapp的頁面并攜帶參數(shù)(uniapp中在onLoad中獲?。?也可以通過uniapp提供的 uni.postMessage({data: [code]}) 去傳遞(注意:通過postMessage傳的參數(shù)在uniap中獲取的data是一個(gè)數(shù)組) uni.webView.navigateTo({ url: `/pages/login/login_webview?code=$[code]` }); } }); }); }); } }; </script>
3. uniapp中可以使用webview去承載釘釘掃碼的網(wǎng)頁,并接收釘釘掃碼后獲取的code參數(shù)
<script> import { dingLogin } from '@/api/login' import { setToken } from "@/utils/auth" export default { name: "LoginWebview", data() { return { url: 'http://xxxxxxx/dd_login' // 這里的 url 就是步驟1中寫的釘釘掃碼網(wǎng)頁地址 } }, onLoad(options) { // 這里是掃碼后回傳的參數(shù)code 用于登錄 if (options.code) { this.login(options.code) } }, methods: { async login(code) { uni.showLoading() try { const res = await dingLogin(code) if (res.data.code === 200) { setToken(res.data.token) uni.reLaunch({ url: '/pages/home/index' }) } uni.hideLoading() } catch (e) { console.log('登錄失敗', e) uni.hideLoading() } } } } </script>
好了,大功告成!?。?/p>
如果有需要從釘釘掃碼的頁面返回uniapp切換登錄方式的操作,可以通過uni的API跳回uniapp
uni.webView.navigateTo({ url: "/pages/login/index" });
到此這篇關(guān)于uniapp實(shí)現(xiàn)釘釘掃碼登錄的文章就介紹到這了,更多相關(guān)uniapp釘釘掃碼登錄內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從parcel.js打包出錯(cuò)到選擇nvm的全部過程
這篇文章主要介紹了從parcel.js打包出錯(cuò)到選擇nvm的全部過程,需要的朋友可以參考下2018-01-01js+css實(shí)現(xiàn)導(dǎo)航效果實(shí)例
這篇文章主要介紹了js+css實(shí)現(xiàn)導(dǎo)航效果,實(shí)例分析了下拉菜單導(dǎo)航的js實(shí)現(xiàn)方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-02-02JavaScript Base64編碼和解碼,實(shí)現(xiàn)URL參數(shù)傳遞。
JavaScript Base64編碼和解碼,實(shí)現(xiàn)URL參數(shù)傳遞。...2006-09-09用JavaScript調(diào)用WebService的示例
JavaScript用htc實(shí)現(xiàn)WebService的調(diào)用2008-04-04Javascript客戶端將指定區(qū)域?qū)С龅絎ord、Excel的代碼
Javascript 瀏覽器客戶端導(dǎo)出指定區(qū)域到Word、Excel,非常不錯(cuò)的應(yīng)用實(shí)例2008-10-10javascript跨域方法、原理以及出現(xiàn)問題解決方法(詳解)
javascript出于安全方面的考慮,不允許跨域調(diào)用其他頁面的對象。但是在安全限制的同時(shí)也給注入iframe或是ajax應(yīng)用上帶來了不少麻煩??缬蚝唵蔚睦斫饩褪且?yàn)閖avascript同源策略的限制,a.com域名下的js無法操作b.com 或者是c.a.com域名下的對象2015-08-08