简易基于http的api请求客户端。直接使用HttpURLConnection,支持keepalives。支持map和pojo作为请求参数。支持设置header。默认支持jtool的_logId日志系统。
1.添加jtool的github的repository
<repositories>
<repository>
<id>jtool-mvn-repository</id>
<url>https://raw.github.com/JavaServerGroup/jtool-mvn-repository/master/releases</url>
</repository>
</repositories>
2.添加依赖
<dependency>
<groupId>com.jtool</groupId>
<artifactId>jtool-apiclient</artifactId>
<version>0.0.18</version>
</dependency>
2.添加import
import static com.jtool.apiclient.ApiClient.Api;
3.使用
Api().get("http://www.example.org");
or
Api().post("http://www.example.org");
Map<String, String> header = new HashMap<String, String>();
header.put("Authorization", "Basic xxx");
Api().header(header).post("http://www.example.org");
带pojo参数:
public class User{
private String name;
...
}
...
User user = new User();
user.setName("Andy");
Api().param(user).post("http://www.example.org");
带Map参数(推荐:Map<String, Object>):
//普通参数
Map<String, Object> user = new HashMap<>();
user.put("user", "Andy");
Api().param(user).post("http://www.example.org");
//发文件
Map<String, Object> uploadImgParam = new HashMap<>();
uploadImgParam.put("img", new File("~/photo.jpg"));
uploadImgParam.put("fileName", "myphoto");
Api().param(uploadImgParam).post("http:/www.example.org");
可以调用restPost直接发送rest风格的post请求
User user = new User();
user.setName("Andy");
String result = Api().param(people).restPost("http://www.xxx.com/restpost");
当请求返回的status code返回的码不在大于等于200,小于400的时候,会抛出一个自定义的运行时异常:StatusCodeNot200Exception