创建新 user 服务项目
							parent
							
								
									bdff67b7b3
								
							
						
					
					
						commit
						cc9696938a
					
				|  | @ -12,6 +12,8 @@ | |||
|     <artifactId>mall-spring-boot-starter-swagger</artifactId> | ||||
| 
 | ||||
|     <dependencies> | ||||
| 
 | ||||
| 
 | ||||
|         <!-- Spring 核心 --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|  |  | |||
|  | @ -12,6 +12,13 @@ | |||
|     <artifactId>mall-spring-boot-starter-web</artifactId> | ||||
| 
 | ||||
|     <dependencies> | ||||
|         <!-- Mall 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>system-rpc-api</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- Spring 核心 --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|  | @ -24,6 +31,12 @@ | |||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-web</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- RPC 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>org.apache.dubbo</groupId> | ||||
|             <artifactId>dubbo</artifactId> | ||||
|         </dependency> | ||||
|     </dependencies> | ||||
| 
 | ||||
| </project> | ||||
|  |  | |||
|  | @ -0,0 +1,23 @@ | |||
| package cn.iocoder.mall.web.config; | ||||
| 
 | ||||
| import cn.iocoder.mall.web.interceptor.AccessLogInterceptor; | ||||
| import org.apache.dubbo.config.annotation.Reference; | ||||
| import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication; | ||||
| import org.springframework.context.annotation.Bean; | ||||
| import org.springframework.context.annotation.Configuration; | ||||
| import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; | ||||
| 
 | ||||
| @Configuration | ||||
| @ConditionalOnWebApplication(type = ConditionalOnWebApplication.Type.SERVLET) // TODO 芋艿,未来可能考虑 REACTIVE
 | ||||
