注冊請求體
@ReqTags("注冊")
public class RegisterReq extends CommonRequest {
public String username;
public String password;
public String repassword;
public RegisterReq(String username, String password, String repassword) {
this.username = username;
this.password = password;
this.repassword = repassword;
}
public RegisterReq() {
}
@Override
public String postfix() {
return "user/register";
}
}
發(fā)起請求
final RegisterReq json = new RegisterReq("12132322333", "123456", "123456");
HttpRequestFactory.doPost(json, new ResultCallbackAdapt<HttpCommObjResp<RegisterResp>>() {
@Override
public void doOnResponse(HttpCommObjResp<RegisterResp> response) {
System.out.println(response + "");
mContent.setText("\n方式一返回:" + response);
}
@Override
public void doOnError(ApiException ex) {
System.out.println(ex + "");
mContent.setText("\n方式一返回:" + ex);
}
}, iLoading);
// 方式二
HttpRequestFactory.doPost(json, new ResultCallbackAdapt<String>() {
@Override
public void doOnResponse(String response) {
System.out.println(response + "");
mContent.setText("\n方式二返回:" + response);
}
@Override
public void doOnError(ApiException ex) {
System.out.println(ex + "");
mContent.setText("\n方式二返回:" + ex);
}
});
初始化函數(shù)
public class MyApplication extends Application
{
@Override
public void onCreate()
{
super.onCreate();
HttpRequestFactory.doCreateHttpReqManager(this, ResLibConfig.DEBUG ? "http://www.wanandroid.com/" : "http://www.wanandroid.com/")
.registerCallbacks(new HttpHeadersImpl() {
@Override
public Map<String, String> generateHeaders() {
Map<String, String> keys = new HashMap<>();
// keys.put("versionCode", "" + IUtil.obtainAppVersionCode(ResLibConfig.CONTEXT));
// keys.put("version", IUtil.obtainAppVersion(ResLibConfig.CONTEXT));
// keys.put("channel", "");
// keys.put("imei", "");
// keys.put("platform", "2");//1:ios 2:Android
// keys.put("model", IUtil.MODEL);
// keys.put("vendor", IUtil.BRAND);
return keys; // 請求頭注入,如有需要
}
}).registerCallbacks(new HttpInterceptor() {
@Override
public void doInterceptor(int... cmds) {
if (cmds != null && cmds.length > 0) {
int code = cmds[0];
switch (code) {
case HttpInterceptor.KICKED_OFF_LINE:
//Tools.showToast("用戶已在其他設(shè)備登錄");
int value = AUTO_INCREMENT.incrementAndGet();
if (value == 1) {
// relogin(); // 調(diào)用一次
}
Logger.e("http", "用戶已在其他設(shè)備登錄|" + value + "|");
break;
case HttpInterceptor.PROHIBIT_USED:
//Tools.showToast("您被禁止使用");
break;
case HttpInterceptor.PROHIBIT_USEDII:
//Tools.showToast("用戶被封禁,不能登錄");
break;
case HttpInterceptor.UN_LOGIN:
//Tools.showToast("請先登錄");
//relogin(false);
break;
}
}
}
}).asEncryptFuncs(new EncryptFuncs() {
@Override
public String encrypt(String plainText) {
//return AesEncryptionUtil.encrypt(plainText);
return "";
}
@Override
public String decrypt(String cipherText) {
//return AesEncryptionUtil.decrypt(cipherText);
return "";
}
/**
* {@link ReqTags}
* {@link kaiqi.cn.httpx.req.RegisterReq}
* 請給予tag,否則取消不掉請求,攔截不了加密解密賽~
*/
@Override
public boolean accept(String httpReaTag) {
if ("注冊".equals(httpReaTag)) {
// return false; // 你們都同意,我注冊第一個不答應(yīng)
}
return true; // 同意加密
}
}).asSubmmitForm(true); // true = 表單提交 false = json提交
}
}
tips:關(guān)于用HttpCommObjResp<RegisterResp> 還是用 HttpCommObjsResp<RegisterResp>
形如格式:
{
"code":200,
"msg":"成功",
"data":{}
}
data = {} 是對象,所以用HttpCommObjResp<RegisterResp>
形如格式:
{
"code":200,
"msg":"成功",
"data":[]
}
data = [] 是數(shù)組對象,所以用HttpCommObjsResp<RegisterResp>
我以為所有的接口返回都是這樣的,其實(shí)并不是
以下是注冊返回json
{
"data": {
"collectIds": [],
"email": "",
"icon": "",
"id": 9073,
"password": "123456",
"token": "",
"type": 0,
"username": "19910222"
},
"errorCode": 0,
"errorMsg": ""
}
為什么不是code,msg??
不過不要怕,照樣無縫鏈接網(wǎng)絡(luò)調(diào)用,提供json,表單兩種提交方式|下載,上傳這個沒上心寫!!!
因?yàn)闀簳r支持這幾種返回格式的組合,不滿足格式的話,如有需要,請修改源碼
{
"msg":"",
"code"100,
"data":{}
}
{
"errorMsg":"",
"errorCode"100,
"data":{}
}
{
"message":"",
"error"100,
"infos":{}
}
{
....
"results":{}
}
關(guān)于取消請求
HttpRequestFactory.cancel("注冊");//取消單個
HttpRequestFactory.cancel("注冊","首頁文章列表"); // 取消多個
關(guān)于加密解密,暫時只支持json加密解密!!!
關(guān)于上傳,公司項(xiàng)目圖片現(xiàn)在都走阿里云,實(shí)在是沒測試接口了,歡迎大佬們提供測試接口,讓我來完善這個庫~
代碼還有很多不足之處,請指教
當(dāng)日志滿天飛,你說我有格式化日志工具類,美倒是美,接口多了,不好找啊,
那怎么樣才可以找我想要的接口信息呢?
問的好,請看日志截圖,一圖勝千言~是不是很清爽,看我所看,愛我所愛.
日志摘要1
日志摘要2
為什么要這樣寫?看下服務(wù)端代馬
@RequestMapping(value = "/showUser", method = { RequestMethod.GET,
RequestMethod.POST }, produces = "application/json;charset=UTF-8")
public JSONObject toIndex(@RequestBody(required = false) String data) {
return callHttpReqTask(data, TO_INDEX);
}
@RequestMapping(value = "/addUser", method = { RequestMethod.GET,
RequestMethod.POST }, produces = "application/json;charset=UTF-8")
public JSONObject addUser(@RequestBody(required = false) String data) {
return callHttpReqTask(data, ADD_USER);
}
每一個請求都有一個RequestMapping
我在每一個請求體上構(gòu)造一個后綴,豈不是和后臺相映成趣.
調(diào)用堆棧不深,適合新手閱讀源碼,有可取之處,給我加star吧
轉(zhuǎn)載注明出處 HttpX
如有需要 加密解密庫
使用方式,如有需要
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
dependencies {
implementation 'com.github.majunm:HttpX:v1.0.0-gamma'
}