AppExceptionHandler.java 2.5 KB
Newer Older
武汉红喜's avatar
武汉红喜 已提交
1
package org.hongxi.whatsmars.spring.boot.exception;
武汉红喜's avatar
武汉红喜 已提交
2 3 4

import com.alibaba.fastjson.JSON;
import com.google.common.collect.Maps;
武汉红喜's avatar
武汉红喜 已提交
5
import org.hongxi.whatsmars.common.result.Result;
武汉红喜's avatar
武汉红喜 已提交
6
import org.hongxi.whatsmars.spring.boot.common.ProfileUtils;
武汉红喜's avatar
武汉红喜 已提交
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.logging.LogLevel;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;
import java.util.Map;

/**
 * 异常信息拦截
 * Created by shenhongxi on 2017/11/16.
 */
@ControllerAdvice(annotations = { RestController.class, Controller.class})
武汉红喜's avatar
武汉红喜 已提交
25
public class AppExceptionHandler {
武汉红喜's avatar
武汉红喜 已提交
26

武汉红喜's avatar
slf4j  
武汉红喜 已提交
27
    private final Logger logger = LoggerFactory.getLogger(getClass());
武汉红喜's avatar
武汉红喜 已提交
28 29 30 31

    /**
     * 业务异常处理,直接返回异常信息提示
     */
武汉红喜's avatar
武汉红喜 已提交
32
    @ExceptionHandler(AppException.class)
武汉红喜's avatar
武汉红喜 已提交
33
    public ResponseEntity<Result> businessExceptionHandle(AppException exception, HttpServletRequest request) {
武汉红喜's avatar
武汉红喜 已提交
34
        logError(exception, request, LogLevel.WARN);
武汉红喜's avatar
武汉红喜 已提交
35
        return new ResponseEntity<Result>(exception.toResult(), HttpStatus.OK);
武汉红喜's avatar
武汉红喜 已提交
36 37 38 39 40 41
    }

    /**
     * 其他为定义异常,统一返回默认错误信息,避免打印出异常堆栈
     */
    @ExceptionHandler(Exception.class)
武汉红喜's avatar
武汉红喜 已提交
42
    public ResponseEntity<Result> defaultExceptionHandle(Exception exception, HttpServletRequest request) {
武汉红喜's avatar
武汉红喜 已提交
43
        logError(exception, request, LogLevel.ERROR);
武汉红喜's avatar
武汉红喜 已提交
44
        return new ResponseEntity<Result>(new Result(AppException.Code.ERROR.getValue(), ProfileUtils.isDev() ? exception.getMessage() : "操作失败"), HttpStatus.OK);
武汉红喜's avatar
武汉红喜 已提交
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
    }


    public void logError(Exception ex, HttpServletRequest request, LogLevel logLevel) {
        Map<String, String> map = Maps.newHashMap();
        map.put("message", ex.getMessage());
        map.put("from", request.getRemoteAddr());
        final String queryString = request.getQueryString();
        map.put("path", queryString != null ? (request.getRequestURI() + "?" + queryString) : request.getRequestURI());

        switch (logLevel) {
            case ERROR:
                logger.error(JSON.toJSONString(map), ex);
                break;
            case WARN:
                logger.warn(JSON.toJSONString(map));
                break;
        }

    }

}