php对接小鹅通API开发高级实战案例解析:获取指定资源学习记录信息(单人单学习记录、单人多学习记录累计、返回数据格式确认)

简介: php对接小鹅通API开发高级实战案例解析:获取指定资源学习记录信息(单人单学习记录、单人多学习记录累计、返回数据格式确认)

前言

开发使用小鹅通API的时候,以下是一些需要注意的事项:


  1. 了解API文档:在开始开发之前,仔细阅读小鹅通的API文档,了解可用的接口和功能。熟悉文档中的请求参数和响应格式是非常重要的。
  2. 身份认证:使用小鹅通API,一般需要进行身份认证,获取访问令牌(Access Token)。确保在每次请求API时,都使用有效的访问令牌进行身份认证。
  3. API调用频率限制:小鹅通对API调用有一定的频率限制,确保你的应用程序在调用API时不会超过限制。若超过限制,可能会导致API调用失败或被临时封禁。
  4. 错误处理:在使用API时,要处理可能出现的错误情况。小鹅通的API会返回特定的错误码和错误信息,确保你的应用程序能正确处理这些错误,以提供更好的用户体验。
  5. 数据安全:在处理用户数据时,要注意数据的安全性和隐私保护。确保使用合适的加密和安全措施来保护用户数据。
  6. 版本控制:小鹅通的API可能会有更新和改动,确保你的应用程序使用的是最新的API版本,并及时更新你的代码以适应可能的变化。
  7. 测试和监控:在开发过程中,进行充分的测试,确保API调用的正确性和稳定性。同时,设置适当的监控机制,及时发现和解决潜在的问题。


一、获取指定资源学习记录信息请求方式及url


请求方式:POST

请求头:Content-Type:application/json

接口地址:https://api.xiaoe-tech.com/xe.user.leaning_record_by_resource.get/1.0.0

频率限制:10秒3000次

备注:数据是准实时的,4~5分钟延迟


二、获取指定资源学习记录信息请求参数

请求参数

1690264938451.png


请求格式

 { 
     "access_token" : "xxxxxxxx", 
     "resource_id" : "xxxxxx", 
     "data" : { 
          "search_max_learn_progress" : 90, 
          "list" : [
               "xxxx"
          ]
     },
    "page": 1,
    "page_size": 10
 }


三、单人单学习记录API封装函数

/*获取指定资源学习记录信息
 * 频率限制:10秒3000次
 * 备注:数据是准实时的,4~5分钟延迟
 * resource_id,是,资源id;
 * list,是,user_id数组,上限100, 如果传空数组,则代表所有用户;
 * data.search_max_learn_progress,最小完成百分比,添加后会筛选出来max_learn_progress > {指定值}的学习记录,值:0-100
 * data.stay_time,否,该资源的看课学习时长,添加后会筛选出来stay_time >= {指定值}的学习记录
 * By WoodCutter 2023-05-25
 * 返回参数
 * learn_progress,最近一次学习进度 0-100;
 * is_finish,是否已学完 1-已学完;
 * stay_time,学习时长,单位秒;
*/
function getUserLearnRecord($resource_id, $user_list)
{
    require_once './libs/Client.php';
    $client = new Client();
    $url = "https://api.xiaoe-tech.com/xe.user.leaning_record_by_resource.get/1.0.0";
    $method = "post";
    $data = array("search_max_learn_progress" => 0,
        "stay_time" => 0,
        "list" => $user_list);
    $params = ["resource_id" => $resource_id, 'data' => $data];
    $result = $client->request($method, $url, $params);
    return json_encode($result);
}


四、单人多学习记录API封装函数

将资源ID,组成数组格式:

$resource_list = ['l_6498027fe4b0cf39e6dc560b','l_64980f01e4b0f2aa7dfca5aa', 'l_64980fc3e4b0cf39e6dc5e90', 'l_64981fb6e4b0b0bc2bf7b35e'];


遍历$resource_list每次的单人单学习记录API封装函数,然后将stay_time进行累计。

举例如下:

获取的小鹅通学习记录数据(模拟数据)

