package com.java110.order.api; import com.alibaba.fastjson.JSONObject; import com.java110.common.constant.ResponseConstant; import com.java110.common.exception.BusinessException; import com.java110.common.util.Assert; import com.java110.core.base.controller.BaseController; import com.java110.event.center.DataFlowEventPublishing; import com.java110.order.smo.IOrderServiceSMO; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiOperation; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.HttpServletRequest; import java.util.HashMap; import java.util.Map; /** * @author wux * @create 2019-02-05 上午10:29 * @desc 订单接口服务类 **/ @RestController @RequestMapping(path = "/orderApi") public class OrderApi extends BaseController { private final static Logger logger = LoggerFactory.getLogger(OrderApi.class); @Autowired private IOrderServiceSMO orderServiceSMOImpl; @RequestMapping(path = "/service",method= RequestMethod.POST) @ApiOperation(value="中心服务订单受理", notes="test: 返回 200 表示服务受理成功,其他表示失败") @ApiImplicitParam(paramType="query", name = "orderInfo", value = "订单受理信息", required = true, dataType = "String") public ResponseEntity servicePost(@RequestBody String orderInfo, HttpServletRequest request) { ResponseEntity responseEntity = null; try { Map headers = new HashMap(); getRequestInfo(request, headers); logger.debug("订单服务请求报文为: {},请求头为:{}",orderInfo,headers); //接受请求事件 DataFlowEventPublishing.receiveRequest(orderInfo,headers); //预校验 preValiateOrderInfo(orderInfo); responseEntity = orderServiceSMOImpl.service(orderInfo, headers); }catch (Exception e){ logger.error("请求订单异常",e); responseEntity = new ResponseEntity("请求中心服务发生异常,"+e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR); }finally { logger.debug("订单服务返回报文为: {}",responseEntity); return responseEntity; } } /** * 这里预校验,请求报文中不能有 dataFlowId * @param orderInfo */ private void preValiateOrderInfo(String orderInfo) { Assert.jsonObjectHaveKey(orderInfo,"orders","请求报文中未包含orders节点,"+orderInfo); Assert.jsonObjectHaveKey(orderInfo,"business","请求报文中未包含business节点,"+orderInfo); if(JSONObject.parseObject(orderInfo).getJSONObject("orders").containsKey("dataFlowId")){ throw new BusinessException(ResponseConstant.RESULT_CODE_ERROR,"报文中不能存在dataFlowId节点"); } } /** * 这里预校验,请求报文中不能有 dataFlowId * @param orderInfo */ private void preValiateOrderInfo(String orderInfo,Map headers) { Assert.hasKey(headers,"serviceCode","没有包含serviceCode"); Assert.hasLength(headers.get("serviceCode"),"serviceCode 不能为空"); Assert.hasKey(headers,"appId","没有包含appId"); Assert.hasLength(headers.get("appId"),"appId 不能为空"); } /** * 获取请求信息 * @param request * @param headers * @throws RuntimeException */ private void getRequestInfo(HttpServletRequest request,Map headers) throws Exception{ try{ super.initHeadParam(request,headers); super.initUrlParam(request,headers); }catch (Exception e){ logger.error("加载头信息失败",e); throw e; } } public IOrderServiceSMO getOrderServiceSMOImpl() { return orderServiceSMOImpl; } public void setOrderServiceSMOImpl(IOrderServiceSMO orderServiceSMOImpl) { this.orderServiceSMOImpl = orderServiceSMOImpl; } }