1. 单点登录配置指南
专属集成平台
  • 快速开始
    • 集成平台概览
  • 身份与用户管理
    • 用户管理
      • 用户与组织架构管理
    • 角色管理
      • 角色管理配置说明
    • 属性管理
      • 属性管理配置说明
      • IDAAS 扩展物理字段使用说明
    • 上游身份数据集成
      • 通讯录身份集成概述
      • 集成连接器配置指南
        • 通讯录集成-泛微
        • 通讯录集成-飞书
        • 通讯录集成-企业微信
        • 通讯录集成-AD
        • 通讯录集成-睿人事
        • 通讯录集成-北森
        • 通讯录集成-SCIM
        • 通讯录集成-用友EHR
        • 通讯录集成-Azure AD
        • 通讯录集成-致远
        • 通讯录集成-LDAP
        • 通讯录集成-数据库
        • 通讯录集成-钉钉
          • 基础说明
          • 钉钉集成连接器如何配置属性映射
      • 通过连接流实现身份集成
        • 在连接流画布中完成身份集成配置
      • 身份集成常见问题
        • 常见问题 & 排错指南
    • 下游身份数据同步
      • 通讯录同步概述
      • 同步连接器配置指南
        • 通讯录同步-企业微信
        • 通讯录同步-AD
        • 通讯录同步-用友U8C
        • 通讯录同步-钉钉
          • 基础说明
          • 如何配置部门职位扩展字段
      • 通过连接流实现身份同步
        • 使用连接流实现身份下游同步
      • 身份同步常见问题
        • 常见问题 & 排错指南
        • 使用代理网关进行身份同步
  • 认证源管理
    • 认证源基础说明
      • 认证源选型说明
      • 认证源管理概述
    • 认证源配置指南
      • 基础协议配置
        • 认证源-CAS协议
        • 认证源-OIDC协议
        • 认证源-OAuth2协议
      • 三方认证源配置手册
        • 认证源-钉钉
        • 认证源-AD
        • 认证源-飞书
        • 认证源-LDAP
        • 认证源-微信
        • 认证源-微信公众号
        • 认证源-Google Workspace
        • 认证源-AD Azure
        • 认证源-美云智数
        • 认证源-企业微信
  • 应用管理
    • 基础说明
      • 应用管理概述
      • 应用创建与配置
    • 应用单点登录
      • 单点登录概述
      • 单点登录配置
      • 单点登出配置
      • 授权范围配置
      • 自定义集成单点登录配置说明
      • 应用密码代填
      • 应用网关
      • 单点登录配置指南
        • 单点登录-OIDC
        • 单点登录-SAML协议
        • 单点登录-OAuth2
        • 单点登录-CAS协议
        • 单点登录-钉钉SSO
        • 单点登录-分贝通
        • 单点登录-用友NCC
        • 单点登录-宜搭
        • 单点登录-泛微OA
        • 单点登录-致远OA
        • 单点登录-金蝶云星空
        • 单点登录-中国电子云邮箱
        • 单点登录-阿里云控制台(RAM)
        • 单点登录-纷享销客应用
        • 单点登录-纷享销客待办
        • 单点登录-Exchange
        • Exchange-双入口配置指南
    • 应用授权管理
      • 应用授权概述
      • 基于组织架构和用户授权
      • 基于角色授权(RBAC)
      • 基于用户属性授权(ABAC)
      • 用户自主申请应用(OA审批授权)权限
    • 应用分发
      • 企业应用分发
      • ABM应用分发
    • 使用应用调用集成平台 OPENAPI
      • M2M接口授权
      • 接口调用权限配置说明
  • 连接中心
    • 产品概述
      • 什么是 AI 连接流
      • AI 连接流的典型使用场景
    • 基础功能
      • 流程运行日志
      • 功能概览
      • 如何创建 AI 工作流
      • 授权凭证管理
      • 错误处理
    • 节点说明
      • 节点基础类型说明
      • 数据处理节点
        • 文本处理节点
        • 数组处理
        • 数据集合节点
      • 文件处理节点
        • 「Base64 转 URL」动作说明
        • 「PPT分页切割」动作说明
      • 应用节点
        • Teambition
        • 金蝶云 K3Cloud
      • 内置节点
        • 子流程调用
        • 缓存处理
        • 分支节点
        • 循环执行
        • MYSQL 触发动作说明
        • 数字签名
        • Webhook触发
        • 缓存列表处理
        • 条件分支
        • FTP
        • 延时节点
        • 模型子节点
        • MCP SERVER 工具
        • 邮件发送
        • 存储子节点
        • 工具子节点
        • HTTP 请求
        • 变量节点
        • 加解密节点
        • 返回变量
      • 运维管理节点
        • 数据校验节点
      • AI节点
        • 构建你的第一个 AI Agent
        • AI 浏览器操作节点
        • AI Agent节点使用指南
        • AI 消息对话节点 & 组件嵌入
  • 审计日志
    • 管理员行为日志
    • 用户变更日志
    • 接口调用日志
    • 用户行为日志
    • 消息发送日志
  • 权限中心
    • 管理员账号管理
    • 管理员角色管理
  • 品牌设置
    • 登录页设置
      • 登录页面配置
      • 登录页CSS自定义页面样式
      • CSS定制页面内容:样式修改指南及故障排除
    • 短信设置
      • 短信模板配置
      • 短信服务使用及签名修改使用指南
      • 短信服务-自定义连接流配置
      • 阿里云短信网关配置指引
    • 邮件设置
      • 邮件模板配置
      • 通过自定义连接流发送邮件
      • SMTP 配置与测试支持文档
    • 企业消息设置
      • 企业消息配置
      • 企业消息(钉钉_飞书)配置
    • 分发页面设置
      • 分发页面设置
  • 平台设置
    • 功能概述
    • 授权管理
    • 代理网关
    • 授权信息
    • 登录策略配置
      • 弱密码检测功能说明
      • 登录流程配置
      • 自动登录功能配置
    • MFA 配置
      • MFA基础配置
      • 使用连接流自定义 MFA 策略
    • 运维日志
      • 运维日志下载
  • 最佳实践
    • AD-LDAP接入指南
    • 第三方平台应用创建指南
      • 钉钉
        • 钉钉全套集成指南
        • 创建钉钉开放平台应用
      • 飞书
        • 飞书全套集成指南
        • 创建飞书开放平台应用
      • 企微
        • 企业微信全套集成指南
        • 创建企业微信开放平台应用
  • 开放接口
    • 鉴权认证
      • 获取access_token(请求体方式)
      • 获取access_token(Basic认证方式)
    • 用户管理
      • 查询用户
      • 创建用户
      • 根据多个条件过滤并查询用户信息
      • 根据用户帐号获取用户信息
      • 修改用户
      • 启用/禁用用户
      • 删除用户
      • 修改用户密码
    • 组织部门
      • 获取组/部门的列表
      • 创建组/部门
      • 根据组/部门ID获取组/部门的信息
      • 修改组/部门
      • 删除组/部门
      • 根据组/部门ID获取下级组/部门信息
      • 过滤部门信息
    • 角色管理
      • 创建角色
      • 获取单个角色详情
      • 修改角色
      • 删除角色
      • 查询角色列表
      • 根据应用ID和用户ID获取角色列表
      • 查看角色所对应的用户列表
      • 给多个用户添加静态角色
      • 删除用户静态角色
      • 获取用户的角色信息
    • 连接中心
      • Webhook启动连接流
    • 事件通知
      • 连接器事件通知
  1. 单点登录配置指南

