钉钉通过手机号获取用户id时遇到的一些坑。

这篇博客介绍了在使用钉钉API时,普通用户与专属帐号员工的区别。对于普通用户,可以通过官方接口直接获取用户URID,而专属帐号员工则需要额外设置`support_exclusive_account_search`参数为true,并且获取用户ID的方式也不同。在开发过程中,注意URL不能多加斜杠,否则会导致错误。此外,文章还提到了URL构建错误可能导致的ApiName不合法问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.普通用户 和 专属帐号员工的区别。
普通用户:通过钉钉提供的官方接口就可以实现

    public static List<String> getUserId (String url, String mobile, String token, List<String> errors) {
        //获取用户urid
        DingTalkClient getUridClient = new DefaultDingTalkClient(url + "/topapi/v2/user/getbymobile");
        OapiV2UserGetbymobileRequest req = new OapiV2UserGetbymobileRequest();
        req.setMobile(mobile);
        req.setHttpMethod("POST");
        OapiV2UserGetbymobileResponse rsp = null;
        try {
            rsp = getUridClient.execute(req, token);
        } catch (Exception e) {
        }
        return rsp.getResult().getExclusiveAccountUseridList();
    }

专属帐号员工:需要注意
首先专属账号需要通过:req.setSupportExclusiveAccountSearch(true);
设置:support_exclusive_account_search参数
并且最后获取用户ID的方式也不一样

    public static List<String> getUserId (String url, String mobile, String token, List<String> errors) {
        //获取用户urid
        DingTalkClient getUridClient = new DefaultDingTalkClient(url + "/topapi/v2/user/getbymobile");
        OapiV2UserGetbymobileRequest req = new OapiV2UserGetbymobileRequest();
        req.setMobile(mobile);
        req.setHttpMethod("POST");
        //【-----这里注意------】
        req.setSupportExclusiveAccountSearch(true);
        OapiV2UserGetbymobileResponse rsp = null;
        try {
            rsp = getUridClient.execute(req, token);
        } catch (Exception e) {
        }
        //【-----这里注意------】
        return rsp.getResult().getExclusiveAccountUseridList();
    }

还有一点:也是开发过程遇到的坑:
拼URL的时候:拼成了"/topapi/v2/user/getbymobile/"
造成了 最后:[submsg=不合法ApiName,ApiName = dingtalk.oapi.v2.user.getbymobile.]
**注意:**正确的URL最后没有/
—>【/topapi/v2/user/getbymobile】

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值