小程序后端对接腾讯有数

2024-03-17 21:30
文章标签 程序 对接 腾讯 有数

本文主要是介绍小程序后端对接腾讯有数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

腾讯生态品牌商家小程序经营分析与数据资产管理平台

有数官方文档 小程序新增授权 | 技术文档

一、概述

  • 小程序订单,创单成功后,订单信息同步到腾讯有数(时效五分钟)
  • 小程序订单状态更改(已支付取消,未支付取消,支付完成、发货、订单完成),需同步到腾讯有数
  • 每天 6:00 前完成前一天的汇总订单数据上报
  • 微信接口 数据拉取、 数据上报(每天十点拉取数据,十一点之前上报完成)

二、业务流程

  1. 获取/新增数据仓库
    1. 调用微信接口推送数据时,需要对应的数据仓库id
  2. 微信数据上报 
    1. 定时任务 每天十点开始拉取 微信页面访问、访问分布数据,成功后,数据入库,并调用腾讯有数数据上报接口,上传成功更新推送记录表, 如果获取失败则一直重试到10:30,如果超过时间则告警
  3. 小程序订单创建 数据上报
    1. 订单创建成功,先数据埋点,然后上报到腾讯有数,时效性为5分钟
    2. 正常流转时序图
    3. 失败补偿流程(初步设计 30s 轮询一次)
      1. 考虑到目前订单量较少,30s轮询间隔,单线程可以满足当前需求
      2. 每次轮询查询结果条数控制在50条内,以防止出现异常情况下,定时任务阻塞(异常情况,如出现大量失败情况,可增加处理线程,快速消耗积压任务)
  4. 小程序订单汇总
    1. 每天 6:00 前完成前一天的数据上报。我们定时任务配置为5点上传
  1. 小程序订单状态更改 数据上报
    1. 在订单取消,支付成功、订单发货、订单完成出进行数据埋点,当订单状态发生改变时,进行上报处理
    2. 正常流转时序图
    3. 失败补偿流程图(定时任务 30秒一次)

三、数据库表设计

  1. 推送订单相关表
    1.  ER图
      1. t_store_youshu_request
    2. SQL
      1. response_info 推送有数响应结果(包含正常响应和异常结果,如请求超时等情况)CREATE TABLE public.t_store_youshu_request (
        id int4 NOT NULL,
        order_id int8 NULL,
        order_code varchar(50) NULL,
        order_source int4 NULL,
        push_type varchar(10) NULL,
        status int4 NULL,
        push_num int4 NULL,
        request_info text NULL,
        response_info text NULL,
        create_time timestamp NOT NULL DEFAULT now(),
        last_modify_time timestamp NOT NULL DEFAULT now(),
        total numeric NULL,
        CONSTRAINT t_store_youshu_request_pkey PRIMARY KEY (id)
        );
        CREATE INDEX idx_youshu_request_create_time ON t_store_youshu_request USING btree (create_time);
        CREATE INDEX idx_youshu_request_order_code ON t_store_youshu_request USING btree (order_code);
        CREATE INDEX idx_youshu_request_order_id ON t_store_youshu_request USING btree (order_id);
        CREATE INDEX t_store_youshu_request_status_idx ON t_store_youshu_request USING btree (status, push_num);comment on column t_store_youshu_request.order_id is '订单id';
        comment on column t_store_youshu_request.order_code is '订单code';
        comment on column t_store_youshu_request.order_source is '订单来源 1:小程序 2:APP 3:官网';
        comment on column t_store_youshu_request.push_type is '推送类型 1110待支付,1150已支付待发货,1160已发货,1180完成';
        comment on column t_store_youshu_request.status is '推送状态 0:未处理1:成功 2:失败 3:超时';
        comment on column t_store_youshu_request.push_num is '推送次数';
        comment on column t_store_youshu_request.request_info is '推送数据';
        comment on column t_store_youshu_request.response_info is '推送响应数据';
        comment on column t_store_youshu_request.create_date is '创建时间';
        comment on column t_store_youshu_request.total IS '订单金额(支付金额)';
        comment on column t_store_youshu_request.last_modify_time IS '最后修改时间';
  2. 微信数据请求/推送记录表
    1. ER图
      1. t_store_youshu_pv 推送有数响应结果(包含正常响应和异常结果,如请求超时等情况)
    2. SQL
      1. CREATE TABLE IF NOT EXISTS t_store_youshu_pv (
            id bigint PRIMARY KEY ,
            weixin_response_info text,
            youshu_response_info text,
            status integer,
            create_date TIMESTAMP,
            last_modify_time TIMESTAMP
        );
        CREATE INDEX t_store_youshu_pv_create_time_idx ON t_store_youshu_pv USING btree (create_time);

        comment on column t_store_youshu_pv.weixin_response_info is '获取到的有数页面访问数据';
        comment on column t_store_youshu_pv.youshu_response_info is '推送有数响应结果';
        comment on column t_store_youshu_pv.status is '推送状态 0:未处理 1:成功 2:失败';
        comment on column t_store_youshu_pv.create_date is '创建时间';
        comment on column t_store_youshu_pv.last_modify_time is '最后修改时间';

