其他分享
首页 > 其他分享> > 快宝微掌柜同步订单

快宝微掌柜同步订单

作者:互联网

LOADING

正在上传…重新上传取消快宝开放平台

开发者指南

13122911354

控制台

API文档

API文档/微掌柜/同步订单

应用场景

各大电商平台的订单可在微掌柜中查看并打单,通过本接口,可以将微掌柜中已有的订单同步给自建的第三方平台,自建平台可自行决定如何处理订单

注:1同步订单之前需要先在微掌柜网页版绑定授权店铺,获取到授权店铺的订单信息为脱敏信息,微掌柜网页地址:https://kbydy.cn/

2开发者需先在微掌柜网页版中获取授权秘钥,秘钥位置:微掌柜网页版-设置-账户管理-本账号秘钥

接口名称

vhome.sync.order

公共参数

请求地址

环境名称

HTTPS请求地址

正式地址https://kop.kuaidihelp.com/api

公共请求参数

名称

类型

是否必须

描述

methodstring

API接口名称

app_idstring

用户ID(注册开放平台时分配,在控制台中查看)

signstring

按照规则(md5(app_id + method + ts + api_key))生成的合法性验证签名(32位字符串,字母小写)如:10000cloud.print.do1524209949bdf3b5f50865ac813cbdfd6c9b572b79加密后5030cae3388ecdc2e686379753a0564c

tsstring

当前请求的时间戳(10位或13位)

datastring

JSON格式请求参数

公共响应参数

名称

类型

是否必须

描述

codeint

响应状态码。0-成功,非0-失败下载并查看详情

msgstring

返回结果说明

uidstring

本次请求唯一业务流水号

datastring

JSON格式响应数据

请求参数

名称

类型

是否必须

描述

secret_keystring

微掌柜密钥,秘钥位置:微掌柜网页版-设置-账户管理-本账号秘钥

pageint

页码,请求时按页码分批获取,第一次填1,第二次填2,以此类推,直到返回为空即为全部获取

sourcestring

传电商平台编码,可查指定平台的订单,下载电商平台编码

shop_idstring

绑定微掌柜的店铺ID,可查指定店铺的订单;店铺ID可通过“获取店铺列表”接口查询

start_timestring

时间筛选可精确到年月日时分,示例:【2020-07-30 23:59】不填默认最近3个月

end_timestring

同start_time

响应参数

名称

类型

是否必须

描述

order_nostring

微掌柜订单号

recipientarray

收件人脱敏信息列表,返回请求时携带的收件人信息

请求示例

Java

C#

Python

PHP

Node.js

Curl

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

import java.util.Map;
import java.util.HashMap;

import java.util.Date;

public class Request {

public static void main(String[] args) {
String host = "http://kop.kuaidihelp.com";
String path = "/api";
String requestMethod = "POST";
Map<String, String> headers = new HashMap<String, String>();
//根据API的要求,定义相对应的Content-Type
headers.put("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
Map<String, String> querys = new HashMap<String, String>();
Map<String, String> bodys = new HashMap<String, String>();

String appId = "50001";
String method = "vhome.sync.order";
// 当前时间戳
String ts = new Date().getTime() + "";
String appKey = "bdf3b5f50865ac813cbdfd6c9b572b79";

// 计算签名
String signStr = appId + method + ts + appKey;
String sign = Request.getMD5(signStr, 32);

bodys.put("app_id", appId);
bodys.put("method", method);
bodys.put("ts", ts);
bodys.put("sign", sign);
// data参数是个json格式的字符串  建议使用函数或方法去生成
bodys.put("data", "{
    "secret_key": "07070feca31bb7225b350997b12e5c9c",
    "page": 1,
    "source": "pdd",
    "shop_id": "12345678",
    "start_time": "2020-07-30 23:59",
    "end_time": "2020-08-31 23:59"
}");


try {
	/**
	* 重要提示如下:
	* HttpUtils请从
	* https://github.com/aliyun/api-gateway-demo-sign-java/blob/master/src/main/java/com/aliyun/api/gateway/demo/util/HttpUtils.java
	* 下载
	*
	* 相应的依赖请参照
	* https://github.com/aliyun/api-gateway-demo-sign-java/blob/master/pom.xml
	*/
	HttpResponse response = HttpUtils.doPost(host, path, requestMethod, headers, querys, bodys);
	System.out.println(response.toString());
	
		//获取response的body
		System.out.println(EntityUtils.toString(response.getEntity()));
	} catch (Exception e) {
		e.printStackTrace();
	}
}

	// 计算md5
    public static String getMD5(String plainText, int length) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");//获取MD5实例
            md.update(plainText.getBytes());//此处传入要加密的byte类型值
            byte[] digest = md.digest();//此处得到的是md5加密后的byte类型值

            /*
               下边的运算就是自己添加的一些二次小加密,记住这个千万不能弄错乱,
                   否则在解密的时候,你会发现值不对的(举例:在注册的时候加密方式是一种,
                在我们登录的时候是不是还需要加密它的密码然后和数据库的进行比对,但是
            最后我们发现,明明密码对啊,就是打不到预期效果,这时候你就要想一下,你是否
             有改动前后的加密方式)   
            */
            int i;
            StringBuilder sb = new StringBuilder();
            for (int offset = 0; offset < digest.length; offset++) {
                i = digest[offset];
                if (i < 0)
                    i += 256;
                if (i < 16)
                    sb.append(0);
                sb.append(Integer.toHexString(i));//通过Integer.toHexString方法把值变为16进制
            }
            return sb.toString().substring(0, length);//从下标0开始,length目的是截取多少长度的值
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
            return null;
        }
    }
}

响应示例

成功响应示例

JSON示例

{"code":

int0

"msg":

string"success"

"data":[0:{"order_no":

string"200901040000142"

"recipient":{"mobile":

string"183****2551"

"province":

string"上海市"

"city":

string"上海市"

"district":

string"长宁区"

}}1:{"order_no":

string"200901040000151"

"recipient":{"mobile":

string"18*******51"

"province":

string"上海市"

"city":

string"上海市"

"district":

string"长宁区"

}}]"uid":

string"4bdbc09b59826808055800793477559200000000"

}

异常响应示例

JSON示例

{"code":

int300103

"msg":

string"不合法的请求参数"

"data":{"reason":

string"参数secret_key的值不能为空"

"unique_no":

string"cf1fd0ba3477711abcf0d7d98230da0700000000"

}"uid":

string"cf1fd0ba3477711abcf0d7d98230da0700000000"

}

错误代码

暂无数据

应用场景

接口名称

公共参数

请求参数

响应参数

请求示例

响应示例

错误代码

首页

解决方案

产品

API文档

关于我们

使用微信或企业微信扫码加入群聊

CopyRight © 2022 沪ICP备 12047396号 快宝(上海)网络科技有限公司

友情链接:申通快递中通快递顺丰速运中国邮政速递物流韵达快递

标签:同步,java,string,示例,API,快宝微,掌柜,String
来源: https://blog.csdn.net/lizheng500/article/details/123630958