import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.nio.charset.Charset;
/**
* TODO 代码仅作为示例,未做优化和代码复用等处理;<br />
* TODO 使用时需根据实际情况进行优化和改造
*/
public class HttpClientDemo {
private static Logger logger = LoggerFactory.getLogger(HttpClientDemo.class);
/**
* app的应用id,开发和上线前联系前海一方获取,需要保密存储
*/
private final static String APP_KEY = "db3a7jajk-dasd-a34d-ffs1-d32123fsfe43s";
/**
* app的密钥,开发和上线前联系前海一方获取,需要保密存储
*/
private final static String APP_SECRET = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCxw6V3m50E2xGN7OZSG/t9qOpfi/VBUFJaIgEFc+sZhadiR7kqcWb3niadyS5okny/SLmN4oM676B4SlaW1BI4TVZ2oh4bP2c63dw0MzA+nTrBrfXVLGE83+66uv8z6d33XCMfxKmE/XnVdwrsj/3veVjNOGuCG2dMzTEIYAjGBQIDAQAB";
public static void main(String[] args) {
// TODO 使用的post请求,如果是GET请求,需使用HttpGet,PUT使用HttpPut,DELETE使用HttpDelete
HttpPost post = null;
try {
String token = getToken(); // 获取token
HttpClient httpClient = HttpClients.createDefault();
post = new HttpPost("http://192.168.138.193:6060/api/kingdee/payment/info");
// 构造消息头
post.setHeader("Content-type", "application/json; charset=utf-8");
post.setHeader("Connection", "Close");
// 每个业务接口调用时,都必须提供token,前海一方将根据token检测请求是否来自合法的三方
// token有过期时间,在过期时间之后token需要重新获取
post.setHeader("token", token);
String requestParameter = "{\"baoliNo\":\"BL-1903-000005\",\"billDate\":\"2019-03-11 14:29:57\",\"applyAmount\":1,\"payee\":\"江苏优创公关策划有限公司\",\"payProviderGUID\":\"447c9c78-884a-e811-80bd-90e2babd62d1\",\"applyDesc\":\"支付优创案名发布会费用\",\"contractCode\":\"住宅开发常州公司-常州天宁区刘塘浜地块(联合操盘)-一期-2018-07-000852\",\"contractName\":\"苏南公司--璞樾门第项目--案名发布会\",\"applyCode\":\"dccz-2018-10-7427\",\"companyName\":\"常州亿泰房地产开发有限公司\",\"payeeBank\":\"中国银行股份有限公司常州新城支行\",\"payeeAccount\":\"496263424668\"}"; // 请求参数,按照不同的接口参数构造json字符串
// 对请求参数进行加密
String rsaParameter = rsaEncryptedString(requestParameter);
// 构建消息实体
StringEntity entity = new StringEntity(rsaParameter, Charset.forName("gbk"));
entity.setContentEncoding("gbk");
// 发送Json格式的数据请求
entity.setContentType("application/json");
//https://data.riskstorm.com/v1/news/57e0fdbcd266387351d0e5a4?apikey=BvAXwAfqr0b3QMg2OCuSrA 这样类型的url
post.setEntity(entity);
HttpResponse response = httpClient.execute(post);
// 检验返回码
int statusCode = response.getStatusLine().getStatusCode();
if (statusCode != HttpStatus.SC_OK) {
logger.error("请求出错: " + statusCode);
} else {
// TODO 这里参考getToken方法中解析响应数据
}
} catch (Exception e) {
// TODO 按需处理异常
e.printStackTrace();
} finally {
if (post != null) {
try {
post.releaseConnection();
Thread.sleep(500);
} catch (InterruptedException e) {
// TODO 按需处理异常
e.printStackTrace();
}
}
}
}
/**
* 获取访问凭证的示例方法<br />
* 建议实际使用时,做好token的缓存和检测(当发现token超时后自动重新获取);token在过期前可缓存使用
*
* @return token
*/
static String getToken() {
HttpClient httpClient = HttpClients.createDefault();
HttpPost post = null;
try {
post = new HttpPost("http://192.168.138.193:6060/api/auth/access/token");
// 设置http请求头的信息,目前仅限定了请求协议为json,编码为utf-8
// 构造消息头
post.setHeader("Content-type", "application/json; charset=utf-8");
post.setHeader("Connection", "Close");
// 构造请求的json参数,可以通过fastjson、gson等框架来构造该字符串
String requestParameter = "{\"appKey\":\"" + APP_KEY + "\",\"appSecret\":\"" + APP_SECRET + "\"}";
// 构建消息实体
StringEntity entity = new StringEntity(requestParameter, Charset.forName("gbk"));
entity.setContentEncoding("gbk");
// 发送Json格式的数据请求
entity.setContentType("application/json");
post.setEntity(entity);
HttpResponse response = null;
response = httpClient.execute(post);
// 检验返回码
int statusCode = response.getStatusLine().getStatusCode();
if (HttpStatus.SC_OK != statusCode) {
throw new RuntimeException("获取token的HTTP请求响应失败,响应代码:" + statusCode);
}
HttpEntity resultEntity = response.getEntity();
if (resultEntity != null) {
// TODO 以下为解析响应的json结构,可按需优化为定义一个POJO对象,并直接从json转换为json对象
String resultString = EntityUtils.toString(resultEntity, "gbk");
JSONObject resultJsonObject = JSON.parseObject(resultString);
if (!resultJsonObject.containsKey("data")) {
throw new RuntimeException("响应数据结构有误,响应数据为:" + resultString);
}
JSONObject dataJsonObject = resultJsonObject.getJSONObject("data");
if (!dataJsonObject.containsKey("token")) {
throw new RuntimeException("响应数据结构有误(未包含token),响应数据为:" + resultString);
}
// long expireTime = dataJsonObject.getLongValue("expireTime"); // 过期时间,代表多少毫秒后token将过期
return dataJsonObject.getString("token");
}
} catch (IOException e) {
// TODO 按需处理异常
// e.printStackTrace();
logger.error("获取token出错,这里需要按照业务需要实现自己的错误处理逻辑", e);
}
return null;
}
/**
* 加密请求参数
*
* @param jsonData 要加密的json参数
* @return 加密后的参数字符串
*/
static String rsaEncryptedString(String jsonData) {
try {
return RsaUtils.encryptedString(jsonData, APP_SECRET);
} catch (Exception e) {
// TODO 按需处理异常
e.printStackTrace();
}
return null;
}
}