四、踩坑总结

1.提前和有数沟通好要做哪些类型的数据上报,比如商品,再比如取消订单等,否则会影响测试结果2.如果有功能点测试不通过,则需要该异常 修复之后重新提测时 需要上传10条或以上条数据到有数3.不同颜色商品 spu_id不一致,有数会认为测试不通过,我们后来改传style款号,前后端要一致4.测试或者提测 有数时 上传有数订单 商品数量需要有多件的订单行数据 也就是 goods_num=1 和 goods_num !=1
5.有数平台数据上传符合要求会有绿色对号成功小图标,但是不代表ok了,需要有数公众号手动提测给有数 6.有数数据仓库id第一次获取之后写死本地,不要再每次上传之前请求接口获取,有数获取仓库id接口不稳定7.有数官方文档有dataSourceType字段,如果之前有添加过仓库id,按照不同业务场景传递不同参数再次添加会返回错误,所以仓库id需要全站共用8.沙箱环境测试ok之后,需要添加连接有数生产环境的密钥参数,如 APP ID  和  APP Secret区分环境 。merchantId(不区分环境)

这篇关于小程序后端对接腾讯有数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/820225

相关文章

将Java程序打包成EXE文件的实现方式

《将Java程序打包成EXE文件的实现方式》:本文主要介绍将Java程序打包成EXE文件的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录如何将Java程序编程打包成EXE文件1.准备Java程序2.生成JAR包3.选择并安装打包工具4.配置Launch4

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

如何用java对接微信小程序下单后的发货接口

《如何用java对接微信小程序下单后的发货接口》:本文主要介绍在微信小程序后台实现发货通知的步骤,包括获取Access_token、使用RestTemplate调用发货接口、处理AccessTok... 目录配置参数 调用代码获取Access_token调用发货的接口类注意点总结配置参数 首先需要获取Ac

基于Python开发PDF转Doc格式小程序

《基于Python开发PDF转Doc格式小程序》这篇文章主要为大家详细介绍了如何基于Python开发PDF转Doc格式小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用python实现PDF转Doc格式小程序以下是一个使用Python实现PDF转DOC格式的GUI程序,采用T

将java程序打包成可执行文件的实现方式

《将java程序打包成可执行文件的实现方式》本文介绍了将Java程序打包成可执行文件的三种方法:手动打包(将编译后的代码及JRE运行环境一起打包),使用第三方打包工具(如Launch4j)和JDK自带... 目录1.问题提出2.如何将Java程序打包成可执行文件2.1将编译后的代码及jre运行环境一起打包2

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

EMLOG程序单页友链和标签增加美化

单页友联效果图: 标签页面效果图: 源码介绍 EMLOG单页友情链接和TAG标签,友链单页文件代码main{width: 58%;是设置宽度 自己把设置成与您的网站宽度一样,如果自适应就填写100%,TAG文件不用修改 安装方法:把Links.php和tag.php上传到网站根目录即可,访问 域名/Links.php、域名/tag.php 所有模板适用,代码就不粘贴出来,已经打

跨系统环境下LabVIEW程序稳定运行

在LabVIEW开发中,不同电脑的配置和操作系统(如Win11与Win7)可能对程序的稳定运行产生影响。为了确保程序在不同平台上都能正常且稳定运行,需要从兼容性、驱动、以及性能优化等多个方面入手。本文将详细介绍如何在不同系统环境下,使LabVIEW开发的程序保持稳定运行的有效策略。 LabVIEW版本兼容性 LabVIEW各版本对不同操作系统的支持存在差异。因此,在开发程序时,尽量使用