h5接入企业微信登录以及本地开发调试

首先管理员登录企业微信,创建第三方应用

把appID(企业微信ID) , AgentId(应用id)和Secret(密钥)记下来给后端同事

在应用中配置可信域名,例如:

我配置好的如下:

配置登录授权域名

设置应用主页

通过hosts文件将www.luocl.cn转发到本地

通过nginx代理,将127.0.0.1转发到本地服务,我的如下:

打开企业微信,按住 Ctrl + Shift + Alt + D 进入调试模式,点击头像打开debugger

点击进入应用:

上面实现了企微本地联调,接下里是实现通过企微登录h5

通过前面的应用主页链接地址,前端可以获取Code,通过code,可以消费code,获取后端返回的token,以及其他参数,具体返回什么根据业务自定义。

参考文档:
https://developer.work.weixin.qq.com/document/path/91023

https://developer.work.weixin.qq.com/document/path/91039

前端代码示例:

复制代码
 const { params } = getUrlParams(window.location.search)
 // 通过code登录
 this.toAuth(params.code)

getUrlParams为获取url参数公用方法:

复制代码
getUrlParams = (url) => {
    let result = {
        url: '',
        params: {}
    };
    let list = url.split('?');
    result.url = list[0];
    let params = list[1];
    if (params) {
        let list = params.split('&');
        list.forEach(ele => {
            let dic = ele.split('=');
            let label = dic[0];
            let value = dic[1];
            result.params[label] = value;
        });
    }
    return result;
}

在前后端联调的时候,注意把后端IP加入到可信IP中:

相关推荐
QYR市场调研几秒前
低密度聚乙烯市场竞争格局变化趋势
前端
学以智用6 分钟前
Vue 3 组件完全指南
前端·vue.js
重庆穿山甲8 分钟前
Java开发者的大模型入门:AgentScope Java组件全攻略(一)
前端·后端
LawrenceLan12 分钟前
36.Flutter 零基础入门(三十六):StatefulWidget 与 setState 进阶 —— 动态页面必学
开发语言·前端·flutter·dart
ego.iblacat13 分钟前
Web 技术与 Nginx 网站环境部署
运维·前端·nginx
ricky_fan14 分钟前
(已解决)安装openclaw龙虾[特殊字符]npm权限问题EACCES
前端·npm·node.js
专业流量卡15 分钟前
让小龙虾给我写文章
前端
技术人生黄勇17 分钟前
微信接入|企业微信官方插件支持 OpenClaw 3步快速接入(实操版)
java·前端·人工智能·微信·企业微信
倔强的石头_19 分钟前
MySQL 兼容性深度解析:从内核级优化到“零修改”迁移工程实践
前端·数据库
小小小米粒19 分钟前
k8s流程创建清单
服务器·前端·etcd