$data = [
    ['code' => 0, 'data' => ['list' => ['stay_time' => 7]]],
    ['code' => 1, 'data' => ['list' => ['stay_time' => 8]]],
    ['code' => 0, 'data' => []],
    ['code' => 0, 'data' => ['list' => ['stay_time' => 9]]],
];


计算如下:

  • ‘code’ => 0,代表正常返回,不返回不计算;
  • ‘data’ => [],代表能返回数据,不返回数据不计算;
  • $v['code'] == 0 && !empty($v['data']),即保证返回数据格式。


$total_time = 0;
foreach ($data as $k => $v) {
    //var_dump($v['code']);
    if ($v['code'] == 0 && !empty($v['data'])) {
        $stay_time = $v['data']['list']['stay_time'];
        //echo $stay_time . "<br>";
        $total_time += $stay_time;
    }
}

总结

在小鹅通API对接的过程中,token是否超限超时过期、API接口是否超限都有特定的返回码,凭据返回码来确定下步的操作如何安排:是否入库,是否跳转页面,不能直接使用cpde=0正常码来直接进行操作。同时,尽量把小鹅通和本地代码的交互生成日志,便于快速查询问题。


@漏刻有时

相关文章
|
30天前
|
监控 算法 API
电商API接口对接实录:淘宝优惠券接口对接处理促销监控系统
在电商开发中,淘宝详情页的“券后价计算”是极易出错的环节。本文作者结合实战经验,分享了因忽略满减券门槛、有效期、适用范围等导致的踩坑经历,并提供了完整的解决方案,包括淘宝API签名生成、券后价计算逻辑、常见坑点及优化建议,助力开发者精准实现券后价功能,避免业务损失。
|
1月前
|
监控 算法 API
电商API接口实录对接:1688混批价格函数处理
本文分享了作者近十年电商开发中对接1688商品详情API的实战经验,涵盖权限申请、签名验证、阶梯价格、库存解析及限流控制等关键问题,并提供Python代码示例,助力开发者高效应对1688开发中的挑战。
|
2月前
|
JSON 监控 网络协议
干货分享“对接的 API 总是不稳定,网络分层模型” 看电商 API 故障的本质
本文从 OSI 七层网络模型出发,深入剖析电商 API 不稳定的根本原因,涵盖物理层到应用层的典型故障与解决方案,结合阿里、京东等大厂架构,详解如何构建高稳定性的电商 API 通信体系。
|
2月前
|
边缘计算 监控 Java
跨境电商 API 对接避坑指南:亚马逊 SP-API 超时问题的 5 种解决方案(附重试代码模板)
在对接亚马逊 SP-API 时,超时问题常导致订单延迟、库存失败,影响运营。本文总结某 3C 品牌实战经验,详解超时的 3 大根源与 5 大解决方案,涵盖动态超时、重试机制、请求拆分、并发控制与边缘加速,并附可复用 Python 代码,助你将超时率从 20% 降至 1% 以下。
|
28天前
|
人工智能 JSON 算法
抖音电商 API 赋能,抖音平台达人合作数据精准对接
抖音电商API为品牌与达人合作提供精准数据对接,提升匹配效率与营销精准度,助力电商生态智能化升级。
122 1
|
1月前
|
监控 安全 BI
电商 API 助力,多平台物流信息无缝对接
在电商多平台运营中,物流信息割裂导致效率低下、客服压力大。通过API技术,可实现订单抓取、状态同步与数据聚合,打通电商平台、快递系统与商家ERP,提升运营效率与用户体验。
100 0
|
2月前
|
监控 数据可视化 API
低代码平台对接API:无需编程快速搭建电商数据中台
低代码平台助力电商企业快速搭建数据中台,通过可视化操作整合京东、淘宝等多平台API,实现库存监控、价格对比、订单分析等功能,降低技术门槛,提升运营效率。
|
6月前
|
算法 测试技术 C语言
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
605 29
|
6月前
|
前端开发 数据安全/隐私保护 CDN
二次元聚合短视频解析去水印系统源码
二次元聚合短视频解析去水印系统源码
178 4
|
6月前
|
JavaScript 算法 前端开发
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

推荐镜像

更多
  • DNS