企业微信jdk 授权 记录

1、npm install @wecom/jssdk

2、index.html 引入

javascript 复制代码
<script src="https://wwcdn.weixin.qq.com/node/open/js/wecom-jssdk-2.0.2.js"></script>

3、创建js import * as ww from "@wecom/jssdk";

javascript 复制代码
/**
 * 获取企业微信jdk局方法--------------------------1
 */
import { accessConfig, accessAgentConfig } from "../api/sdk/index";
import * as ww from "@wecom/jssdk";
/**
 *** 作者: Lenovo-【Lindon】
 *** 文件名称: weChat
 *** 文件创建日期: 2024/4/30
 ***
 */
// 注册企业微信应用信息
// 注册企业微信应用信息
export async function registerWeChat() {
  // ✅ 前置处理:确保URL处理一致
  const getCleanUrl = () => window.location.href.split('#')[0];

  // ✅ 企业签名(同步改造)
  const getConfigSignature = async () => {
    try {
      console.log('[DEBUG] 开始获取企业签名');
      const res = await accessConfig({ path: getCleanUrl() });
      if (res?.code !== 200) throw new Error('企业签名接口异常');
      console.log('[DEBUG] 企业签名数据:', res.data);
      return res.data; // ✅ 直接返回后端结构体
    } catch (error) {
      console.error('[ERROR] 企业签名失败:', error);
      throw error; // 必须抛出以中断流程
    }
  };

  // ✅ 应用签名(保持原有正确结构)
  const getAgentConfigSignature = async (urlFromSDK) => {
    try {
      console.log('[DEBUG] 开始获取应用签名,SDK传入URL:', urlFromSDK);
      const pureUrl = new URL(urlFromSDK.split('#')[0]).href; // ✅ 使用SDK提供的URL
      const res = await accessAgentConfig({ path: pureUrl });
      if (res?.code !== 200) throw new Error('应用签名接口异常');
      console.log('[DEBUG] 应用签名数据:', res.data);
      return res.data;
    } catch (error) {
      console.error('[ERROR] 应用签名失败:', error);
      throw error;
    }
  };

  // ✅ 注册时开启调试模式
  ww.register({
    corpId: "wwf823be6e18d7191f",
    agentId: 1000003,
    jsApiList: ["getCurExternalContact","scanQRCode"],
    getConfigSignature,
    getAgentConfigSignature,
    debug: true, // ✅ 关键!开启调试模式
    onConfigSuccess(res) {
      console.log('[SUCCESS] 配置成功:', res);
    },
    onConfigFail(res) {
      console.error('[FAIL] 配置失败:', res);
      alert('SDK配置失败,请检查控制台');
    }
  });
}


//后续在哪个页面如果需要使用到sdk,都需要先注册registerWeChat,然后再调用对应的sdk方法

4、将方法引入到 需要使用的页面 中 然后调用 registerWeChat() 进行授权 可以在 加载时Mounted 去授权

5、使用示例

javascript 复制代码
点击事件

function fafacc() {
  ww.getCurExternalContact({
    success(res) {
      console.log('获取外部联系人id成功', res)
    },
    fail(res) {
      console.log('获取外部联系人id失败', res)
    },
  })
}
相关推荐
源雀数智5 天前
源雀AI SCRM开源版重磅升级:AI智能标签库
人工智能·企业微信·流量运营
梦想的旅途25 天前
企业微信API:外部群自动化推送实战指南
大数据·机器人·自动化·企业微信·rpa
vx-bot5556665 天前
企业微信ipad协议的事件驱动架构与实时监听实践
架构·企业微信·ipad
天空属于哈夫克35 天前
基于 Webhook 的企业微信外部群自动化推送集成
运维·自动化·企业微信
JZC_xiaozhong5 天前
企业微信对接泛微OA:实现审批进度实时同步与自动催办
企业微信·etl工程师·泛微oa·数据集成与应用集成·业务流程管理系统·异构系统集成·跨系统流程管理
天空属于哈夫克36 天前
Java 开发|企微外部群主动发送小程序消息实战
开发语言·python·小程序·自动化·企业微信·rpa
vx-bot5556666 天前
企业微信ipad协议的标签管理机制与自动化打标实践
自动化·企业微信·ipad
梦想的旅途26 天前
Python 实现企业微信外部群主动消息发送
机器人·自动化·企业微信·rpa
风笑谷10 天前
openclaw+ollama+企业微信 实操记录
企业微信·ollama·openclaw
ipad协议开发11 天前
企业微信iPad协议接口深度解析:技术原理、应用场景与开发实战
ios·企业微信·ipad