单点登录-纷享销客待办

概述

本文档详细介绍如何配置纷享销客与专属集成平台之间的待办消息免登功能。此功能允许用户在收到纷享销客待办消息后,点击待办消息可以无需重复登录即可直接进入相应的待办页面,极大地提升用户体验和工作效率。

功能价值

  • 简化用户操作流程:用户点击待办消息后无需额外登录,直接进入待办处理页面
  • 提高工作效率:减少重复登录步骤,加快待办事项处理速度
  • 增强用户体验:流畅的操作体验,降低用户操作门槛
  • 支持多渠道应用:可应用于钉钉等多种消息推送渠道

技术实现原理

该功能通过纷享销客的"自定义认证服务商"功能实现,利用Java代码编写自定义认证逻辑,结合专属集成平台的身份认证服务,实现用户身份自动识别和无缝跳转至指定待办页面。

前提条件

在开始配置前,请确保满足以下条件:

  • 账号准备:
    • 拥有纷享销客管理员账号,具备认证服务商配置权限
    • 拥有专属集成平台管理员账号
  • 用户数据准备:
    • 专属集成平台中已创建相应用户
    • 纷享销客中已创建对应用户
    • 关键:确保纷享销客用户的手机号与专属集成平台中对应用户的手机号保持一致
  • 技术要求:
    • 对Java编程有基本了解,能够理解和修改示例代码
    • 了解OAuth 2.0协议基本原理
    • 对API调用有基本认识

