1. 目标

微信发展到今天,庞大的用户群体使得很多企业选择了微信定制开发。第三方应用可以通过集成企业微信实现企业用户对APP的功能的操作。

2. 准备

 2.1 进入微信后台管理页面,开发者需要拥有管理员权限。

扫码进入后台管理:https://work.weixin.qq.com/wework_admin/loginpage_wx#profile/wxPlugin

2.2 到应用管理内创建本次需要集成的应用

2.3 准备好企业的ID 和 应用的ID(AgentId)、Secret

3. 开发集成

3.1 OAuth2接入流程

OAuth2的设计背景,在于允许用户在不告知第三方自己的帐号密码情况下,通过授权方式,让第三方服务可以获取自己的资源信息。

微信access_token有效期为7200秒,且每次URL重新获取时为最新的时效为7200秒的access_token,,FSC后台取到后缓存到redis 避免与微信服务的频繁交互。

 3.2 集成过程

3.3开发步骤

3.3.1 登录企业微信后台,配置应用入口URL和网页授权

3.3.2 配置的入口URL跳转到应用的中间页面,用于重定向到应用的登录验证中间页面。( 此处也可以直接配置重定向的URL,直接跳转到登录验证。)

    <script>$.get('https://xxx.yyy.net/security/getDeriectInfoForWeChat', {},function (params, status) {console.log(params, status);if (status == "success") {var deriectUrl = encodeURIComponent(params.deriectUrl);var reidctUrl = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + params.appID + "&response_type=code&scope=snsapi_privateinfo&agentid=" + params.agentId + "&state=WeChat&redirect_uri=" + deriectUrl + "#wechat_redirect";// alert(reidctUrl)window.location.href = reidctUrl;} else {alert('初始化失败!')}})</script>

3.3.3 重定向后的页面获取到微信授权码code,调用应用后台验证用户信息并登录

1)根据企业ID+应用Secret 获取access_token,并缓存到redis

2)根据access_token+code获取微信用户基本信息 (UserId、user_ticket)

3)根据access_token+user_ticket获取微信用户详细信息(userid、name、mobile、email)

4)根据userid匹配后台用户信息映射表 并做应用的登录

/*** 验证微信用户信息* @param LoginUser * @return*/
//    @RequestMapping(value="/preLoginForWeChat",method=RequestMethod.GET)public void preLoginForWeChat(LoginUser loginUser) {String code = loginUser.getCode();if(code==null||"".equals(code)){throw new RuntimeException("未获取到微信code");}SystemService sService = SpringBeanUtil.getBean(SystemService.class);String accessToken = "";Object accessTokenTimeObj = redisManager.get("WETCHAT_ACCESSTOKEN_TIME");//先从缓存里获取accessToken缓存的时间boolean isGetTokenByURL = false;if(accessTokenTimeObj!=null && !"".equals(accessTokenTimeObj)){String accessTokenTimeStr = String.valueOf(accessTokenTimeObj);Long accessTokenTime = Long.parseLong(accessTokenTimeStr);Long thisTime = new Date().getTime();long interval = (thisTime - accessTokenTime)/1000;if(interval > 6900) //上次缓存到现在大于6900秒,再次通过URL获取{isGetTokenByURL = true;}else //否则从缓存中取{accessToken = String.valueOf(redisManager.get("WETCHAT_ACCESSTOKEN"));}}else //未获取到缓存时间(即没有缓存),需通过URL获取{isGetTokenByURL = true;}if(isGetTokenByURL)//缓存中没有时 调用url获取{AdSysParamDto aspd = sService.getAdSysParamDtoByTypeAndCode("APP_WECHAT","ACCESS_TOKEN_URL");if(aspd!=null){String tokenUrl = aspd.getParamValues();//urlif(tokenUrl!=null){String resStr = LocalUtil.sendPost(tokenUrl, null);JSONObject json = JSONObject.parseObject(resStr);accessToken = json.getString("access_token");if(accessToken!=null && !"".equals(accessToken)) //获取到accessToken{redisManager.delete("WETCHAT_ACCESSTOKEN");redisManager.set("WETCHAT_ACCESSTOKEN", accessToken,7000);//缓存accessToken7000秒(accessToken有效期7200秒)redisManager.delete("WETCHAT_ACCESSTOKEN_TIME");String tokenTime = String.valueOf(new Date().getTime());redisManager.set("WETCHAT_ACCESSTOKEN_TIME", tokenTime,7000);//本次缓存的时间}}}}if("".equals(accessToken)||"null".equals(accessToken)){throw new RuntimeException("未获取到微信accessToken");}AdSysParamDto aspd = sService.getAdSysParamDtoByTypeAndCode("APP_WECHAT","USER_INFO_URL");if(aspd!=null){String userUrl = aspd.getParamValues();//urlif(userUrl!=null){userUrl = userUrl.replace("{ACCESS_TOKEN}", accessToken);userUrl = userUrl.replace("{CODE}", code);String resStr = LocalUtil.sendPost(userUrl, null);JSONObject json = JSONObject.parseObject(resStr);String userId = json.getString("UserId");String userTicket = "";if(userId!=null && !"".equals(userId)){userTicket = json.getString("user_ticket");Map<String, Object> param = new HashMap<String, Object>();param.put("weChatUserId", userId);ModuleReturn<UserInfoWechatMappingDto> weUserModule = userIfoWeChatMappingAPI.queryUserInfoWechatMapping(param);if(weUserModule.isSuccess()){UserInfoWechatMappingDto weUser = weUserModule.getDatas();if(weUser!=null){String userAccount = weUser.getUserAccount();String password  = userAccount;//任意密码(此处做单点不校验)loginUser.setIsPointLogin("1");//单点登录loginUser.setUserAccount(userAccount);loginUser.setPassword(userAccount);//单点登录密码不校验}}}else{throw new RuntimeException("未获取到微信userId");}}}}

