wxAuthorized.js 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. import {
  2. wechatConfig,
  3. share
  4. } from '@/api/wx';
  5. // 加载日志
  6. import * as log from './log.js'
  7. import {
  8. isAndroid
  9. } from './platform.js'
  10. import store from '../store';
  11. // 保存wx对象
  12. import weixinObj from "@/plugin/jweixin-module/index.js";
  13. // 保存分享数据
  14. let shareData = '';
  15. // 保存注册返回appId数据
  16. let appId = '';
  17. //保存路由对象
  18. let router = '';
  19. //微信登录
  20. /**
  21. * @param {string} 当前页面地址信息
  22. */
  23. export async function loginWinxin() {
  24. console.log('1');
  25. let pages, page, path;
  26. if (!router) {
  27. router = await setRouter();
  28. }
  29. try {
  30. pages = getCurrentPages();
  31. // 获取跳转前页面
  32. page = pages[pages.length - 1];
  33. // 获取跳转前路由地址
  34. path = page.route;
  35. } catch (e) {
  36. console.log(e);
  37. //TODO handle the exception
  38. }
  39. // 判断是否在登录页
  40. if (path != 'pages/public/redirect') {
  41. log.addLog('开始注册微信')
  42. weixindata().then(() => {
  43. // 调用
  44. try {
  45. weixinSq();
  46. } catch (e) {
  47. console.log(e);
  48. //TODO handle the exception
  49. }
  50. });
  51. }
  52. };
  53. // 微信授权登录
  54. function weixinSq() {
  55. // 微信授权后跳转页面
  56. try {
  57. // 判断是否真实路由模式
  58. const type = router.mode === "history"?'':'/#'
  59. let ul = encodeURIComponent(store.state.baseURL + store.state.urlFile +type+ '/pages/public/redirect');
  60. // 打开微信授权页面
  61. let url =
  62. 'https://open.weixin.qq.com/connect/oauth2/authorize?appid=' +
  63. appId +
  64. '&redirect_uri=' +
  65. ul +
  66. '&response_type=code&scope=snsapi_userinfo&state=' +
  67. new Date().getTime() +
  68. '#wechat_redirect';
  69. window.location.href = url;
  70. } catch (e) {
  71. console.log(e);
  72. //TODO handle the exception
  73. }
  74. };
  75. // 微信注册
  76. export async function weixindata(config) {
  77. let url;
  78. try {
  79. // 判断是否存在router
  80. if (!router) {
  81. router = await setRouter();
  82. }
  83. if (router.mode === "history") {
  84. // 在ios中时候注册为微信刚进入时候的页面
  85. if (!window.entryUrl) {
  86. window.entryUrl = location.href.split('#')[0]
  87. }
  88. url = isAndroid() ? location.href.split('#')[0] : window.entryUrl;
  89. }
  90. if (router.mode === "hash") {
  91. url = location.href.split('#')[0];
  92. }
  93. log.addLog('注册开始', url)
  94. console.log('开始注册', url);
  95. } catch (e) {
  96. console.log('错误', e);
  97. }
  98. return new Promise((ok, error) => {
  99. try {
  100. //注册微信信息
  101. wechatConfig({
  102. url
  103. })
  104. .then(({
  105. data
  106. }) => {
  107. try {
  108. // 保存appId
  109. appId = data.appId
  110. // 微信信息配置
  111. weixinObj.config({
  112. debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  113. appId: data.appId, // 必填,企业号的唯一标识,此处填写企业号corpid
  114. timestamp: data.timestamp, // 必填,生成签名的时间戳
  115. nonceStr: data.nonceStr, // 必填,生成签名的随机串
  116. signature: data.signature, // 必填,签名,见附录1
  117. jsApiList: data.jsApiList // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
  118. });
  119. weixinObj.ready((e) => {
  120. log.addLog("注册完毕", data)
  121. console.log('注册完毕');
  122. ok(data,weixinObj)
  123. })
  124. } catch (e) {
  125. console.log(e)
  126. }
  127. })
  128. .catch(e => {
  129. error(e);
  130. console.log(e);
  131. });
  132. } catch (e) {
  133. console.log(e);
  134. //TODO handle the exception
  135. }
  136. })
  137. }
  138. // 判断分享调用方法
  139. export function shareLoad(config) {
  140. console.log('开始调用分享')
  141. try {
  142. weixindata().then((e) => {
  143. // 判断有无自定义数据
  144. if (config) {
  145. shareFun(config)
  146. } else {
  147. // 判断是否已经缓存了默认数据
  148. if (shareData) {
  149. shareFun()
  150. } else {
  151. // 请求获取默认数据
  152. share({}).then(({
  153. data
  154. }) => {
  155. shareData = data.data
  156. shareFun()
  157. });
  158. }
  159. }
  160. })
  161. } catch (e) {
  162. console.log('报错', e)
  163. //TODO handle the exception
  164. }
  165. }
  166. // 配置分享数据
  167. function shareFun(config) {
  168. try {
  169. console.log('再付分享内容', config);
  170. let mess;
  171. if (config) {
  172. mess = {
  173. link: config.link, // 分享链接
  174. imgUrl: config.imgUrl,
  175. desc: config.desc,
  176. title: config.title,
  177. success: config.success || function(e) {
  178. console.log(e);
  179. },
  180. fail: config.fail || function(e) {
  181. console.log(e);
  182. }
  183. }
  184. } else {
  185. const userInfo = uni.getStorageSync('userInfo')
  186. console.log(userInfo);
  187. const url = window.location.href + '?spread=' + userInfo.uid;
  188. url = url.replace(/[\?,&]{0,1}from=singlemessage/g, '');
  189. mess = {
  190. title: shareData.title,
  191. link: url, // 分享链接
  192. imgUrl: shareData.img, // 分享图标
  193. desc: shareData.synopsis,
  194. success: function() {
  195. // uni.showModal({
  196. // title: '分享',
  197. // content: '分享成功',
  198. // showCancel: false,
  199. // success: res => {
  200. // console.log('分享成功回调接口');
  201. // },
  202. // fail: () => {},
  203. // complete: () => {}
  204. // });
  205. }
  206. }
  207. }
  208. // 获取仓库数据
  209. // 分享好友
  210. weixinObj.updateAppMessageShareData(mess);
  211. // 分享朋友圈
  212. weixinObj.updateTimelineShareData(mess)
  213. } catch (e) {
  214. console.log(e);
  215. //TODO handle the exception
  216. }
  217. }
  218. // 保存路由对象
  219. export function setRouter(route) {
  220. return new Promise((ok, err) => {
  221. router = getApp().$router;
  222. console.log(router,'开始数据');
  223. if (!router) {
  224. const set = setInterval(() => {
  225. router = getApp().$router;
  226. console.log(router,'返回数据');
  227. if (router) {
  228. console.log(router,'结束');
  229. clearInterval(set)
  230. ok(router)
  231. }
  232. }, 100);
  233. }else{
  234. console.log(router,'成功');
  235. ok(router)
  236. }
  237. })
  238. }
  239. export default {
  240. weixinObj,
  241. shareData,
  242. appId,
  243. setRouter,
  244. shareLoad
  245. }