修改频道商品信息
接口描述
1、编辑频道商品库商品信息
2、(channelId, timestamp, appId)参与sign签名,并和sign一起通过url传递,请求体参数不参与签名,通过post请求体传递【请设置请求头contentType:application/json】
3、接口支持https协议
接口URL
http://api.polyv.net/live/v3/channel/product/update
请求方式
POST
接口约束
1、接口同时支持HTTP 、HTTPS ,建议使用HTTPS 确保接口安全,接口调用有频率限制,详细请查看
请求参数描述
请求体参数描述
productId
true
Integer
商品库商品productId
name
true
String
商品名称,必填,长度范围:1-100 注:接口可支持100字符,直播后台设置仅支持50个字符
status
true
Integer
商品上下架状态 1:上架状态 2:下架状态
linkType
true
Integer
商品链接类型 10:通用链接 11:多平台链接
cover
false
String
商品封面链接,长度范围:1-500
yield
false
String
金融商品参数,产品收益率/价格,如:87.99%
realPrice
false
Float
普通商品参数,商品类型为普通商品时必传,商品购买价格,保留两位小数,如:0.01
price
false
Float
普通商品参数,商品原价,保留两位小数,如:0.01
link
false
String
通用链接(linkType=10) 商品链接,长度1-500,必填 多平台链接(linkType=11),非必填
pcLink
false
String
pc端跳转链接,长度1-500
mobileLink
false
String
移动web端链接
wxMiniprogramLink
false
String
小程序端链接
wxMiniprogramOriginalId
false
String
小程序端Id
mobileAppLink
false
String
移动App端链接
androidLink
false
String
多平台链接,移动APP-安卓系统原生页面链接
iosLink
false
String
多平台链接,移动APP-苹果系统原生页面链接
btnShow
false
String
按钮显示文案
params
false
String
自定义参数,json对象,例如:{"id":21,"color":"blue","level":1}
该参数以String类型接收,请求时需要转义,见下方请求体参数示例
tagIds
false
String
商品标签ID, json对象 例如: [1,2,3]
示例
http://api.polyv.net/live/v3/channel/product/update?appId=frlr1zazn3&sign=4C8FCD995644EEB248AB2CE70329F4D2&channelId=1965681×tamp=1621843510009
请求体参数
{
"productId": 27538,
"name": "开心豆",
"price": 0.99,
"cover": "//liveimages.videocc.net/uploadimage/20200827/chat_img_1779741_15985125681801.jpeg?x-oss-process=image/crop,x_95,y_0,w_235,h_235",
"link": "",
"status": 1,
"realPrice": 1.99,
"yield": "87.99%",
"linkType": 11,
"pcLink": "https://www.polyv.net/",
"mobileLink": "",
"wxMiniprogramLink": "",
"wxMiniprogramOriginalId": "",
"mobileAppLink": "",
"params": "{\"color\": \"red\"}"
}
响应参数描述
status
String
响应状态文本信息
message
String
响应描述信息,当code为400或者500的时候,辅助描述错误原因
data
String
响应成功返回SUCCESS,失败返回空
Java请求示例
快速接入基础代码请下载相关依赖源码, 点击下载源代码 ,下载后加入到自己的源码工程中即可。测试用例中的HttpUtil.java 和 LiveSignUtil.java 都包含在下载文件中。
强烈建议您使用直播Java SDK完成API的功能对接,直播Java SDK 对API调用逻辑、异常处理、数据签名、HTTP请求线程池进行了统一封装和优化。
private static final Logger log = LoggerFactory.getLogger(ChannelOperateTest.class);
/**
* 修改商品信息
* @throws IOException
* @throws NoSuchAlgorithmException
*/
@Test
public void testUpdateChannelProduct() throws IOException, NoSuchAlgorithmException {
//公共参数,填写自己的实际参数
String appId = super.appId;
String appSecret = super.appSecret;
String userId = super.userId;
String timestamp = String.valueOf(System.currentTimeMillis());
//业务参数
String url = "http://api.polyv.net/live/v3/channel/product/update";
String channelId = "1965681";
//http 调用逻辑
Map<String, String> requestMap = new HashMap<>();
requestMap.put("appId", appId);
requestMap.put("timestamp", timestamp);
requestMap.put("channelId", channelId);
String body = "{\"productId\":27538,\"name\":\"开心豆\",\"price\":0.99,\"cover\":\"//liveimages.videocc.net/uploadimage/20200827/chat_img_1779741_15985125681801.jpeg?x-oss-process=image/crop,x_95,y_0,w_235,h_235\",\"link\":\"\",\"status\":1,\"realPrice\":1.99,\"linkType\":11,\"pcLink\":\"https://www.polyv.net\",\"mobileLink\":\"\",\"wxMiniprogramLink\":\"\",\"wxMiniprogramOriginalId\":\"\",\"mobileAppLink\":\"\",\"params\":\"{\\\"cc\\\": 11}\"}";
requestMap.put("sign", LiveSignUtil.getSign(requestMap, appSecret));
url = HttpUtil.appendUrl(url, requestMap);
String response = HttpUtil.postJsonBody(url, body, null);
log.info("测试修改商品信息:{}", response);
//do somethings
}
响应示例
系统全局错误说明详见全局错误说明
成功示例
{
"code": 200,
"status": "success",
"message": "",
"data": "SUCCESS"
}
异常示例
{
"code": 400,
"status": "error",
"message": "invalid signature.",
"data": ""
}
Last updated
Was this helpful?