OpenAPI接入指南
开始前必读
开始开发
更新时间:2018-07-19 15:12:23
产品功能接口调用

(1)使用请求报文body、签名密钥signature、时间戳ts,计算得出签名信息sign。

     请求报文签名规则:

     a.报文前拼接签名密钥,后面拼接时间戳(毫秒)字符串:signature + body + ts ;

          signature: 签名密钥;

          body: 请求JSON报文;

          ts: 时间戳,毫秒;

     b.使用SHA-256算法计算HASH值;


(2)使用产品token、签名信息sign、时间戳ts、请求报文body,发出API调用请求,报文签名算法见下文

 


报文签名样例代码

报文签名算法

/**
     * 签名算法
     *
     * @param body
     *            报文体
     * @param ts
     *            时间戳
     * @param signature
     *            密钥
     * @return
     */
    public static String sign(String body, String ts, String signature) {
        String sign = EncodeUtils.encodeBySHA256(signature + body + ts);
 
        return sign;
    }

 

 SHA256签名算法

private static final char[] HEX_DIGITS = { '0', '1', '2', '3', '4', '5',
            '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
 
/**
     * encode By SHA-256
     *
     * @param str
     * @return
     */
    public static String encodeBySHA256(String str) {
        if (str == null) {
            return null;
        }
        try {
            MessageDigest messageDigest = MessageDigest.getInstance("SHA-256");
            messageDigest.reset();
            messageDigest.update(str.getBytes(“UTF-8”));
            return getFormattedText(messageDigest.digest());
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
 
/**
     * Takes the raw bytes from the digest and formats them correct.
     *
     * @param bytes
     *            the raw bytes from the digest.
     * @return the formatted bytes.
     */
    private static String getFormattedText(byte[] bytes) {
        int len = bytes.length;
 
        StringBuilder buf = new StringBuilder(len * 2);
        // 把密文转换成十六进制的字符串形式
        for (int j = 0; j < len; j++) {
            buf.append(HEX_DIGITS[(bytes[j] >> 4) & 0x0f]);
            buf.append(HEX_DIGITS[bytes[j] & 0x0f]);
        }
 
        return buf.toString();
    }


 

咨询与服务