/// <summary> /// 处理托管接口请求响应 /// </summary> /// <param name="isSync">是否同步返回</param> protected void DoResponse(bool isSync = false) { Agp2pDataContext context = new Agp2pDataContext(); try { string reqStr = ReadReqStr(); ResponseLog = new li_pay_response_log() { request_id = string.IsNullOrEmpty(Request["requestId"]) ? null : Request["requestId"], result = string.IsNullOrEmpty(Request["result"]) ? "" : Request["result"], status = (int)Agp2pEnums.SumapayResponseEnum.Return, response_time = DateTime.Now, response_content = reqStr }; if (!string.IsNullOrEmpty(ResponseLog.request_id)) { //根据响应报文找到对应的request,生成处理消息,对应各种消息处理逻辑 RequestLog = context.li_pay_request_log.SingleOrDefault(r => r.id == ResponseLog.request_id); if (RequestLog != null) { //检查请求是否已经处理过 if (RequestLog.status != (int)Agp2pEnums.SumapayRequestEnum.Complete) { BaseRespMsg respMsg = null; switch (RequestLog.api) { //个人/企业 开户/激活 case (int)Agp2pEnums.SumapayApiEnum.URegi: case (int)Agp2pEnums.SumapayApiEnum.URegM: case (int)Agp2pEnums.SumapayApiEnum.Activ: case (int)Agp2pEnums.SumapayApiEnum.CRegi: respMsg = new UserRegisterRespMsg(reqStr); break; //个人自动投标续约 case (int)Agp2pEnums.SumapayApiEnum.AtBid: respMsg = new AutoBidSignRespMsg(reqStr); break; //个人自动投标取消 case (int)Agp2pEnums.SumapayApiEnum.ClBid: respMsg = new AutoBidSignRespMsg(reqStr, true); break; //个人/企业 自动账户/银行还款开通 case (int)Agp2pEnums.SumapayApiEnum.AcReO: case (int)Agp2pEnums.SumapayApiEnum.CcReO: case (int)Agp2pEnums.SumapayApiEnum.AbReO: respMsg = new AutoRepaySignRespMsg(reqStr); break; //个人/企业 自动还款取消 case (int)Agp2pEnums.SumapayApiEnum.ClRep: case (int)Agp2pEnums.SumapayApiEnum.CancR: respMsg = new AutoRepaySignRespMsg(reqStr, true); break; //企业/个人网银充值 case (int)Agp2pEnums.SumapayApiEnum.WeRec: case (int)Agp2pEnums.SumapayApiEnum.CeRec: respMsg = new RechargeRespMsg(reqStr); break; //个人一键充值 case (int)Agp2pEnums.SumapayApiEnum.WhRec: case (int)Agp2pEnums.SumapayApiEnum.WhReM: respMsg = new WithholdingRechargeRespMsg(reqStr); break; //个人投标/自动投标 普通/集合项目 case (int)Agp2pEnums.SumapayApiEnum.MaBid: case (int)Agp2pEnums.SumapayApiEnum.McBid: case (int)Agp2pEnums.SumapayApiEnum.MaBiM: case (int)Agp2pEnums.SumapayApiEnum.McBiM: case (int)Agp2pEnums.SumapayApiEnum.AmBid: case (int)Agp2pEnums.SumapayApiEnum.AcBid: respMsg = new BidRespMsg(reqStr); break; //个人撤标 case (int)Agp2pEnums.SumapayApiEnum.CaPro: case (int)Agp2pEnums.SumapayApiEnum.CoPro: respMsg = new WithDrawalRespMsg(reqStr); break; //流标普通项目 case (int)Agp2pEnums.SumapayApiEnum.RePro: respMsg = new RepealProjectRespMsg(reqStr); break; //普通/集合项目放款 case (int)Agp2pEnums.SumapayApiEnum.ALoan: case (int)Agp2pEnums.SumapayApiEnum.CLoan: respMsg = new MakeLoanRespMsg(reqStr); break; //个人/企业提现 case (int)Agp2pEnums.SumapayApiEnum.Wdraw: case (int)Agp2pEnums.SumapayApiEnum.Cdraw: case (int)Agp2pEnums.SumapayApiEnum.WdraM: respMsg = new WithdrawRespMsg(reqStr, isSync); break; //个人/企业 存管账户还款普通/集合项目 case (int)Agp2pEnums.SumapayApiEnum.MaRep: case (int)Agp2pEnums.SumapayApiEnum.McRep: case (int)Agp2pEnums.SumapayApiEnum.CaRep: case (int)Agp2pEnums.SumapayApiEnum.CoRep: respMsg = new RepayRespMsg(reqStr); break; //个人协议还款普通/集合项目 case (int)Agp2pEnums.SumapayApiEnum.BaRep: case (int)Agp2pEnums.SumapayApiEnum.BcRep: respMsg = new RepayRespMsg(reqStr, true); break; //个人自动还款普通/集合项目 case (int)Agp2pEnums.SumapayApiEnum.AcRep: case (int)Agp2pEnums.SumapayApiEnum.AbRep: case (int)Agp2pEnums.SumapayApiEnum.CcRep: case (int)Agp2pEnums.SumapayApiEnum.CbRep: respMsg = new RepayRespMsg(reqStr, false, true); break; //普通/集合项目本息到账 case (int)Agp2pEnums.SumapayApiEnum.RetPt: case (int)Agp2pEnums.SumapayApiEnum.RetCo: respMsg = new ReturnPrinInteRespMsg(reqStr); break; //债权转让 case (int)Agp2pEnums.SumapayApiEnum.CreAs: case (int)Agp2pEnums.SumapayApiEnum.CreAM: respMsg = new CreditAssignmentRespMsg(reqStr); break; //查询项目 case (int)Agp2pEnums.SumapayApiEnum.QuPro: respMsg = BaseRespMsg.NewInstance <QueryProjectRespMsg>(reqStr); break; //银行卡解绑 case (int)Agp2pEnums.SumapayApiEnum.RemCa: respMsg = new RemoveCardRespMsg(reqStr); break; //红包付款至用户 case (int)Agp2pEnums.SumapayApiEnum.HbPay: respMsg = new HongbaoPayRespMsg(reqStr); break; default: respMsg = new BaseRespMsg(); break; } //发送响应消息处理 MessageBus.Main.Publish(respMsg); //更新日志信息 ResponseLog.user_id = respMsg.UserIdIdentity; ResponseLog.project_id = respMsg.ProjectCode; RequestLog.complete_time = DateTime.Now; if (respMsg.HasHandle) { ResponseLog.status = (int)Agp2pEnums.SumapayResponseEnum.Complete; RequestLog.status = (int)Agp2pEnums.SumapayRequestEnum.Complete; } else { ResponseLog.status = (int)Agp2pEnums.SumapayResponseEnum.Invalid; RequestLog.status = (int)Agp2pEnums.SumapayRequestEnum.Fail; //记录失败信息 ResponseLog.remarks += respMsg.Remarks; } context.li_pay_response_log.InsertOnSubmit(ResponseLog); } } else { context.AppendAdminLog("SumaPayNotic", "没有找到对应的请求,RequestID:" + ResponseLog.request_id); } } else { context.AppendAdminLog("SumaPayNotic", "请求流水号为空!返回报文为:" + reqStr); } } catch (Exception ex) { context.AppendAdminLog("SumaPayNotic", "noticeUrl 内部错误:" + ex.Message); } //解决错误“找不到行或已修改” try { context.SubmitChanges(System.Data.Linq.ConflictMode.ContinueOnConflict); } catch (System.Data.Linq.ChangeConflictException ex) { //不再提交数据更新 new Agp2pDataContext().AppendAdminLogAndSave("SumaPayNotic", "noticeUrl 找不到行或已修改:" + ex.Message); } }
/// <summary> /// 还款 /// </summary> /// <param name="msg"></param> private static void Repay(RepayRespMsg msg) { try { //检查请求处理结果 if (msg.CheckResult()) { //检查签名 if (msg.CheckSignature()) { Agp2pDataContext context = new Agp2pDataContext(); //异步返回才执行,内网测试使用同步 #if DEBUG if (msg.Sync) { #endif #if !DEBUG if (!msg.Sync) { #endif var req = context.li_pay_request_log.SingleOrDefault(r => r.id == msg.RequestId); if (req != null) { //查找对应的项目 var pro = context.li_projects.SingleOrDefault(p => p.id == msg.ProjectCode); if (pro != null) { if (!string.IsNullOrEmpty(req.remarks)) { //活期项目不需要生成还款记录 if (!msg.HuoqiRepay) { var dic = Utils.UrlParamToData(req.remarks); int repayId = Utils.StrToInt(dic["repayTaskId"], 0); context.GainLoanerRepayment(DateTime.Now, repayId, (int) msg.UserIdIdentity, Utils.StrToDecimal(msg.Sum, 0)); //如果是手动还款立刻发送本息到账请求 TODO 是否需要? if (!msg.AutoRepay) { RequestApiHandle.SendReturnPrinInte(msg.ProjectCode, msg.Sum, repayId, Utils.StrToBool(dic["isEarly"], false), false); } } msg.HasHandle = true; } else msg.Remarks = "请求没有包含还款计划信息!"; } else msg.Remarks = "没有找到平台项目,项目编号为:" + msg.ProjectCode; } else msg.Remarks = "没有找到对应的还款请求,请求编号为:" + msg.RequestId; } } } } catch (ChangeConflictException) { MessageBus.Main.Publish(msg); } catch (Exception ex) { msg.Remarks = "内部错误:" + ex.Message; } }