Java httpClient 连接一个需要Signature验证的API

使用httpClent 4.x 连接一个需要Signature验证的API 一直返回401

HTTP/1.1 401 Unauthorized
Server: Apache-Coyote/1.1
X-Application-Context: bootstrap
Authorization: WWW-Authenticate: Signature realm="World-Check One API",algorithm="hmac-sha256",headers="(request-target) host date content-type content-length
Transfer-Encoding: chunked
Date: Fri, 21 Oct 2016 12:36:54 GMT 

我确认我的加密方法已经正确,我只是把Signature Authenticate 加到Header,这样是否正确?

                // httpClient 连接到url
         final HttpGet request = new HttpGet(httpUrl);
        request.setHeader("Date", gmtDate);
        request.setHeader("Authorization", auth);
        final HttpClient client = HttpClientBuilder.create().build();
        final HttpResponse response = client.execute(request);
        final int statusCode = response.getStatusLine().getStatusCode();
     // 加密
     private String getSignature(final String dataToSign) {
        logger.info("***** dataToSign : " + dataToSign +" *****");
        final String signature = Hmac.encodeHmacSHA256(dataToSign.getBytes(), apiSecret.getBytes());
        logger.info("***** signature : " + signature +" *****");
        return signature;
    }

   // 拼装成Authorisation
    private String getAuthorisation(final String signature) {
        final StringBuffer sb = new StringBuffer("");
        sb.append("Signature keyId=\"").append(apiKey);
        sb.append("\",algorithm=\"hmac-sha256\",headers=\"(request-target) host date\",signature=\"");
        sb.append(signature).append("\"");

        logger.info("***** dataToSign : " + sb.toString() +" *****");
        return sb.toString();
    }

https://zhidao.baidu.com/question/2014315944592539868.html?skiptype=2