五.(核心功能)Springboot web 开发阶段( 3.请求参数处理) 目标如何确定参数值,以及返回值

目录

5、如何确定目标方法每一个参数的值  

5.1、挨个判断所有参数解析器那个支持解析这个参数

5.2、解析这个参数的值

5.3、自定义类型参数 封装POJO

6、目标方法执行完成

7、处理派发结果


5、如何确定目标方法每一个参数的值  

调用InvocableHandlerMethod ,寻找 对应的处理解析器  andlerMethodArgumentResolver 的 resolveArgument  解析这个参数的值  ,再处理派发结果

processDispatchResult(processedRequest, response, mappedHandler, mv, dispatchException);

============InvocableHandlerMethod========================== 源码
protected Object[] getMethodArgumentValues(NativeWebRequest request, @Nullable ModelAndViewContainer mavContainer,
			Object... providedArgs) throws Exception {

		MethodParameter[] parameters = getMethodParameters();
		if (ObjectUtils.isEmpty(parameters)) {
			return EMPTY_ARGS;
		}

		Object[] args = new Object[parameters.length];
		for (int i = 0; i < parameters.length; i++) {
			MethodParameter parameter = parameters[i];
			parameter.initParameterNameDiscovery(this.parameterNameDiscoverer);
			args[i] = findProvidedArgument(parameter, providedArgs);
			if (args[i] != null) {
				continue;
			}
			if (!this.resolvers.supportsParameter(parameter)) {
				throw new IllegalStateException(formatArgumentError(parameter, "No suitable resolver"));
			}
			try {
				args[i] = this.resolvers.resolveArgument(parameter, mavContainer, request, this.dataBinderFactory);
			}
			catch (Exception ex) {
				// Leave stack trace for later, exception may actually be resolved and handled...
				if (logger.isDebugEnabled()) {
					String exMsg = ex.getMessage();
					if (exMsg != null && !exMsg.contains(parameter.getExe
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
你可以使用Spring Boot提供的AOP(面向切面编程)功能来实现该需求。具体来说,你可以定义一个切面类,使用@Around注解拦截所有被@RestController注解的类中的@PostMapping方法,并在方法执行前后打印请求值和返回值。 以下是示例代码: ```java @Aspect @Component public class LoggingAspect { private static final Logger LOGGER = LoggerFactory.getLogger(LoggingAspect.class); @Around("@annotation(org.springframework.web.bind.annotation.PostMapping) && within(@org.springframework.web.bind.annotation.RestController *)") public Object logRequestAndResponse(ProceedingJoinPoint joinPoint) throws Throwable { ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); HttpServletRequest request = attributes.getRequest(); String requestUrl = request.getRequestURL().toString(); String httpMethod = request.getMethod(); String requestHeaders = Collections.list(request.getHeaderNames()).stream().map(headerName -> headerName + ":" + request.getHeader(headerName)).collect(Collectors.joining(",")); String requestParams = Collections.list(request.getParameterNames()).stream().map(paramName -> paramName + ":" + request.getParameter(paramName)).collect(Collectors.joining(",")); String requestBody = IOUtils.toString(request.getInputStream(), StandardCharsets.UTF_8); LOGGER.info("Received {} request for {} with headers [{}] and request params [{}] with body [{}]", httpMethod, requestUrl, requestHeaders, requestParams, requestBody); Object response = joinPoint.proceed(); String responseBody = ""; if (response instanceof ResponseEntity) { ResponseEntity responseEntity = (ResponseEntity) response; responseBody = responseEntity.getBody() != null ? responseEntity.getBody().toString() : ""; } else if (response != null) { responseBody = response.toString(); } LOGGER.info("Returning response [{}] for {} request to {}", responseBody, httpMethod, requestUrl); return response; } } ``` 这段代码中定义了一个名为LoggingAspect的切面类,使用@Around注解拦截所有被@PostMapping注解的方法,并且这些方法所在的类必须被@RestController注解标记。在方法执行前,我们可以获取到HTTP请求的URL、请求方法、请求头、请求参数请求体,并打印到日志中。在方法执行后,我们可以获取到方法的返回值,并打印到日志中。 需要注意的是,我们使用了HttpServletRequest.getInputStream()方法来获取请求体,因此需要注意请求体的大小不能太大,否则可能会导致性能问题。如果需要处理大文件等场景,建议使用其他方式获取请求体,比如使用MultipartFile等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是小晴晴呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值