上篇讲解营销数据的校准,那么这边来讲解下营销导流后,内容交付后的订单数据获取。
今天的案例展示是明道云与小鹅通的对接,首先了解下小鹅通。小鹅通是一套全功能的内容付费工具,为商家提供了完整的付费内容解决方案。小鹅通提供了音频、视频、图文等多样化的内容付费支持,付费订阅、会员体系、渠道推广、用户运维、数据分析等功能模块。使用小鹅您可以快速、低成本的搭建一个付费频道,引导您的粉丝成为付费订阅用户。通俗的说小鹅通是一款集品牌营销、知识产品交付、用户管理和商业变现为一体的平台。
接入步骤
- 开通应用,开通 API 权限 【填写申请理由,审核通过(工作日 2h 内)】
- 完成权限开通后,登录获取应用信息,并配置 IP 白名单。登录方式: 「小鹅通店铺管理台」- 「营销中心」- 「API 自主开发」- 「云服务控制台」
- 确认需要对接的 API
本篇使用到的 API 如下 (baseUrl:{baseUrl})
- Token 获取接口 {baseUrl}/token
- 批量获取用户信息 {baseUrl}/xe.user.batch.get/1.0.0
- 获取用户详情 {baseUrl}/xe.user.info.get/1.0.0
- 课程列表 {baseUrl}/xe.resource.list.get/1.0.0
- 订单列表 {baseUrl}/xe.order.list.get/1.0.1
- 订单详情 {baseUrl}/xe.order.detail/1.0.0
- 商品详情 {baseUrl}/xe.goods.detail.get/3.0.0
- 商品有效期:{baseUrl}/xe.resource.purchase.get/1.0.0
- 采集信息:{baseUrl}/xe.information.user.result.get/1.0.0
正文
- 应用第三方配置表的设计。效果如图
2.基础数据同步 例如 用户、商品、专栏。基础同步后就不用再次同步了,每次后期只用同步对于的课程即可。
这里只展示用户获取。
var fetch = require('node-fetch');
var params = JSON.parse(input.realParams);
var url=input.url;
params.access_token=input.token;
async function getAll(data){
const res = await fetch(url,{
method:"POST",
headers:
{
"Content-Type": "application/json"
},
body:JSON.stringify(data)
}).then(function(response){
return response.json();
}).catch(function(err){
return {"code":102,"error":"Fetch错误:"+err};
});
const result = await res;
return result;
}
var result=await getAll(params);
var hasnew=false;
if(result.code=="0"){
hasnew=result.data.list.length>0
}
output={result:result,url:url,hasnew:hasnew}
3.基础数据同步后这里开始同步订单数据。使用子流程逐条插入,小鹅通在用户下单之前是需要用户提交个人信息的例如 姓名 手机 职位 公司等。这样工作流逻辑处理下用户是否存在 存在则更新不存在就新用户。逻辑如下
//订单列表
var fetch = require('node-fetch');
var params = JSON.parse(input.realParams);
var url=input.url;
params.access_token=input.token;
params.page_size=50
params.order_by="updated_at:asc";
var btime=new Date(params.begin_time);
var etime=new Date(params.end_time+':59');
var loctime=3600*8;
params.begin_time=((btime.getTime()/1000)-loctime).toString()
params.end_time=((etime.getTime()/1000)-loctime).toString()
async function getAll(data){
const res = await fetch(url,{
method:"POST",
headers:
{
"Content-Type": "application/json"
},
body:JSON.stringify(data)
}).then(function(response){
if(response.ok){
return response.json();
}else{
return {"code":-1,"result_msg":response}
}
}).catch(function(err){
return {"code":102,"error":"Fetch错误:"+err};
});
const result = await res;
return result;
}
var result=await getAll(params);
var hasnext=false;
var hasnew=false;
var lasttime=''
if(result.code=="0"){
hasnew=result.data.list.length>0
hasnext=(result.data.total>(parseInt(params.page_index)*parseInt(params.page_size)))
if(hasnew){lasttime=result.data.list[result.data.list.length-1]["pay_time"];
lasttime=(lasttime==null?'':lasttime.replace(/-/g,'').replace(/ /g,'').replace(/:/g,''))
}
}
output={lasttime:lasttime,result:result,url:url,hasnew:hasnew,hasnext:hasnext,params:params,pstr:JSON.stringify(params)}
//采集信息获取
var fetch = require('node-fetch');
var params = {};
var url=input.url;
params.access_token=input.token;
params.user_id=input.userid;
params.resource_id=input.resource_id;
params.page=1;
params.page_size=50;
async function getAll(data){
const res = await fetch(url,{
method:"POST",
headers:
{
"Content-Type": "application/json"
},
body:JSON.stringify(data)
}).then(function(response){
return response.json();
}).catch(function(err){
return {"code":102,"error":"Fetch错误:"+err};
});
const result = await res;
return result;
}
var result=await getAll(params);
var hasnew=false;
var tempresult={}
if(result.code=="0"){
hasnew=result.data.collection_list.length>0
var resultemp=result.data.collection_list;
if(hasnew){
//var resultemp2= Object.keys(resultemp).sort(function(a,b){ return resultemp[a]["id"]-resultemp[b]["id"];});
tempresult=resultemp[0]
}
}
output={result:result,url:url,hasnew:hasnew,tempresult:tempresult}
所有数据获取后,结合上篇的信息校准,与客户的职位,制定个性化的营销活动及内容吧。
明道云,一如既往的强大。6.5 版本以上线,快快体验吧