3.3.4 应用的前台获取后台接口登录成功结果,跳转到对应的展示页面

4 集成效果

企业微信集成外部APP相关推荐

  1. Dynamics CRM和企业微信集成(二)方案实现

    Dynamics CRM和企业微信集成(二)方案实现 准备工作 1. 企业微信 2. CRM准备 3. 其他准备 实施工作 1. 企业微信配置 2. 应用后台处理 1. 登陆时处理 2. WeChat ...

  2. 禅道与企业微信集成单点登录

    背景 公司使用企业微信做为办公管理系统.为了公司人事相关研发系统统一授权认证,实现业务系统账号与企业微信挂钩,做到统一管理授权,以此才有了禅道与企业微信集成单点登录研究. 集成步骤 集成步骤大致分为三 ...

  3. JeecgBoot低代码平台 2.4.5 版本发布,钉钉与企业微信集成版本

    项目介绍 JeecgBoot是一款基于代码生成器的低代码平台!前后端分离架构 SpringBoot2.x,SpringCloud,Ant Design&Vue,Mybatis-plus,Shi ...

  4. 企业微信集成EAS流程助手

    1.账户绑定 通过EAS提供账户登陆接口,判断用户是否与企业微信账户绑定, 如果未绑定,进行绑定并且存储在EAS用户表中.下次进入企业微信免登之间进入主界面 2.主界面 主界面加载EAS流程代办信息 ...

  5. 企业微信集成其他html,企业微信(新微信企业号)集成

    5.1 主页配置 进入刚刚自建的应用-文档测试: 1)可见范围:选择用户所在的部门,不能选择单个成员,因为单个用户将无法读取,示例文档组 2)网页授权及JS-SDK(可信域名):域名和端口号,示例ww ...

  6. 企业微信的外部联系人回调处理技巧

    一.关于设置接收事件服务器的信息 在企业微信管理后台的"客户联系-客户"页面,点开"API"小按钮,再点击"接收事件服务器"配置,进入配置页 ...

  7. 钉钉企业微信集成免登录

    一.资料 钉钉免登录方案:https://open.dingtalk.com/document/orgapp-server/sso-overview 二.实现 2.1 钉钉实现免登录第三方网站 实现后 ...

  8. 易飞ERP工作流解决方案之【企业微信集成】

    一.业务环境: 原有易飞电子签核不好用,不支持移动审核: 二.本方案优点: 完美的使用原易飞电子签核,使用和操作方法不变: 支持提交审批后单据不能修改,避免审批前后数据不一致: 支持单别启用审批流,即 ...

  9. 微信小程序中企业微信获取外部联系人信息

    需求:企业微信聊天页面,点击可跳转微信小程序的用户详情页. 本质就是在企业微信端拿到当前联系人的unionid,然后去用户服务里找到对应的用户userid,进入用户的详情页面. 流程:后端写一个从un ...

  10. 安卓内嵌浏览器打开不微信等外部app的问题

    做项目时要求在内嵌浏览器内完成微信支付宝等支付,支付时要如果安装了应该要跳转.遇到的问题是在要跳转时失败,原因是内嵌浏览器没有设置好client,示例代码如下: DisplayMetrics dm = ...

最新文章

  1. 转帖-MySQL Innodb日志机制深入分析
  2. pycharm 常用快捷键整理
  3. 2020-11-23(“花式扫雷” 辅助制作)
  4. class里面只能写以下5种
  5. jspwiki mysql_Wiki.js初体验
  6. 【ArcGIS遇上Python】ArcGIS批量处理栅格影像(NDVI)归一化完整案例代码
  7. 传感器和单片机主板之间远距离通讯应该有哪些保障处理措施
  8. iOS开发 - 动画实践系列
  9. linux目录与文件
  10. exit()和return的区别
  11. MySQL及其图形界面navicat的安装
  12. java+整合handwrite_解决java.lang.UnsatisfiedLinkError: JNI_ERR returned from JNI_OnLoad
  13. 用ajax来上传图片,AJAX上传图片,使用ajaxupload
  14. (三)Excel函数应用之逻辑函数
  15. gltf 2.0快速入门
  16. 基于SpringBoot + Vue的个人博客系统12——使用vue-admin-template展示文章列表(后台管理)
  17. 电子邮件发错了怎么撤回?原来邮件误发也有“后悔药”
  18. 中职计算机说课教法,2015教师资格证面试高中美术中职公共艺术美术篇说课稿 平面构成中的形象—活泼的点...
  19. android小米手机拍照功能,拍照参数设置界面_小米 M1(MIUI)_手机Android频道-中关村在线...
  20. Kafka之ISR机制的理解

热门文章

  1. 平方数之和【leetcode 633】
  2. linux触摸屏两指缩放_Linux内核触摸屏驱动--多点触摸 【转】
  3. 谱瑞PS8625替代方案|PS8622替代方案|高性价比EDP转LVDS转接板方案CS5211设计开发
  4. Ubuntu 谷歌浏览器下载
  5. MOV格式视频转MP4
  6. android计算器实训报告总结,计算机实训总结报告【三篇】
  7. airtest自动化测试
  8. excel中看着是空单元格,使用Ctrl+G定位空值却定位不到
  9. 获取UWP应用的三种方式
  10. 计算机主机配置一般有机箱主板cpu,电脑配置参数详解教程