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中:

相关推荐
吴声子夜歌6 分钟前
JavaScript——异步编程
开发语言·前端·javascript
陈随易25 分钟前
农村程序员聊五险一金
前端·后端·程序员
恋猫de小郭27 分钟前
Swift 6.3 正式发布支持 Android ,它能在跨平台发挥什么优势?
android·前端·flutter
xujing_0630 分钟前
跑马灯组件vue3+es6
前端·javascript·es6
小小善后师41 分钟前
告别周报烦恼:我用 200 行代码打造了一个 AI 工时助手
前端
Mahut44 分钟前
我们是怎么用 TanStack 全家桶的
前端·javascript·架构
FreeBuf_1 小时前
Claude浏览器扩展漏洞允许通过任意网站实现零点击XSS提示注入
前端·网络·xss
AlunYegeer1 小时前
【JAVA】网关的管理原理和微服务的Interceptor区分
java·服务器·前端
sensen_kiss1 小时前
CAN302 电子商务技术 Pt.2 深入了解HTML和CSS
前端·css·学习·html
说实话起个名字真难啊1 小时前
前端JS审计:渗透测试的“破局之钥”
开发语言·前端·javascript·测试工具