订阅消息 data.thing1.value is emtpy

本文档记录了一位开发者在微信小程序发送订阅消息时遇到的问题及解决过程。问题主要涉及请求参数错误、格式不符和内容不合规。通过调整代码,将键值对格式修正,并确保内容符合文档要求,最终解决了问题。特别地,注意到value字段的内容必须按文档规定填写,不能使用纯数字,而应使用中文或其他有效格式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目场景:

微信小程序发送订阅消息
文档连接:https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/subscribe-message/subscribeMessage.send.html

在这里插入图片描述


问题描述

一请求接口一直返回 data.thing1.value is emtpy


原因分析:

经过分析发现主要原因有以下三点:
1、请求参数错误,字符串被二次JSON导致
在这里插入图片描述
2、格式错误,文档要求键值对形式,key一定要对应上,值都是value
在这里插入图片描述
3、内容有问题,没有按照文档要求
在这里插入图片描述


解决方案:

测试demo代码如下

Map<String, String> dataMap = new HashMap<>();
        JSONObject thing = new JSONObject();
        thing.put("value", "测试数据");
        dataMap.put("thing1", JSONObject.toJSONString(thing));
        JSONObject name = new JSONObject();
        name.put("value", "123");
        dataMap.put("name2", JSONObject.toJSONString(name));

上面代码输出结果为:
{“name2”:“{\“value\”:\“123\”}”,“thing1”:“{\“value\”:\“测试数据\”}”}

后代码调整为如下:

 Map<String, Object> dataMap = new HashMap<>();
        JSONObject thing = new JSONObject();
        thing.put("value", "测试数据");
        dataMap.put("thing1", thing);
        JSONObject name = new JSONObject();
        name.put("value", "123");
        dataMap.put("name2", name);

输出结果为:
{“name2”:{“value”:“123”},“thing1”:{“value”:“测试数据”}}

到这里请求参数data没有问题了,再有问题就是value没有按照文档需求。
详细参考顶部链接:https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/subscribe-message/subscribeMessage.send.html

再失败
在这里插入图片描述
结果发现是我输入的数字,大意了。改成中文之后,就成功了
在这里插入图片描述

订阅消息发送成功,到这里就结束了。

/************************************************************* date: April 2017 copyright: Zhu En DO NOT distribute this code without my permission. **************************************************************/ // 循环顺序的队列实现文件 ///////////////////////////////////////////////////////// #include <stdio.h> #include <stdlib.h> #include "SeqQueue.h" SeqQueue* SQ_Create(int maxlen) // 创建顺序队列, 队列最多存储maxlen个队列元素。 { SeqQueue* sq=(SeqQueue*)malloc(sizeof(SeqQueue)); sq->data=(T*)malloc(sizeof(T)*(maxlen+1)); sq->front=sq->rear=0; sq->max=maxlen+1; return sq; } void SQ_Free(SeqQueue* sq) // 释放队列空间,以删除队列。 { free(sq->data); free(sq); } void SQ_MakeEmpty(SeqQueue* sq) // 将队列置空。 { sq->front=0; sq->rear=0; } bool SQ_IsEmpty(SeqQueue* sq) // 判断队列是否为空,为空返回true,否则返回false。 { // 请在Begin-End之间补充代码,完成队列是否为空的判断。 /********** Begin *********/ /********** End **********/ } bool SQ_IsFull(SeqQueue* sq) // 判断队列是否为满。为满返回true,否则返回false。 { // 请在Begin-End之间补充代码,完成队列是否为满的判断。 /********** Begin *********/ /********** End **********/ } int SQ_Length(SeqQueue* sq) // 队列长度。 { // 请在Begin-End之间补充代码,获取队列长度。 /********** Begin *********/ /********** End **********/ } bool SQ_In(SeqQueue* sq, T x) // 将x入队。若入队失败(队列满),则返回false,否则返回true。 { // 请在Begin-End之间补充代码,将 x 入队。 /********** Begin *********/ /********** End **********/ } bool SQ_Out(SeqQueue* sq, T& item) // 从队列sq出队一个元素,返回时item为出队的元素的值。若出队成功(队列不为空),则返回true,否则(队列空),返回false,此时item不会返回有效值。 { // 请在Begin-End之间补充代码,完成元素出队操作。 /********** Begin *********/ /********** End **********/ } bool SQ_Head(SeqQueue* sq, T& head) // 获取队列头结点元素,返回时head保存头结点元素。 // 若获取失败(队列空),则返回值为false,否则返回值为true。 { if ( SQ_IsEmpty(sq) ){ return false; } else { head = sq->data[sq->front]; return true; } } void SQ_Print(SeqQueue* sq) // 依次打印出队列中的每个元素。 { int i=sq->front; if (SQ_IsEmpty(sq)) { printf("queue is emtpy")
最新发布
03-30
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值