企业出于安全考虑,需要在修改功能或登录密级较高的页面时,对成员进行二次身份校验

企业需要双因子认证时,可以怎么操作?

该组件仅适用于私有化WPS365版本

1. 方案概述

一般来讲,用户登录的安全认证分为两种:

  • 单因子认证:用户只需提供一种认证因子来登录,通常是账号密码、微信扫码、短信验证码等。
  • 双因子认证:用户需要提供两种不同认证因子来登录,通常是账密+其它形式的身份验证,其他形式比如短信验证码、安全令牌等,具体选择通过后台配置实现。

文档中心使用的是单因子认证的方式。

出于安全考虑,企业需要在修改定制应用功能前,比如修改消息审计、全局配置前。

或登录密级较高的页面时,对成员进行二次身份校验。

针对这种情况,我们可以使用文档中心管理后台的开放能力,定制双因子认证

实现效果用户登录管理后台时,页面会跳出窗口,提醒用户绑定二次认证。SWUUONRAABQDW
支持端文档中心管理后台
涉及接口获取当前会话信息
版本限制版本24-12a(含)以上
操作系统限制支持X86、XC

2. 扩展应用对接

👉接口依赖

扩展应用中选择应用依赖,添加对应的接口依赖

R45EEYA5AAAGK

根据接口文档,选择对应云文档V7所需依赖的接口

SAAUKYA5AAAEK

👉接口能力

在扩展应用中新建独立服务型组件,选择接口能力并新增API,

Z4JJAWY5ABAE4

根据弹框中提示信息进行接口填写,请求方法GET,网关类型为c或proxy网关

PL6FIYA5AAAGW

👉接口详情

参考对应的接口文档

接口类型:365api内部网关

MethodGET
Path/v7/sessions/current
网关365api内部网关
认证kso_token或者access_token
Request见下方代码块
Response见下方代码块

Request:

{
  "with_detail": boolean
}

1
2
3

Response:

{
  "data": {
    "account": "string",
    "avatar": "string",
    "company_id": "string",
    "ctime": 0,
    "gender": {},
    "login_mode": "string",
    "multi_factor_auth": true,
    "nick_name": "string",
    "regtime": 0,
    "role": {},
    "status": {},
    "user_id": "string"
  },
  "code": 0,
  "more": {},
  "msg": "string"
}

👉演示效果

kso_token鉴权方式

💡 提示

365api内部网关支持通过kso_token方式直接调用,kso_token可以通过proxy网关将前端的cookie转为kso_token

// 调用云文档获取用户信息
func (u *UserInfoService) GetUserInfo(token string) (*interApiModal.UserInfo, error) {
    host := config.GlobalConfig.ECIS_HOST
    url := host + "/v7/sessions/current?with_detail=true"
    header := map[string]string{
        "X-Kso-Token": token,
    }

    res, err := util.Get(url, header)
    if err != nil {
        log.Info("获取用户信息网络请求错误:", errors.Any("err", err))
        return nil, err
    }

    if res != nil && res.Body != nil {
        defer res.Body.Close()
    }

    var respBody []byte

    if res.StatusCode != 200 {
        if res.Body != nil {
            respBody, _ =https://v7.wpseco.cn/c/manage/docs#/appDocs/wps365.open.docs/%E6%9C%8D%E5%8A%A1%E7%AB%AF/%E8%AE%A4%E8%AF%81%E4%B8%8E%E6%8E%88%E6%9D%83/%E8%8E%B7%E5%8F%96%E8%AE%BF%E9%97%AE%E5%87%AD%E8%AF%81/%E8%8E%B7%E5%8F%96%E8%87%AA%E5%BB%BA%E5%BA%94%E7%94%A8%E7%9A%84%E7%A7%9F%E6%88%B7access_tokehttps://v7.wpseco.cn/c/manage/docs#/appDocs/wps365.open.docs/%E6%9C%8D%E5%8A%A1%E7%AB%AF/%E8%AE%A4%E8%AF%81%E4%B8%8E%E6%8E%88%E6%9D%83/%E8%8E%B7%E5%8F%96%E8%AE%BF%E9%97%AE%E5%87%AD%E8%AF%81/%E8%8E%B7%E5%8F%96%E8%87%AA%E5%BB%BA%E5%BA%94%E7%94%A8%E7%9A%84%E7%A7%9F%E6%88%B7access_tokenio.ReadAll(res.Body)
            log.Info("状态码错误:", errors.Any("err", string(respBody)))
        }
        return nil, fmt.Errorf("获取用户信息网络请求失败")
    }

    respBody, err = io.ReadAll(res.Body)

    if err != nil {
        log.Info("获取用户信息读取流错误:", errors.Any("err", err))
        return nil, err
    }
    v7UserInfo := &V7UserInfoRes{}
    err = json.Unmarshal(respBody, v7UserInfo)
    if err != nil {
        log.Info("获取用户信息转json错误:", errors.Any("err", err))
        return nil, err
    }

    if v7UserInfo.Code != 0 {
        log.Info("获取用户信息错误:", errors.Any("err", v7UserInfo.Data))
        return nil, fmt.Errorf("获取用户信息失败")
    }

    return &v7UserInfo.Data, nil
}
access_token鉴权方式
// 获取acc_token
wps365Token, err := auth.NewWps365AuthTokenCache().GetAccessToken(config.GlobalConfig.AK, config.GlobalConfig.SK, companyId)
if err != nil {
    log.Info("获取wps365Token失败", errors.String("error", err.Error()))
    return nil, err
}

