内容营销平台对接案例--小鹅通

集成 API系统集成第三方  收藏
1 / 2290

上篇讲解营销数据的校准,那么这边来讲解下营销导流后,内容交付后的订单数据获取。

今天的案例展示是明道云与小鹅通的对接,首先了解下小鹅通。小鹅通是一套全功能的内容付费工具,为商家提供了完整的付费内容解决方案。小鹅通提供了音频、视频、图文等多样化的内容付费支持,付费订阅、会员体系、渠道推广、用户运维、数据分析等功能模块。使用小鹅您可以快速、低成本的搭建一个付费频道,引导您的粉丝成为付费订阅用户。通俗的说小鹅通是一款集品牌营销、知识产品交付、用户管理和商业变现为一体的平台。

接入步骤

  1. 开通应用,开通 API 权限 【填写申请理由,审核通过(工作日 2h 内)】

  1. 完成权限开通后,登录获取应用信息,并配置 IP 白名单。登录方式: 「小鹅通店铺管理台」- 「营销中心」- 「API 自主开发」- 「云服务控制台」
  2. 确认需要对接的 API

本篇使用到的 API 如下 (baseUrl:{baseUrl})

正文

  1. 应用第三方配置表的设计。效果如图

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 版本以上线,快快体验吧

  1. 明道云
  2. V6.5 版本更新功能介绍
  3. 小鹅通开发平台