${docRemark}
配置项
HTTP请求地址 | |
---|---|
app_key | |
secret | |
access_token | |
jwt |
${apiModule.name}
#foreach($docItem in ${apiModule.moduleItems})${docItem.description}${docItem.version}
${docItem.remark}
接口名(${API_NAME}):${docItem.name}
版本号(${VERSION_NAME}):${docItem.version}
请求参数/
数据模型
返回结果/数据模型
#if(${docItem.customWrapper})
#else
#end
名称 | 类型 | 示例值 | 描述 |
---|
名称 | 类型 | 描述 | ||||
---|---|---|---|---|---|---|
${code_name} | string | ${code_description} | ||||
${msg_name} | string | ${msg_description} | ||||
${data_name} | ${docItem.apiDocReturnDefinition.dataType} | ${docItem.apiDocReturnDefinition.description}。#if(${docItem.apiDocReturnDefinition.example} != "")示例值:${docItem.apiDocReturnDefinition.example}#end | ||||
${data_name} | object | ${data_description}
|
#end #end
附录
签名算法
签名算法描述如下: 1.将请求参数按参数名升序排序; 2.按请求参数名及参数值相互连接组成一个字符串:<paramName1><paramValue1><paramName2><paramValue2>...; 3.将应用密钥分别添加到以上请求参数串的头部和尾部:<secret><请求参数字符串><secret>; 4.对该字符串进行MD5(全部大写),MD5后的字符串即是这些请求参数对应的签名; 5.该签名值使用sign参数一起和其它请求参数一起发送给服务开放平台。 伪代码: Map<String,Object> paramsMap = new ...; // 参数 Set<String> keySet = paramsMap.keySet(); List<String> paramNames = new ArrayList<String>(keySet); // 1. Collections.sort(paramNames); StringBuilder paramNameValue = new StringBuilder(); // 2. for (String paramName : paramNames) { paramNameValue.append(paramName).append(paramsMap.get(paramName)); } // 3. String source = secret + paramNameValue.toString() + secret; // 4. String sign = md5(source); // 5. paramsMap.put("sign",sign);
请求示例
Java版本:import java.io.IOException;
import java.net.URLEncoder;
import java.security.MessageDigest;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.junit.Test;
import com.alibaba.fastjson.JSON;
import junit.framework.TestCase;
public class PostTest extends TestCase {
@Test
public void testPost() throws IOException {
String appKey = "test";
String secret = "123456";
// 业务参数
Map<String, String> jsonMap = new HashMap<String, String>();
jsonMap.put("goodsName", "iphoneX");
String json = JSON.toJSONString(jsonMap);
json = URLEncoder.encode(json, "utf-8");
// 系统参数
Map<String, Object> param = new HashMap<String, Object>();
param.put("name", "goods.get");
param.put("app_key", appKey);
param.put("data", json);
param.put("timestamp", getTime());
param.put("version", "");
param.put("access_token", "");
String sign = buildSign(param, secret);
param.put("sign", sign);
/*
// 最终请求数据
{
"sign": "2AE534A15AACE112EE43B9CCF6BD4383",
"timestamp": "2018-03-21 12:57:30",
"name": "goods.get",
"data": "%7B%22goodsName%22%3A%22iphoneX%22%7D",
"app_key": "test",
"version": ""
}
*/
System.out.println("=====请求数据=====");
String postJson = JSON.toJSONString(param);
System.out.println(postJson);
// String resp = HttpUtil.post(postJson); // 发送请求
/*
响应结果:
{
"${code_name}":"0",
"${data_name}":{
"pageIndex":1,
"pageSize":10,
"rows":[
{
"goods_name":"iPhoneX",
"id":1,
"price":8000
},
{
"goods_name":"三星",
"id":2,
"price":7000
}
],
"total":100
}
}
*/
}
/**
* 构建签名
*
* @param paramsMap
* 参数
* @param secret
* 密钥
* @return
* @throws IOException
*/
public static String buildSign(Map<String, ?> paramsMap, String secret) throws IOException {
Set<String> keySet = paramsMap.keySet();
List<String> paramNames = new ArrayList<String>(keySet);
Collections.sort(paramNames);
StringBuilder paramNameValue = new StringBuilder();
for (String paramName : paramNames) {
paramNameValue.append(paramName).append(paramsMap.get(paramName));
}
String source = secret + paramNameValue.toString() + secret;
return md5(source);
}
/**
* 生成md5,全部大写
*
* @param message
* @return
*/
public static String md5(String message) {
try {
// 1 创建一个提供信息摘要算法的对象,初始化为md5算法对象
MessageDigest md = MessageDigest.getInstance("MD5");
// 2 将消息变成byte数组
byte[] input = message.getBytes();
// 3 计算后获得字节数组,这就是那128位了
byte[] buff = md.digest(input);
// 4 把数组每一字节(一个字节占八位)换成16进制连成md5字符串
return byte2hex(buff);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
/**
* 二进制转十六进制字符串
*
* @param bytes
* @return
*/
private static String byte2hex(byte[] bytes) {
StringBuilder sign = new StringBuilder();
for (int i = 0; i < bytes.length; i++) {
String hex = Integer.toHexString(bytes[i] & 0xFF);
if (hex.length() == 1) {
sign.append("0");
}
sign.append(hex.toUpperCase());
}
return sign.toString();
}
public String getTime() {
return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
}
}
JavaScript版本:jssdk下载