配置步骤

纷享销客配置

创建自定义认证服务商

以管理员身份登录纷享销客管理后台 导航至"系统管理 → 认证服务商"模块 点击"新增认证服务商"按钮,选择提供商类型为"自定义认证服务商" 填写基本信息: - 名称:自定义(建议使用有意义的名称,如"待办免登") - URL后缀:自定义一个标识符(如"todo"),此标识符将用于后续应用的RedirectURIs配置

image.png

创建执行函数

点击"新增执行函数"按钮 填写函数基本信息: - 代码名称:自定义Java代码文件的中文名称(如"待办免登认证函数") - API Name:Java文件名,建议使用英文(如"MobileToDo") - 命名空间:选择"认证提供商" - 绑定对象:选择"不绑定对象" - 描述:简要描述此函数的功能

image.png

image.png

选择代码模板

建议选择"空白模板",以便完全自定义代码逻辑。

image.png

编写执行函数代码

在代码编辑器中编写认证逻辑代码:

image.png

关键代码部分需要修改:

  1. 应用登录地址:修改为专属集成平台的应用登录地址
return "https://您的域名/iam/authorize?response_type=code&" +
      "response_mode=query&" +
      "scope=openid%20profile%20address%20phone%20email%20offline_access&" +
      "redirect_uri=https%3A%2F%2F您的域名.my.fxiaoke.com%2Foauth%2Fsp%2Fcallback%2Ftodo&client_id=您的客户端ID&state="+continueUrl;

image.png

  1. 待办跳转逻辑:根据待办消息传递的参数,处理跳转逻辑
@Override
String redirect(FunctionContext context, Map<String, List<String>> params) {
    log.info("params" + params);
    log.info("context" + context);
    if(params["state"] != null && params["state"].size() > 0 && params["state"].get(0)!=""){
        log.info("333333");
        return params["state"].get(0);
    }else{
        String s = params["continue"].get(0);
        String substring = params["continue"].get(0).substring(74, s.length());
        return "https://www.fxiaoke.com/XV/UI/Home#objdetail/AccountObj/" + substring;
    }
}

image.png

示例:https://{your-domain}.my.fxiaoke.com/oauth/sp/sso/todo?continue= 待办地址两次编码

  1. 自动登出URL:配置登出时跳转的地址
@Override
String logoffUrl(FunctionContext context) {
    return "https://<您的域名>/iam/logout"
}

image.png

  1. 用户信息处理:处理专属集成平台与纷享销客之间的用户匹配

注意:纷享销客登录的用户账号是不带"+86"前缀的手机号,而专属集成平台集成钉钉的用户手机号带有"+86"前缀,需要特殊处理以确保用户匹配

String user = (String)o.content["phone_number"];
if(user.size() == 15){
    user = user.substring(4, 15); // 移除+86前缀
}
log.info(user)

image.png

第三方用户信息获取接口:专属集成平台客户环境获取用户信息接口:https://<您的域名>/iam/userinfo

保存配置

完成代码编辑后,点击保存按钮。系统将生成三个关键URL:

  • 单点登录地址
  • 回调地址
  • 登出地址

image.png

专属集成平台配置

创建应用

