同步接口
1.调用流程分析:
1.MHCContext -> RemoteContext -> doBussiness(InparamMBDeviceRegister inparam,new IResponder(),30)
->new PTPickupFailed.doBussiness(request,responder,timeout);
->ProxyManager.sendRequest(Request,Responder,timeout,DBSContext.secretKey)
->Prox4MHCsoft()中被反射调用
->HttpHelper.execPost()网络请求
->Proxy4MHCsoft()中调用相应的responder.result()和responder.fault();
1.LocalContext是本地业务的集合类(也会有一些联网操作等),RemoteContext是远程业务的集合类。
LocalContext中的各种本地操作如PTSetBox()等,RemoteContext中有各种远程业务操作如PTPickUpFailed();
他们都有doBussiness(),callMethod(),和抽象handleBussines()方法;
在CallMethod()方法中
(1)打开数据库,验证request中是否有TerminalNo字段,如果有继续验证DBSContext.terminalUid是否为空,空则抛出DCDZSystemExeception()异常
不为空则把DBSContext.terminalUid设置给request的TerminalNo字段。
(2)然后调用result = handleBussiness() ,在handleBussiness可以进行访问网络操作。
(3)在handleBussiness中获取单例类ProxyManager,然后ProxyManager.sendRequest(InParamMBDeviceRegister inparam,new IResponder,30,DBSContext.secretKey);
在sendRequest()方法中开启线程池进行网络连接任务。
(4)首先判断Proxy()是否存在,不存在则判断Responder是否存在,存在则调用request.fault(FaultResult)
(5)然后通过反射调用invoke()方法,去调用相应的Bussiness方法。
(6)调用的实际是Prox4MHCsoft()中的doBussiness()方法;
(7)在doBussiness()中调用相应HttpHelper方法利用okhttp发送网络请求;
(8)在Proxy4MHCsoft()中jason解析然后根据消息调用相应的.result()和.fault()方法。
非同步,失败重传接口
失败重传接口与同步接口不同的是在handlerBussiness()中,同步接口是调用ProxManager.sendRequest();
而同传接口是调用CommonDao.insertUploadDataQueue(database,request),
1. 把数据插入到SCUploadDataQueue表中
2. 在doBussiness中新建一个SyncDataProc.syncData传入MsgId和Request;
3. ThreadPool.QuequeUserWorkItem()线程池提交一个任务
SyncDataProc.sendPickUpRecoder(syncData);