如何获钉钉 API开放平台密钥(分步指南)
在当今数字化转型的浪潮中,企业对于高效、安全且功能丰富的API服务需求日益增长,而钉钉API开放平台正是满足这一需求的佼佼者。作为一款集办公、管理、沟通于一体的企业级应用平台,钉钉不仅为企业提供了全面的数字化解决方案,更通过其API开放平台,为开发者们打开了无限的创新空间。为了帮助广大开发者快速上手并充分利用钉钉API开放平台的强大功能,本文特别推出了“钉钉API开放平台访问token分步指南”。本指南将详细阐述如何一步步获取钉钉API的访问token,这是解锁钉钉API各项服务的关键。通过一系列条理清晰、易于执行的步骤,我们将引导你顺利完成从注册开发者账号到成功获取访问token的全过程。无论你是希望开发企业应用、提升办公效率,还是在数据处理、业务逻辑等方面寻求创新,获取钉钉API的访问token都将是你实现目标的重要一步。
1. 登录/注册钉钉 API开放平台
2. 创建应用
1. 登录钉钉开发者后台。说明只有管理员和子管理员可登录开发者后台。
2.在应用开发页面,选择第三方个人应用,然后单击创建应用。
3.填写应用的基本信息,然后单击确定创建。
4.单击凭证与基础信息获取应用的AppId和AppSecret。
3. 免登接入
建议用户信息保存在前端缓存中(dd.setStorage)或者cookie中,避免每次进入应用都调用钉钉接口进行免登。
1.获取小程序免登授权码。
调用dd.getAuthCode接口获取小程序免登授权码。
免登是指用户进入应用后,无需输入钉钉用户名和密码,应用程序可自动获取当前用户身份登录系统的流程。企业应用和个人应用的免登授权码均可通过该JSAPI获取。
dd.getAuthCode({
success:function(res){
/*{
authCode: 'hYLK98jkf0m' //string authCode
}*/
},
fail:function(err){
}
});
返回说明:
参数 | 说明 |
authCode | 授权码。有效期5分钟,且只能使用一次,使用后会失效。 |
2.获取用户详情。通过sns/getuserinfo_bycode接口获取用户详情信息,详情请参考获取用户基本信息。
示例代码
/**
* Quick-Start示例代码
* 实现了最简单的获取个人身份验证功能
*/
@RestController
public class IndexController {
private static final Logger bizLogger = LoggerFactory.getLogger(IndexController.class);
/**
* 欢迎页面
*/
@RequestMapping(value = "/welcome", method = RequestMethod.GET)
public String welcome() {
return "welcome";
}
/**
* 钉钉用户登录,显示当前登录用户基本信息
* @param authCode 由E应用前端JSAPI获取到的临时授权码
*/
@RequestMapping(value = "/login", method = RequestMethod.POST)
@ResponseBody
public Object login(@RequestParam(value = "authCode") String authCode) {
Long start = System.currentTimeMillis();
ServiceResult serviceResult;
try {
DefaultDingTalkClient client = new DefaultDingTalkClient(URL_GET_USERINFO_BY_CODE);
OapiSnsGetuserinfoBycodeRequest req = new OapiSnsGetuserinfoBycodeRequest();
req.setTmpAuthCode(authCode);
OapiSnsGetuserinfoBycodeResponse response = client.execute(req,Constant.APP_ID,Constant.APP_SECRET);
serviceResult = ServiceResult.success(response.getUserInfo());
return serviceResult;
} catch (Exception e) {
bizLogger.error("loginFailed,authCode"+authCode,e);
serviceResult = ServiceResult.failure("-1",e.getMessage());
//返回结果
}
bizLogger.info("cost:"+(System.currentTimeMillis()-start));
return serviceResult;
}
}
4. 发送消息
开发者可通过消息高效触达用户,通知用户当前行为的结果及状态等,同时可在消息中配置应用内跳转页面地址。当用户查看消息时,在消息卡片点击“进入应用查看”,进入开发者配置的应用内指定页面;
1.开发者在用户提交的form表单上声明属性report-submit="true"
。
说明该属性需要在真机环境下生效。
<form onSubmit="formSubmit" report-submit="true">
<view class="section section_gap">
<view class="section__title">表单类型</view>
<input name="text" maxlength="10" placeholder="最大输入长度10" />
</view>
<view class="btn-area">
<button formType="submit">推送消息</button>
</view>
</form>
2. 通过e.detail.formId
可以获取推送消息临时授权码,在处理onsubmit事件时,需将临时授权码code一起存储到服务器。
formSubmit(e){
// 通过e.detail.formId可以获取到推送消息的临时授权码code
dd.httpRequest({
url: 'http://表单提交的服务端地址?code='+e.detail.formId,
method: 'POST',
headers:{"Content-Type":"application/json"},
data: {
},
dataType: 'json',
success: function(res) {
if(res.data.success){
dd.alert({content:'form表单提交处理成功'});
}else{
dd.alert({title:"form表单提交处理失败",
content:JSON.stringify(res)});
}
},
fail: function(res) {
dd.alert({content: 'form表单提交处理'});
}
});
}
3. 当业务场景需要给用户推送消息时,服务端使用推送消息接口给用户推送消息。
public static String sendMsg() throws RuntimeException {
try {
DefaultDingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/sns/send_msg");
OapiSnsSendMsgRequest req = new OapiSnsSendMsgRequest();
req.setCode(code);
OapiSnsSendMsgRequest.Eapp eapp = new OapiSnsSendMsgRequest.Eapp();
eapp.setImg("@lALPBY0V5EuR4oDNAcrNAs4");
eapp.setContent("非常感谢您的反馈,非常感谢您的反馈。 \n\n"+System.currentTimeMillis());
eapp.setTitle("工单已回复");
eapp.setLink("eapp://page/index?param=aaa");
OapiSnsSendMsgRequest.Msg msg = new OapiSnsSendMsgRequest.Msg();
msg.setMsgtype("eapp");
msg.setEapp(eapp);
req.setMsg(msg);
OapiSnsSendMsgResponse response = client.execute(req,Constant.APP_ID,Constant.APP_SECRET)
} catch (ApiException e) {
bizLogger.error("sendMsg failed", e);
throw new RuntimeException();
}
}
5. 常见问题
Q:如何找到钉钉 API开放平台
A:幂简集成是国内领先的API集成管理平台,专注于为开发者提供全面、高效、易用的API集成解决方案。幂简API平台可以通过以下两种方式找到所需API:通过关键词搜索API(例如,输入’钉钉 API开放平台‘这类品类词,更容易找到结果)、或者从API hub分类页进入寻找。
Q:连接器适用于哪些场景?
A:企业开通使用钉钉的官方应用、钉钉三方企业应用(即钉钉应用市场上的应用)、同时企业已经购买了自有系统,连接器可以实现钉钉的官方应用与钉钉三方企业应用数据互通、钉钉官方应用与企业自有系统数据互通、钉钉三方企业应用与企业自有系统数据互通。
Q:连接器中包含三方连接器和企业自建连接器,应该如何选择?
A:
- 三方连接器:三方连接器需要你的组织完成服务商认证。在创建连接器的时候,需要选择关联的应用,如果你创建连接器关联的应用已经在钉钉的应用市场上架,可直接开始创建连接器。
- 自建连接器:自建连接器不需要你的组织进行服务商认证,是企业的开发者即可使用。
Q:企业客户在哪里可以开通使用?
A:如果你购买的钉钉第三方企业应用已经创建了连接器应用,可以在开发者后台 > 连接平台 > 自建连接流中直接开通授权适用。
Q:连接器和应用开放的API是什么关系?
A:连接器本质是一组API的集合。API通过声明触发事件和执行动作配置成为了连接器。连接器包括触发事件、执行操作、数据模型。目前连接器主要支持不同应用之间发送和接收数据。例如,当在销帮帮中新签订一个客户订单的时候,同步客户数据、订单数据到BOSS管账中。
除了钉钉 API开放平台,还有其他替代服务商也提供类似api服务,例如:
yosmart API开放平台、Homey API开放平台、plumsail API开放平台
更多竞品可以在幂简集成开放平台中找到。
Q:钉钉 API开放平台这个密钥还适用于哪些api?
获取用户token、获取第三方应用授权企业的accessToken、获取企业开通应用后的授权信息
6. 总结
本文“钉钉API开放平台访问token分步指南”为开发者们提供了一份详尽而实用的操作指南,旨在帮助他们轻松获取并有效利用钉钉API开放平台的强大功能。从注册开发者账号、完成身份认证,到最终成功获取访问token,每一步操作都进行了详细阐述,并配以清晰的步骤说明,确保开发者能够顺利完成整个流程。我们深知,获取访问token只是利用钉钉API的第一步。因此,在本文中,我们也特别强调了获取token后应进行集成测试和可用性验证的重要性。这是确保API能够顺利集成到应用中,并发挥最佳效果的关键环节。通过测试,开发者们可以及时发现并解决潜在的问题,为后续的开发工作奠定坚实的基础。本文为开发者们搭建了一个便捷的桥梁,帮助他们成功接入钉钉API开放平台,将这一强大的企业级服务转化为实际应用的价值。我们相信,通过本文的指导,开发者们将能够更加高效、便捷地利用钉钉API开放平台的资源,推动项目的创新与发展,提升应用的性能和用户体验,为企业数字化转型注入新的活力。