// 获取KSO-1签名
ksoSignService, _ := auth.NewKsoSign(config.GlobalConfig.AK, config.GlobalConfig.SK)
ksoSign, err := ksoSignService.KSO1Sign(request, jsonData)
if err != nil {
    log.Info("获取KSO-1签名失败", errors.String("error", err.Error()))
    return nil, err
}
识别双因子认证

multi_factor_auth

根据multi_factor_auth字段来判断双因子认证

  • multi_factor_auth为null,则说明未开启双因子认证
  • multi_factor_auth为true,则说明开启双因子认证且用户已经双因子认证通过
  • multi_factor_auth为false,则说明开启双因子认证且用户未通过双因子认证

相关新闻

  • 自定义文件列表右键菜单项

    自定义文件列表右键菜单项

    企业需要在文件列表的右键菜单栏中,新增其它定制菜单项 如何在文件列表新增右键菜单项? 本定制方案仅适用于私有化WPS365版本 1. 方案概述 有时候,企业需要给不在组织通讯录中的成员共享文档,传统流程是把文档下载下来,通过邮件发送,易导致效率瓶颈。 现在,通过文档中心的扩展能力,可以直接在文件列表右键菜单新增自定义分享弹窗入口,简化协作流程。 这一功能不仅支持自定义分享弹窗,企业也可根据实际需要,在文件列表的右键菜单栏中,新增其它定制菜单项。 我们可以使用文档中心Web端(PC端)的开放能力,…

    最佳实践 2025年12月11日
  • 文档中心主题皮肤定制

    文档中心主题皮肤定制

    将企业主题色融入WPS365产品界面,使之与企业风格更为统一 如何为文档中心定制主题皮肤? 本定制方案仅适用于私有化WPS365版本 1. 方案概述 主题皮肤就是文档中心提供的界面颜色,下图为文档中心标准产品的主题皮肤: 出于以下需求的考虑,客户可能会需要定制个性化的主题皮肤: 实现效果 深色模式浅色模式护眼模式跟随系统模式注:以上展示的【深色】【浅色】【护眼】模式的具体颜色效果由客户自己定义,上图仅作参考示例 依赖端 文档中心PC端 依赖版本 23.0907(含)以上 依赖操作系统 支持X86…

    最佳实践 2025年12月11日
  • 扩展文件属性字段

    扩展文件属性字段

    企业需要在文件属性后打标签,方便后续查找和管理文件。

    最佳实践 2025年12月11日
  • 新增自定义侧边栏菜单

    新增自定义侧边栏菜单

    企业想把文档中心上定制的新功能放在文档中心上,可以将入口放在文档中心左侧Tab栏

    最佳实践 2025年12月11日
  • 文档中心欢迎页定制

    文档中心欢迎页定制

    在文档中心登录前进行品牌展示,为满足企业或组织的的个性化需求 如何为文档中心定制欢迎页? 该组件仅适用于私有化WPS365版本 1. 方案概述 欢迎页是由客户自己设计和定义的独立页面,可以在文档中心登录前进行品牌展示。 总的来说,欢迎页的内容客户可以根据自己的需求自行设计,通常比较高频的使用方式有: 如果没有定制欢迎页,客户在登录文档中心时,会直接进入文档中心登录页,输入账号和密码进行登录。 客户定制了文档中心欢迎页之后,遇到需要登录的场景,会先跳转进入企业欢迎页,在欢迎页进行相关操作(例如:点…

    最佳实践 2025年12月11日
  • 文档中心定制功能多语言适配

    文档中心定制功能多语言适配

    满足企业的多语言需求,为文档中心的定制功能提供多语言适配方案。

    最佳实践 2025年12月11日

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

立即咨询 企业版试用 上门服务

请您留言

感谢您的关注,你可留下联系方式,我们将第一时间与您联系。