| public class CommonWebAutoConfiguration implements WebMvcConfigurer { | ||||
| 
 | ||||
|     @Reference(validation = "true", version = "${dubbo.consumer.AdminAccessLogService.version:1.0.0}") | ||||
| //    @Reference(validation = "true", version = "1.0.0")
 | ||||
| //    private SystemLogRPC systemLogRPC;
 | ||||
| 
 | ||||
|     @Bean | ||||
|     public AccessLogInterceptor accessLogInterceptor() { | ||||
|         return new AccessLogInterceptor(); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  | @ -1,131 +1,103 @@ | |||
| package cn.iocoder.mall.web.handler; | ||||
| 
 | ||||
| import cn.iocoder.common.framework.constant.SysErrorCodeEnum; | ||||
| import cn.iocoder.common.framework.exception.ServiceException; | ||||
| import cn.iocoder.common.framework.util.ExceptionUtil; | ||||
| import cn.iocoder.common.framework.util.HttpUtil; | ||||
| import cn.iocoder.common.framework.util.MallUtil; | ||||
| import cn.iocoder.common.framework.vo.CommonResult; | ||||
| import cn.iocoder.mall.system.api.SystemLogService; | ||||
| import cn.iocoder.mall.system.api.dto.systemlog.AccessLogAddDTO; | ||||
| import cn.iocoder.mall.system.api.dto.systemlog.ExceptionLogAddDTO; | ||||
| import com.alibaba.fastjson.JSON; | ||||
| import io.micrometer.core.instrument.Counter; | ||||
| import io.micrometer.core.instrument.Metrics; | ||||
| import org.apache.commons.lang3.exception.ExceptionUtils; | ||||
| import org.apache.dubbo.config.annotation.Reference; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
| import org.springframework.beans.factory.annotation.Value; | ||||
| import org.springframework.scheduling.annotation.Async; | ||||
| import org.springframework.util.Assert; | ||||
| import org.springframework.web.bind.MissingServletRequestParameterException; | ||||
| import org.springframework.web.bind.annotation.ControllerAdvice; | ||||
| import org.springframework.web.bind.annotation.ExceptionHandler; | ||||
| import org.springframework.web.bind.annotation.ResponseBody; | ||||
| 
 | ||||
| import javax.servlet.http.HttpServletRequest; | ||||
| import javax.validation.ConstraintViolationException; | ||||
| import java.util.Date; | ||||
| 
 | ||||
| @ControllerAdvice | ||||
| public class GlobalExceptionHandler { | ||||
| 
 | ||||
| //    /**
 | ||||
| //     * 异常总数 Metrics
 | ||||
| //     */
 | ||||
| //    private static final Counter EXCEPTION_COUNTER = Metrics.counter("mall.exception.total");
 | ||||
| 
 | ||||
|     private Logger logger = LoggerFactory.getLogger(getClass()); | ||||
| 
 | ||||
|     @Value("${spring.application.name}") | ||||
|     private String applicationName; | ||||
| 
 | ||||
|     @Reference(validation = "true", version = "${dubbo.consumer.AdminAccessLogService.version:1.0.0}") | ||||
|     private SystemLogService systemLogService; | ||||
| 
 | ||||
|     // 逻辑异常
 | ||||
|     @ResponseBody | ||||
|     @ExceptionHandler(value = ServiceException.class) | ||||
|     public CommonResult serviceExceptionHandler(HttpServletRequest req, ServiceException ex) { | ||||
|         logger.debug("[serviceExceptionHandler]", ex); | ||||
|         return CommonResult.error(ex.getCode(), ex.getMessage()); | ||||
|     } | ||||
| 
 | ||||
|     // Spring MVC 参数不正确
 | ||||
|     @ResponseBody | ||||
|     @ExceptionHandler(value = MissingServletRequestParameterException.class) | ||||
|     public CommonResult missingServletRequestParameterExceptionHandler(HttpServletRequest req, MissingServletRequestParameterException ex) { | ||||
|         logger.warn("[missingServletRequestParameterExceptionHandler]", ex); | ||||
|         return CommonResult.error(SysErrorCodeEnum.MISSING_REQUEST_PARAM_ERROR.getCode(), SysErrorCodeEnum.MISSING_REQUEST_PARAM_ERROR.getMessage() + ":" + ex.getMessage()); | ||||
|     } | ||||
| 
 | ||||
|     @ResponseBody | ||||
|     @ExceptionHandler(value = ConstraintViolationException.class) | ||||
|     public CommonResult constraintViolationExceptionHandler(HttpServletRequest req, ConstraintViolationException ex) { | ||||
|         logger.info("[constraintViolationExceptionHandler]", ex); | ||||
|         // TODO 芋艿,后续要想一个更好的方式。
 | ||||
|         // 拼接详细报错
 | ||||
|         StringBuilder detailMessage = new StringBuilder("\n\n详细错误如下:"); | ||||
|         ex.getConstraintViolations().forEach(constraintViolation -> detailMessage.append("\n").append(constraintViolation.getMessage())); | ||||
|         return CommonResult.error(SysErrorCodeEnum.VALIDATION_REQUEST_PARAM_ERROR.getCode(), SysErrorCodeEnum.VALIDATION_REQUEST_PARAM_ERROR.getMessage() | ||||
|             + detailMessage.toString()); | ||||
|     } | ||||
| 
 | ||||
|     // TODO 芋艿,应该还有其它的异常,需要进行翻译
 | ||||
|     @ResponseBody | ||||
|     @ExceptionHandler(value = Exception.class) | ||||
|     public CommonResult exceptionHandler(HttpServletRequest req, Exception e) { | ||||
|         logger.error("[exceptionHandler]", e); | ||||
|         // 插入异常日志
 | ||||
|         ExceptionLogAddDTO exceptionLog = new ExceptionLogAddDTO(); | ||||
|         try { | ||||
|             // 增加异常计数 metrics
 | ||||
|             EXCEPTION_COUNTER.increment(); | ||||
|             // 初始化 exceptionLog
 | ||||
|             initExceptionLog(exceptionLog, req, e); | ||||
|             // 执行插入 exceptionLog
 | ||||
|             addExceptionLog(exceptionLog); | ||||
|         } catch (Throwable th) { | ||||
|             logger.error("[exceptionHandler][插入访问日志({}) 发生异常({})", JSON.toJSONString(exceptionLog), ExceptionUtils.getRootCauseMessage(th)); | ||||
|         } | ||||
|         // 返回 ERROR CommonResult
 | ||||
|         return CommonResult.error(SysErrorCodeEnum.SYS_ERROR.getCode(), SysErrorCodeEnum.SYS_ERROR.getMessage()); | ||||
|     } | ||||
| 
 | ||||
|     private void initExceptionLog(ExceptionLogAddDTO exceptionLog, HttpServletRequest request,  Exception e) { | ||||
|         // 设置用户编号
 | ||||
|         exceptionLog.setUserId(MallUtil.getUserId(request)); | ||||
|         if (exceptionLog.getUserId() == null) { | ||||
|             exceptionLog.setUserId(AccessLogAddDTO.USER_ID_NULL); | ||||
|         } | ||||
|         exceptionLog.setUserType(MallUtil.getUserType(request)); | ||||
|         // 设置异常字段
 | ||||
|         exceptionLog.setExceptionName(e.getClass().getName()); | ||||
|         exceptionLog.setExceptionMessage(ExceptionUtil.getMessage(e)); | ||||
|         exceptionLog.setExceptionRootCauseMessage(ExceptionUtil.getRootCauseMessage(e)); | ||||
|         exceptionLog.setExceptionStackTrace(ExceptionUtil.getStackTrace(e)); | ||||
|         StackTraceElement[] stackTraceElements = e.getStackTrace(); | ||||
|         Assert.notEmpty(stackTraceElements, "异常 stackTraceElements 不能为空"); | ||||
|         StackTraceElement stackTraceElement = stackTraceElements[0]; | ||||
|         exceptionLog.setExceptionClassName(stackTraceElement.getClassName()); | ||||
|         exceptionLog.setExceptionFileName(stackTraceElement.getFileName()); | ||||
|         exceptionLog.setExceptionMethodName(stackTraceElement.getMethodName()); | ||||
|         exceptionLog.setExceptionLineNumber(stackTraceElement.getLineNumber()); | ||||
|         // 设置其它字段
 | ||||
|         exceptionLog.setTraceId(MallUtil.getTraceId()) | ||||
|                 .setApplicationName(applicationName) | ||||
|                 .setUri(request.getRequestURI()) // TODO 提升:如果想要优化,可以使用 Swagger 的 @ApiOperation 注解。
 | ||||
|                 .setQueryString(HttpUtil.buildQueryString(request)) | ||||
|                 .setMethod(request.getMethod()) | ||||
|                 .setUserAgent(HttpUtil.getUserAgent(request)) | ||||
|                 .setIp(HttpUtil.getIp(request)) | ||||
|                 .setExceptionTime(new Date()); | ||||
|     } | ||||
| 
 | ||||
|     @Async | ||||
|     public void addExceptionLog(ExceptionLogAddDTO exceptionLog) { | ||||
|         systemLogService.addExceptionLog(exceptionLog); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| //@ControllerAdvice
 | ||||
| //public class GlobalExceptionHandler {
 | ||||
| //
 | ||||
| ////    /**
 | ||||
| ////     * 异常总数 Metrics
 | ||||
| ////     */
 | ||||
| ////    private static final Counter EXCEPTION_COUNTER = Metrics.counter("mall.exception.total");
 | ||||
| //
 | ||||
| //    private Logger logger = LoggerFactory.getLogger(getClass());
 | ||||
| //
 | ||||
| //    @Value("${spring.application.name}")
 | ||||
| //    private String applicationName;
 | ||||
| //
 | ||||
| //    @Reference(validation = "true", version = "${dubbo.consumer.AdminAccessLogService.version:1.0.0}")
 | ||||
| //    private SystemLogService systemLogService;
 | ||||
| //
 | ||||
| //    // 逻辑异常
 | ||||
| //    @ResponseBody
 | ||||
| //    @ExceptionHandler(value = ServiceException.class)
 | ||||
| //    public CommonResult serviceExceptionHandler(HttpServletRequest req, ServiceException ex) {
 | ||||
| //        logger.debug("[serviceExceptionHandler]", ex);
 | ||||
| //        return CommonResult.error(ex.getCode(), ex.getMessage());
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    // Spring MVC 参数不正确
 | ||||
| //    @ResponseBody
 | ||||
| //    @ExceptionHandler(value = MissingServletRequestParameterException.class)
 | ||||
| //    public CommonResult missingServletRequestParameterExceptionHandler(HttpServletRequest req, MissingServletRequestParameterException ex) {
 | ||||
| //        logger.warn("[missingServletRequestParameterExceptionHandler]", ex);
 | ||||
| //        return CommonResult.error(SysErrorCodeEnum.MISSING_REQUEST_PARAM_ERROR.getCode(), SysErrorCodeEnum.MISSING_REQUEST_PARAM_ERROR.getMessage() + ":" + ex.getMessage());
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    @ResponseBody
 | ||||
| //    @ExceptionHandler(value = ConstraintViolationException.class)
 | ||||
| //    public CommonResult constraintViolationExceptionHandler(HttpServletRequest req, ConstraintViolationException ex) {
 | ||||
| //        logger.info("[constraintViolationExceptionHandler]", ex);
 | ||||
| //        // TODO 芋艿,后续要想一个更好的方式。
 | ||||
| //        // 拼接详细报错
 | ||||
| //        StringBuilder detailMessage = new StringBuilder("\n\n详细错误如下:");
 | ||||
| //        ex.getConstraintViolations().forEach(constraintViolation -> detailMessage.append("\n").append(constraintViolation.getMessage()));
 | ||||
| //        return CommonResult.error(SysErrorCodeEnum.VALIDATION_REQUEST_PARAM_ERROR.getCode(), SysErrorCodeEnum.VALIDATION_REQUEST_PARAM_ERROR.getMessage()
 | ||||
| //            + detailMessage.toString());
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    // TODO 芋艿,应该还有其它的异常,需要进行翻译
 | ||||
| //    @ResponseBody
 | ||||
| //    @ExceptionHandler(value = Exception.class)
 | ||||
| //    public CommonResult exceptionHandler(HttpServletRequest req, Exception e) {
 | ||||
| //        logger.error("[exceptionHandler]", e);
 | ||||
| //        // 插入异常日志
 | ||||
| //        ExceptionLogAddDTO exceptionLog = new ExceptionLogAddDTO();
 | ||||
| //        try {
 | ||||
| //            // 增加异常计数 metrics
 | ||||
| //            EXCEPTION_COUNTER.increment();
 | ||||
| //            // 初始化 exceptionLog
 | ||||
| //            initExceptionLog(exceptionLog, req, e);
 | ||||
| //            // 执行插入 exceptionLog
 | ||||
| //            addExceptionLog(exceptionLog);
 | ||||
| //        } catch (Throwable th) {
 | ||||
| //            logger.error("[exceptionHandler][插入访问日志({}) 发生异常({})", JSON.toJSONString(exceptionLog), ExceptionUtils.getRootCauseMessage(th));
 | ||||
| //        }
 | ||||
| //        // 返回 ERROR CommonResult
 | ||||
| //        return CommonResult.error(SysErrorCodeEnum.SYS_ERROR.getCode(), SysErrorCodeEnum.SYS_ERROR.getMessage());
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    private void initExceptionLog(ExceptionLogAddDTO exceptionLog, HttpServletRequest request,  Exception e) {
 | ||||
| //        // 设置用户编号
 | ||||
| //        exceptionLog.setUserId(MallUtil.getUserId(request));
 | ||||
| //        if (exceptionLog.getUserId() == null) {
 | ||||
| //            exceptionLog.setUserId(AccessLogAddDTO.USER_ID_NULL);
 | ||||
| //        }
 | ||||
| //        exceptionLog.setUserType(MallUtil.getUserType(request));
 | ||||
| //        // 设置异常字段
 | ||||
| //        exceptionLog.setExceptionName(e.getClass().getName());
 | ||||
| //        exceptionLog.setExceptionMessage(ExceptionUtil.getMessage(e));
 | ||||
| //        exceptionLog.setExceptionRootCauseMessage(ExceptionUtil.getRootCauseMessage(e));
 | ||||
| //        exceptionLog.setExceptionStackTrace(ExceptionUtil.getStackTrace(e));
 | ||||
| //        StackTraceElement[] stackTraceElements = e.getStackTrace();
 | ||||
| //        Assert.notEmpty(stackTraceElements, "异常 stackTraceElements 不能为空");
 | ||||
| //        StackTraceElement stackTraceElement = stackTraceElements[0];
 | ||||
| //        exceptionLog.setExceptionClassName(stackTraceElement.getClassName());
 | ||||
| //        exceptionLog.setExceptionFileName(stackTraceElement.getFileName());
 | ||||
| //        exceptionLog.setExceptionMethodName(stackTraceElement.getMethodName());
 | ||||
| //        exceptionLog.setExceptionLineNumber(stackTraceElement.getLineNumber());
 | ||||
| //        // 设置其它字段
 | ||||
| //        exceptionLog.setTraceId(MallUtil.getTraceId())
 | ||||
| //                .setApplicationName(applicationName)
 | ||||
| //                .setUri(request.getRequestURI()) // TODO 提升:如果想要优化,可以使用 Swagger 的 @ApiOperation 注解。
 | ||||
| //                .setQueryString(HttpUtil.buildQueryString(request))
 | ||||
| //                .setMethod(request.getMethod())
 | ||||
| //                .setUserAgent(HttpUtil.getUserAgent(request))
 | ||||
| //                .setIp(HttpUtil.getIp(request))
 | ||||
| //                .setExceptionTime(new Date());
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    @Async
 | ||||
| //    public void addExceptionLog(ExceptionLogAddDTO exceptionLog) {
 | ||||
| //        systemLogService.addExceptionLog(exceptionLog);
 | ||||
| //    }
 | ||||
| //
 | ||||
| //}
 | ||||
|  |  | |||
|  | @ -1,31 +1,21 @@ | |||
| package cn.iocoder.mall.web.handler; | ||||
| 
 | ||||
| import cn.iocoder.common.framework.util.MallUtil; | ||||
| import cn.iocoder.common.framework.vo.CommonResult; | ||||
| import org.springframework.core.MethodParameter; | ||||
| import org.springframework.http.MediaType; | ||||
| import org.springframework.http.server.ServerHttpRequest; | ||||
| import org.springframework.http.server.ServerHttpResponse; | ||||
| import org.springframework.http.server.ServletServerHttpRequest; | ||||
| import org.springframework.web.bind.annotation.ControllerAdvice; | ||||
| import org.springframework.web.servlet.mvc.method.annotation.ResponseBodyAdvice; | ||||
| 
 | ||||
| @ControllerAdvice | ||||
| public class GlobalResponseBodyHandler implements ResponseBodyAdvice { | ||||
| 
 | ||||
|     @Override | ||||
|     public boolean supports(MethodParameter returnType, Class converterType) { | ||||
|         if (returnType.getMethod() == null) { | ||||
|             return false; | ||||
|         } | ||||
|         return returnType.getMethod().getReturnType() == CommonResult.class; | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType, Class selectedConverterType, | ||||
|                                   ServerHttpRequest request, ServerHttpResponse response) { | ||||
|         MallUtil.setCommonResult(((ServletServerHttpRequest) request).getServletRequest(), (CommonResult) body); | ||||
|         return body; | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| //@ControllerAdvice
 | ||||
| //public class GlobalResponseBodyHandler implements ResponseBodyAdvice {
 | ||||
| //
 | ||||
| //    @Override
 | ||||
| //    public boolean supports(MethodParameter returnType, Class converterType) {
 | ||||
| //        if (returnType.getMethod() == null) {
 | ||||
| //            return false;
 | ||||
| //        }
 | ||||
| //        return returnType.getMethod().getReturnType() == CommonResult.class;
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    @Override
 | ||||
| //    public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType, Class selectedConverterType,
 | ||||
| //                                  ServerHttpRequest request, ServerHttpResponse response) {
 | ||||
| //        MallUtil.setCommonResult(((ServletServerHttpRequest) request).getServletRequest(), (CommonResult) body);
 | ||||
| //        return body;
 | ||||
| //    }
 | ||||
| //
 | ||||
| //}
 | ||||
|  |  | |||
|  | @ -1,102 +1,102 @@ | |||
| package cn.iocoder.mall.web.interceptor; | ||||
| 
 | ||||
| import cn.iocoder.common.framework.util.HttpUtil; | ||||
| import cn.iocoder.common.framework.util.MallUtil; | ||||
| import cn.iocoder.common.framework.vo.CommonResult; | ||||
| import cn.iocoder.mall.system.api.SystemLogService; | ||||
| import cn.iocoder.mall.system.api.dto.systemlog.AccessLogAddDTO; | ||||
| import com.alibaba.fastjson.JSON; | ||||
| import org.apache.commons.lang3.exception.ExceptionUtils; | ||||
| import org.apache.dubbo.config.annotation.Reference; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
| import org.springframework.beans.factory.annotation.Value; | ||||
| import org.springframework.scheduling.annotation.Async; | ||||
| import org.springframework.stereotype.Component; | ||||
| import org.springframework.util.Assert; | ||||
| import org.springframework.beans.BeansException; | ||||
| import org.springframework.beans.factory.InitializingBean; | ||||
| import org.springframework.context.ApplicationContext; | ||||
| import org.springframework.context.ApplicationContextAware; | ||||
| import org.springframework.web.servlet.handler.HandlerInterceptorAdapter; | ||||
| 
 | ||||
| import javax.servlet.http.HttpServletRequest; | ||||
| import javax.servlet.http.HttpServletResponse; | ||||
| import java.util.Date; | ||||
| 
 | ||||
| /** | ||||
|  * 访问日志拦截器 | ||||
|  */ | ||||
| @Component | ||||
| public class AccessLogInterceptor extends HandlerInterceptorAdapter { | ||||
| public class AccessLogInterceptor extends HandlerInterceptorAdapter implements InitializingBean, ApplicationContextAware { | ||||
| 
 | ||||
|     private Logger logger = LoggerFactory.getLogger(getClass()); | ||||
|     private ApplicationContext context; | ||||
| 
 | ||||
|     /** | ||||
|      * 开始时间 | ||||
|      */ | ||||
|     private static final ThreadLocal<Date> START_TIME = new ThreadLocal<>(); | ||||
| 
 | ||||
|     @Reference(validation = "true", version = "${dubbo.consumer.AdminAccessLogService.version:1.0.0}") | ||||
|     private SystemLogService systemAccessLogService; | ||||
| 
 | ||||
|     @Value("${spring.application.name}") | ||||
|     private String applicationName; | ||||
| //
 | ||||
| //    private Logger logger = LoggerFactory.getLogger(getClass());
 | ||||
| //
 | ||||
| //    /**
 | ||||
| //     * 开始时间
 | ||||
| //     */
 | ||||
| //    private static final ThreadLocal<Date> START_TIME = new ThreadLocal<>();
 | ||||
| //
 | ||||
| //    @Reference(validation = "true", version = "${dubbo.consumer.AdminAccessLogService.version:1.0.0}")
 | ||||
| //    private SystemLogService systemAccessLogService;
 | ||||
| //
 | ||||
| //    @Value("${spring.application.name}")
 | ||||
| //    private String applicationName;
 | ||||
| //
 | ||||
| //    @Override
 | ||||
| //    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
 | ||||
| //        // 记录当前时间
 | ||||
| //        START_TIME.set(new Date());
 | ||||
| //        return true;
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    @Override
 | ||||
| //    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
 | ||||
| //        AccessLogAddDTO accessLog = new AccessLogAddDTO();
 | ||||
| //        try {
 | ||||
| //            // 初始化 accessLog
 | ||||
| //            initAccessLog(accessLog, request);
 | ||||
| //            // 执行插入 accessLog
 | ||||
| //            addAccessLog(accessLog);
 | ||||
| //            // TODO 提升:暂时不考虑 ELK 的方案。而是基于 MySQL 存储。如果访问日志比较多,需要定期归档。
 | ||||
| //        } catch (Throwable th) {
 | ||||
| //            logger.error("[afterCompletion][插入访问日志({}) 发生异常({})", JSON.toJSONString(accessLog), ExceptionUtils.getRootCauseMessage(th));
 | ||||
| //        } finally {
 | ||||
| //            clear();
 | ||||
| //        }
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    private void initAccessLog(AccessLogAddDTO accessLog, HttpServletRequest request) {
 | ||||
| //        // 设置用户编号
 | ||||
| //        accessLog.setUserId(MallUtil.getUserId(request));
 | ||||
| //        if (accessLog.getUserId() == null) {
 | ||||
| //            accessLog.setUserId(AccessLogAddDTO.USER_ID_NULL);
 | ||||
| //        }
 | ||||
| //        accessLog.setUserType(MallUtil.getUserType(request));
 | ||||
| //        // 设置访问结果
 | ||||
| //        CommonResult result = MallUtil.getCommonResult(request);
 | ||||
| //        Assert.isTrue(result != null, "result 必须非空");
 | ||||
| //        accessLog.setErrorCode(result.getCode())
 | ||||
| //                .setErrorMessage(result.getMessage());
 | ||||
| //        // 设置其它字段
 | ||||
| //        accessLog.setTraceId(MallUtil.getTraceId())
 | ||||
| //                .setApplicationName(applicationName)
 | ||||
| //                .setUri(request.getRequestURI()) // TODO 提升:如果想要优化,可以使用 Swagger 的 @ApiOperation 注解。
 | ||||
| //                .setQueryString(HttpUtil.buildQueryString(request))
 | ||||
| //                .setMethod(request.getMethod())
 | ||||
| //                .setUserAgent(HttpUtil.getUserAgent(request))
 | ||||
| //                .setIp(HttpUtil.getIp(request))
 | ||||
| //                .setStartTime(START_TIME.get())
 | ||||
| //                .setResponseTime((int) (System.currentTimeMillis() - accessLog.getStartTime().getTime())); // 默认响应时间设为 0
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    @Async // 异步入库
 | ||||
| //    public void addAccessLog(AccessLogAddDTO accessLog) {
 | ||||
| //        try {
 | ||||
| //            systemAccessLogService.addAccessLog(accessLog);
 | ||||
| //        } catch (Throwable th) {
 | ||||
| //            logger.error("[addAccessLog][插入访问日志({}) 发生异常({})", JSON.toJSONString(accessLog), ExceptionUtils.getRootCauseMessage(th));
 | ||||
| //        }
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    private static void clear() {
 | ||||
| //        START_TIME.remove();
 | ||||
| //    }
 | ||||
| //
 | ||||
| 
 | ||||
|     @Override | ||||
|     public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) { | ||||
|         // 记录当前时间
 | ||||
|         START_TIME.set(new Date()); | ||||
|         return true; | ||||
|     public void setApplicationContext(ApplicationContext context) throws BeansException { | ||||
|         this.context = context; | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) { | ||||
|         AccessLogAddDTO accessLog = new AccessLogAddDTO(); | ||||
|         try { | ||||
|             // 初始化 accessLog
 | ||||
|             initAccessLog(accessLog, request); | ||||
|             // 执行插入 accessLog
 | ||||
|             addAccessLog(accessLog); | ||||
|             // TODO 提升:暂时不考虑 ELK 的方案。而是基于 MySQL 存储。如果访问日志比较多,需要定期归档。
 | ||||
|         } catch (Throwable th) { | ||||
|             logger.error("[afterCompletion][插入访问日志({}) 发生异常({})", JSON.toJSONString(accessLog), ExceptionUtils.getRootCauseMessage(th)); | ||||
|         } finally { | ||||
|             clear(); | ||||
|         } | ||||
|     public void afterPropertiesSet() throws Exception { | ||||
|         System.out.println(); | ||||
|     } | ||||
| 
 | ||||
|     private void initAccessLog(AccessLogAddDTO accessLog, HttpServletRequest request) { | ||||
|         // 设置用户编号
 | ||||
|         accessLog.setUserId(MallUtil.getUserId(request)); | ||||
|         if (accessLog.getUserId() == null) { | ||||
|             accessLog.setUserId(AccessLogAddDTO.USER_ID_NULL); | ||||
|         } | ||||
|         accessLog.setUserType(MallUtil.getUserType(request)); | ||||
|         // 设置访问结果
 | ||||
|         CommonResult result = MallUtil.getCommonResult(request); | ||||
|         Assert.isTrue(result != null, "result 必须非空"); | ||||
|         accessLog.setErrorCode(result.getCode()) | ||||
|                 .setErrorMessage(result.getMessage()); | ||||
|         // 设置其它字段
 | ||||
|         accessLog.setTraceId(MallUtil.getTraceId()) | ||||
|                 .setApplicationName(applicationName) | ||||
|                 .setUri(request.getRequestURI()) // TODO 提升:如果想要优化,可以使用 Swagger 的 @ApiOperation 注解。
 | ||||
|                 .setQueryString(HttpUtil.buildQueryString(request)) | ||||
|                 .setMethod(request.getMethod()) | ||||
|                 .setUserAgent(HttpUtil.getUserAgent(request)) | ||||
|                 .setIp(HttpUtil.getIp(request)) | ||||
|                 .setStartTime(START_TIME.get()) | ||||
|                 .setResponseTime((int) (System.currentTimeMillis() - accessLog.getStartTime().getTime())); // 默认响应时间设为 0
 | ||||
|     } | ||||
| 
 | ||||
|     @Async // 异步入库
 | ||||
|     public void addAccessLog(AccessLogAddDTO accessLog) { | ||||
|         try { | ||||
|             systemAccessLogService.addAccessLog(accessLog); | ||||
|         } catch (Throwable th) { | ||||
|             logger.error("[addAccessLog][插入访问日志({}) 发生异常({})", JSON.toJSONString(accessLog), ExceptionUtils.getRootCauseMessage(th)); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     private static void clear() { | ||||
|         START_TIME.remove(); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -1 +0,0 @@ | |||
| package cn.iocoder.mall.web; | ||||
|  | @ -0,0 +1,2 @@ | |||
| org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ | ||||
|   cn.iocoder.mall.web.config.CommonWebAutoConfiguration | ||||
|  | @ -4,4 +4,4 @@ spring: | |||
|     name: admin-application | ||||
|   # Profile 的配置项 | ||||
|   profiles: | ||||
|     active: test | ||||
|     active: local | ||||
|  |  | |||
|  | @ -22,14 +22,17 @@ | |||
| 
 | ||||
|         <!-- Web 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-web</artifactId> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>mall-spring-boot-starter-web</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>mall-spring-boot-starter-swagger</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- TODO 云服务 --> | ||||
|         <dependency> | ||||
|             <groupId>com.qiniu</groupId> | ||||
|             <artifactId>qiniu-java-sdk</artifactId> | ||||
|  |  | |||
|  | @ -9,7 +9,6 @@ import org.springframework.beans.factory.annotation.Autowired; | |||
| import org.springframework.beans.factory.annotation.Value; | ||||
| import org.springframework.web.bind.annotation.GetMapping; | ||||
| import org.springframework.web.bind.annotation.RequestMapping; | ||||
| import org.springframework.web.bind.annotation.RestController; | ||||
| 
 | ||||
| /** | ||||
|  * 文件模块(Admins API) | ||||
|  | @ -17,7 +16,7 @@ import org.springframework.web.bind.annotation.RestController; | |||
|  * author: sin | ||||
|  * time: 2020/4/20 9:41 上午 | ||||
|  */ | ||||
| @RestController | ||||
| //@RestController
 | ||||
| @RequestMapping("admins/file") | ||||
| @Api(tags = "文件模块") | ||||
| public class AdminsFileController { | ||||
|  |  | |||
							
								
								
									
										12
									
								
								user/pom.xml
								
								
								
								
							
							
						
						
									
										12
									
								
								user/pom.xml
								
								
								
								
							|  | @ -12,17 +12,21 @@ | |||
|     <artifactId>user</artifactId> | ||||
|     <packaging>pom</packaging> | ||||
|     <modules> | ||||
| <!--        <module>user-application</module>--> | ||||
| <!--        <module>user-service-api</module>--> | ||||
| <!--        <module>user-sdk</module>--> | ||||
| <!--        <module>user-service-impl</module>--> | ||||
|         <module>user-application</module> | ||||
|         <module>user-service-api</module> | ||||
|         <module>user-sdk</module> | ||||
|         <module>user-service-impl</module> | ||||
|         <module>user-rest</module> | ||||
|         <module>user-rpc</module> | ||||
|         <module>user-rpc-api</module> | ||||
|     </modules> | ||||
| 
 | ||||
|     <dependencyManagement> | ||||
|         <dependencies> | ||||
|             <dependency> | ||||
|                 <groupId>cn.iocoder.mall</groupId> | ||||
|                 <artifactId>common-dependencies</artifactId> | ||||
|                 <artifactId>mall-dependencies</artifactId> | ||||
|                 <version>1.0-SNAPSHOT</version> | ||||
|                 <type>pom</type> | ||||
|                 <scope>import</scope> | ||||
|  |  | |||
|  | @ -11,97 +11,20 @@ | |||
| 
 | ||||
|     <artifactId>user-application</artifactId> | ||||
| 
 | ||||
|     <properties> | ||||
|     </properties> | ||||
| 
 | ||||
|     <dependencies> | ||||
|         <!-- Mall 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>common-framework</artifactId> | ||||
|             <artifactId>user-rest</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>mall-spring-boot</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>user-service-api</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>user-service-impl</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>system-sdk</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>user-sdk</artifactId> | ||||
|             <artifactId>user-rpc</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- Web 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-web</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <dependency> | ||||
|             <groupId>io.springfox</groupId> | ||||
|             <artifactId>springfox-swagger2</artifactId> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>com.github.xiaoymin</groupId> | ||||
|             <artifactId>swagger-bootstrap-ui</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 服务保障相关 --> | ||||
|         <dependency> | ||||
|             <groupId>com.alibaba.cloud</groupId> | ||||
|             <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 监控相关 --> | ||||
| 
 | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-actuator</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <dependency> | ||||
|             <groupId>io.micrometer</groupId> | ||||
|             <artifactId>micrometer-registry-prometheus</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 测试相关 --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-test</artifactId> | ||||
|             <scope>test</scope> | ||||
|         </dependency> | ||||
|     </dependencies> | ||||
| 
 | ||||
|     <build> | ||||
|         <plugins> | ||||
|             <!-- 提供给 mapstruct 使用 --> | ||||
|             <plugin> | ||||
|                 <groupId>org.apache.maven.plugins</groupId> | ||||
|                 <artifactId>maven-compiler-plugin</artifactId> | ||||
|             </plugin> | ||||
| 
 | ||||
|             <!-- 打包 --> | ||||
|             <plugin> | ||||
|                 <groupId>org.springframework.boot</groupId> | ||||
|                 <artifactId>spring-boot-maven-plugin</artifactId> | ||||
|             </plugin> | ||||
|         </plugins> | ||||
|     </build> | ||||
| 
 | ||||
| </project> | ||||
|  |  | |||
|  | @ -2,13 +2,22 @@ package cn.iocoder.mall.user.application; | |||
| 
 | ||||
| import org.springframework.boot.SpringApplication; | ||||
| import org.springframework.boot.autoconfigure.SpringBootApplication; | ||||
| import org.springframework.scheduling.annotation.EnableAsync; | ||||
| import org.springframework.boot.context.config.ConfigFileApplicationListener; | ||||
| 
 | ||||
| @SpringBootApplication(scanBasePackages = {"cn.iocoder.mall.user"}) | ||||
| @EnableAsync(proxyTargetClass = true) | ||||
| @SpringBootApplication(scanBasePackages = {"cn.iocoder.mall.system"}) | ||||
| public class UserApplication { | ||||
| 
 | ||||
|     /** | ||||
|      * 设置需要读取的配置文件的名字。 | ||||
|      * 基于 {@link org.springframework.boot.context.config.ConfigFileApplicationListener#CONFIG_NAME_PROPERTY} 实现。 | ||||
|      */ | ||||
|     private static final String CONFIG_NAME_VALUE = "biz,rest,rpc,application"; | ||||
| 
 | ||||
|     public static void main(String[] args) { | ||||
|         // 设置环境变量
 | ||||
|         System.setProperty(ConfigFileApplicationListener.CONFIG_NAME_PROPERTY, CONFIG_NAME_VALUE); | ||||
| 
 | ||||
|         // 启动 Spring Boot 应用
 | ||||
|         SpringApplication.run(UserApplication.class, args); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,32 +1,8 @@ | |||
| spring: | ||||
|   # Application 的配置项 | ||||
|   application: | ||||
|     name: user-application | ||||
|   # Profile 的配置项 | ||||
|   profiles: | ||||
|     active: local | ||||
| 
 | ||||
|   # Spring Cloud 配置项 | ||||
|   cloud: | ||||
|     # Spring Cloud Sentinel 配置项 | ||||
|     sentinel: | ||||
|       transport: | ||||
|         dashboard: s1.iocoder.cn:12088 # Sentinel Dashboard 服务地址 | ||||
|       eager: true # 项目启动时,直接连接到 Sentinel | ||||
| 
 | ||||
| # server | ||||
| server: | ||||
|   port: 18082 | ||||
|   servlet: | ||||
|     context-path: /user-api/ | ||||
| 
 | ||||
| swagger: | ||||
|   enable: true # 暂时不去掉 | ||||
|   title: 用户子系统 | ||||
|   description: 用户子系统 | ||||
|   version: 1.0.0 | ||||
|   base-package: cn.iocoder.mall.user.application.controller | ||||
| 
 | ||||
| management: | ||||
|   endpoints: | ||||
|     web: | ||||
|       exposure: | ||||
|         include: health,info,env,metrics,prometheus | ||||
|     metrics: | ||||
|       enabled: true | ||||
|  |  | |||
|  | @ -0,0 +1,32 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project xmlns="http://maven.apache.org/POM/4.0.0" | ||||
|          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||||
|          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||||
|     <parent> | ||||
|         <artifactId>user</artifactId> | ||||
|         <groupId>cn.iocoder.mall</groupId> | ||||
|         <version>1.0-SNAPSHOT</version> | ||||
|     </parent> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
| 
 | ||||
|     <artifactId>user-rest</artifactId> | ||||
| 
 | ||||
|     <dependencies> | ||||
|         <!-- Mall 相关 --> | ||||
| <!--        <dependency>--> | ||||
| <!--            <groupId>cn.iocoder.mall</groupId>--> | ||||
| <!--            <artifactId>system-biz</artifactId>--> | ||||
| <!--            <version>1.0-SNAPSHOT</version>--> | ||||
| <!--        </dependency>--> | ||||
| 
 | ||||
|         <!-- Web 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>mall-spring-boot-starter-web</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- TODO 云服务 --> | ||||
|     </dependencies> | ||||
| 
 | ||||
| </project> | ||||
|  | @ -0,0 +1,12 @@ | |||
| # 服务器的配置项 | ||||
| server: | ||||
|   port: 18082 | ||||
|   servlet: | ||||
|     context-path: /user-api/ | ||||
| 
 | ||||
| # Swagger 配置项 | ||||
| swagger: | ||||
|   title: 用户子系统 | ||||
|   description: 用户子系统 | ||||
|   version: 1.0.0 | ||||
|   base-package: cn.iocoder.mall.user.rest.controller | ||||
|  | @ -0,0 +1,30 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project xmlns="http://maven.apache.org/POM/4.0.0" | ||||
|          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||||
|          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||||
|     <parent> | ||||
|         <artifactId>user</artifactId> | ||||
|         <groupId>cn.iocoder.mall</groupId> | ||||
|         <version>1.0-SNAPSHOT</version> | ||||
|     </parent> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
| 
 | ||||
|     <artifactId>user-rpc-api</artifactId> | ||||
| 
 | ||||
|     <dependencies> | ||||
|         <!-- Mall 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>common-framework</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 工具类 --> | ||||
|         <dependency> | ||||
|             <groupId>javax.validation</groupId> | ||||
|             <artifactId>validation-api</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|     </dependencies> | ||||
| 
 | ||||
| </project> | ||||
|  | @ -0,0 +1,45 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project xmlns="http://maven.apache.org/POM/4.0.0" | ||||
|          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||||
|          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||||
|     <parent> | ||||
|         <artifactId>user</artifactId> | ||||
|         <groupId>cn.iocoder.mall</groupId> | ||||
|         <version>1.0-SNAPSHOT</version> | ||||
|     </parent> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
| 
 | ||||
|     <artifactId>user-rpc</artifactId> | ||||
| 
 | ||||
|     <dependencies> | ||||
|         <!-- Mall 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>system-rpc-api</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>user-rpc-api</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
| <!--        <dependency>--> | ||||
| <!--            <groupId>cn.iocoder.mall</groupId>--> | ||||
| <!--            <artifactId>user-biz</artifactId>--> | ||||
| <!--            <version>1.0-SNAPSHOT</version>--> | ||||
| <!--        </dependency>--> | ||||
| 
 | ||||
|         <!-- RPC 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>com.alibaba.cloud</groupId> | ||||
|             <artifactId>spring-cloud-starter-dubbo</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- Registry 和 Config 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>com.alibaba.cloud</groupId> | ||||
|             <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> | ||||
|         </dependency> | ||||
|     </dependencies> | ||||
| 
 | ||||
| </project> | ||||
|  | @ -0,0 +1,14 @@ | |||
| spring: | ||||
|   # Spring Cloud 配置项 | ||||
|   cloud: | ||||
|     nacos: | ||||
|       # Spring Cloud Nacos Discovery 配置项 | ||||
|       discovery: | ||||
|         server-addr: s1.iocoder.cn:8848 # Nacos 服务器地址 | ||||
|         namespace: local # Nacos 命名空间 | ||||
| 
 | ||||
| # Dubbo 配置项 | ||||
| dubbo: | ||||
|   # Dubbo 注册中心 | ||||
|   registry: | ||||
|     address: spring-cloud://s1.iocoder.cn:8848 # 指定 Dubbo 服务注册中心的地址 | ||||
|  | @ -0,0 +1,14 @@ | |||
| spring: | ||||
|   # Spring Cloud 配置项 | ||||
|   cloud: | ||||
|     nacos: | ||||
|       # Spring Cloud Nacos Discovery 配置项 | ||||
|       discovery: | ||||
|         server-addr: s1.iocoder.cn:8848 # Nacos 服务器地址 | ||||
|         namespace: test # Nacos 命名空间 | ||||
| 
 | ||||
| # Dubbo 配置项 | ||||
| dubbo: | ||||
|   # Dubbo 注册中心 | ||||
|   registry: | ||||
|     address: spring-cloud://s1.iocoder.cn:8848 # 指定 Dubbo 服务注册中心的地址 | ||||
|  | @ -0,0 +1,17 @@ | |||
| # Dubbo 配置项 | ||||
| dubbo: | ||||
|   # Spring Cloud Alibaba Dubbo 专属配置 | ||||
|   cloud: | ||||
|     subscribed-services: system-application # 设置订阅的应用列表,默认为 * 订阅所有应用 | ||||
|   # Dubbo 提供者的协议 | ||||
|   protocol: | ||||
|     name: dubbo | ||||
|     port: -1 | ||||
|   # Dubbo 提供服务的扫描基础包 | ||||
|   scan: | ||||
|     base-packages: cn.iocoder.mall.user.rpc.rpc | ||||
|   # Dubbo 服务提供者的配置 | ||||
|   provider: | ||||
|     filter: -exception | ||||
|     SystemLogRPC: | ||||
|       version: 1.0.0 | ||||
|  | @ -0,0 +1,107 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project xmlns="http://maven.apache.org/POM/4.0.0" | ||||
|          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||||
|          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||||
|     <parent> | ||||
|         <artifactId>user</artifactId> | ||||
|         <groupId>cn.iocoder.mall</groupId> | ||||
|         <version>1.0-SNAPSHOT</version> | ||||
|     </parent> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
| 
 | ||||
|     <artifactId>user-application</artifactId> | ||||
| 
 | ||||
|     <properties> | ||||
|     </properties> | ||||
| 
 | ||||
|     <dependencies> | ||||
|         <!-- Mall 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>common-framework</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>mall-spring-boot</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>user-service-api</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>user-service-impl</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>system-sdk</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>cn.iocoder.mall</groupId> | ||||
|             <artifactId>user-sdk</artifactId> | ||||
|             <version>1.0-SNAPSHOT</version> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- Web 相关 --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-web</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <dependency> | ||||
|             <groupId>io.springfox</groupId> | ||||
|             <artifactId>springfox-swagger2</artifactId> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>com.github.xiaoymin</groupId> | ||||
|             <artifactId>swagger-bootstrap-ui</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 服务保障相关 --> | ||||
|         <dependency> | ||||
|             <groupId>com.alibaba.cloud</groupId> | ||||
|             <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 监控相关 --> | ||||
| 
 | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-actuator</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <dependency> | ||||
|             <groupId>io.micrometer</groupId> | ||||
|             <artifactId>micrometer-registry-prometheus</artifactId> | ||||
|         </dependency> | ||||
| 
 | ||||
|         <!-- 测试相关 --> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-starter-test</artifactId> | ||||
|             <scope>test</scope> | ||||
|         </dependency> | ||||
|     </dependencies> | ||||
| 
 | ||||
|     <build> | ||||
|         <plugins> | ||||
|             <!-- 提供给 mapstruct 使用 --> | ||||
|             <plugin> | ||||
|                 <groupId>org.apache.maven.plugins</groupId> | ||||
|                 <artifactId>maven-compiler-plugin</artifactId> | ||||
|             </plugin> | ||||
| 
 | ||||
|             <!-- 打包 --> | ||||
|             <plugin> | ||||
|                 <groupId>org.springframework.boot</groupId> | ||||
|                 <artifactId>spring-boot-maven-plugin</artifactId> | ||||
|             </plugin> | ||||
|         </plugins> | ||||
|     </build> | ||||
| 
 | ||||
| </project> | ||||
|  | @ -0,0 +1,15 @@ | |||
| package cn.iocoder.mall.user.application; | ||||
| 
 | ||||
| import org.springframework.boot.SpringApplication; | ||||
| import org.springframework.boot.autoconfigure.SpringBootApplication; | ||||
| import org.springframework.scheduling.annotation.EnableAsync; | ||||
| 
 | ||||
| @SpringBootApplication(scanBasePackages = {"cn.iocoder.mall.user"}) | ||||
| @EnableAsync(proxyTargetClass = true) | ||||
| public class UserApplication { | ||||
| 
 | ||||
|     public static void main(String[] args) { | ||||
|         SpringApplication.run(UserApplication.class, args); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,32 @@ | |||
| spring: | ||||
|   application: | ||||
|     name: user-application | ||||
| 
 | ||||
|   # Spring Cloud 配置项 | ||||
|   cloud: | ||||
|     # Spring Cloud Sentinel 配置项 | ||||
|     sentinel: | ||||
|       transport: | ||||
|         dashboard: s1.iocoder.cn:12088 # Sentinel Dashboard 服务地址 | ||||
|       eager: true # 项目启动时,直接连接到 Sentinel | ||||
| 
 | ||||
| # server | ||||
| server: | ||||
|   port: 18082 | ||||
|   servlet: | ||||
|     context-path: /user-api/ | ||||
| 
 | ||||
| swagger: | ||||
|   enable: true # 暂时不去掉 | ||||
|   title: 用户子系统 | ||||
|   description: 用户子系统 | ||||
|   version: 1.0.0 | ||||
|   base-package: cn.iocoder.mall.user.application.controller | ||||
| 
 | ||||
| management: | ||||
|   endpoints: | ||||
|     web: | ||||
|       exposure: | ||||
|         include: health,info,env,metrics,prometheus | ||||
|     metrics: | ||||
|       enabled: true | ||||
		Loading…
	
		Reference in New Issue
	
	 YunaiV
						YunaiV