登录专属集成平台管理控制台 导航至"应用管理"模块,点击"新建应用",创建用于纷享销客免登的应用

配置应用参数

填写应用基本信息 在RedirectURIs字段中,填入纷享销客生成的回调地址 配置应用授权范围,确定哪些用户可以使用此应用 点击保存完成配置

image.png

待办消息推送配置

向消息推送开发人员提供待办消息跳转URL,格式为:

https://您的域名.my.fxiaoke.com/oauth/sp/sso/todo?continue=待办页面URL两次编码

说明:continue参数是待办详情页的URL,需要进行两次URL编码。参数名称可以根据需要修改,但修改后脚本中的参数名也需要同步修改。

验证与测试

功能测试流程

在钉钉或其他平台接收纷享销客推送的待办消息 点击待办消息链接 系统自动跳转至专属集成平台认证 认证成功后,自动跳转至相应的待办处理页面,验证页面内容是否正确显示对应的待办事项

日志查看

配置完成后,可以通过纷享销客后台查看执行日志:

  1. 在纷享销客后台搜索框中输入"APL"
  2. 查看自定义认证服务商代码的执行日志
  3. 分析日志中的错误信息,确定问题所在

image.png

image.png

image.png

常见问题

可能原因及解决方案: - 检查纷享销客中配置的应用登录地址是否正确 - 验证URL中的client_id是否与专属集成平台应用一致 - 确认redirect_uri是否正确编码 可能原因: - 检查redirect函数中的跳转逻辑是否正确 - 确认continue参数是否正确传递并解析 - 验证continue参数的URL编码是否正确(需两次编码)

<Accordion title="Q:用户认证失败,提示"找不到对应的用户"?" defaultOpen={false}>
这通常是由于用户匹配问题导致:

  • 确认纷享销客中用户的手机号与专属集成平台用户手机号一致
  • 检查代码中对手机号前缀(+86)的处理逻辑是否正确
  • 验证查询PersonnelObj时使用的字段名是否正确
可以通过以下方式进行调试: - 在代码中使用log.info()输出关键变量和状态 - 通过纷享销客后台的APL日志查看执行情况 - 根据日志信息定位和解决问题 可以通过continue参数传递不同的目标URL,并在redirect函数中进行判断: ``` if(continueUrl.contains("AccountObj")) { // 客户相关待办处理逻辑 } else if(continueUrl.contains("OpportunityObj")) { // 商机相关待办处理逻辑 } else { // 默认处理逻辑 } ``` 这些参数来自专属集成平台创建的应用: - client_id对应应用的Client ID - client_secret对应应用的Client Secret - 这些信息可在专属集成平台应用详情页查看

最佳实践

安全建议

  1. 参数安全处理:
    • 对所有用户输入进行严格验证和过滤
    • 防止SQL注入和XSS攻击
    • 避免在日志中打印敏感信息
  2. 凭证保护:
    • 不要在代码中硬编码client_secret等敏感信息
    • 定期更新应用凭证
    • 限制应用权限范围
  3. 异常处理:
    • 完善异常处理逻辑,提供友好的错误提示
    • 记录详细的错误日志,便于问题排查
    • 设置合理的超时和重试策略

性能优化

  1. 减少API调用:
    • 优化认证流程,减少不必要的API调用
    • 考虑添加缓存机制,减少重复请求
  2. 优化查询:
    • 确保PersonnelObj查询使用索引字段
    • 只查询必要的字段,减少数据传输量
  3. 提高响应速度:
    • 设置合理的超时参数
    • 优化代码执行效率
    • 考虑异步处理非关键步骤

用户体验优化

  1. 错误提示:
    • 提供明确的错误提示,帮助用户理解问题
    • 对常见错误提供自助解决方案
  2. 跳转体验:
    • 减少跳转次数,提供流畅的登录体验
    • 添加加载提示,避免用户困惑
  3. 兼容性考虑:
    • 适配不同的终端设备(PC、移动端)
    • 考虑不同网络环境下的用户体验
修改于 2026-05-06 13:02:30
上一页
单点登录-纷享销客应用
下一页
单点登录-Exchange
Built with