自定义@ResponseBody以及SpringMVC总结

2024-08-24 10:28

本文主要是介绍自定义@ResponseBody以及SpringMVC总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1.需求分析
    • 2.目录
    • 3.自定义ResponseBody注解
    • 4.MonsterController.java
    • 5.Monster.java 实现序列化接口
    • 6.引入jackson
    • 7.Adapter.java 如果有@ResponseBody注解就返回json
    • 8.测试
    • 9.SpringMVC执行流程

1.需求分析

CleanShot 2024-08-08 at 14.23.16@2x

2.目录

CleanShot 2024-08-08 at 14.52.19@2x

3.自定义ResponseBody注解

package com.sunxiansheng.springmvc.annotation;import java.lang.annotation.*;/*** Description: 自定义ResponseBody注解* @Author sun* @Create 2024/8/6 16:09* @Version 1.0*/
@Retention(value = RetentionPolicy.RUNTIME) // 运行时生效
@Target(value = ElementType.METHOD) // 作用在方法上
@Documented // 生成文档
public @interface ResponseBody {}

4.MonsterController.java

    /*** 返回JSON数据的格式*/@ResponseBody // 返回JSON数据@RequestMapping(url = "/json/monster")public List<Monster> jsonMonster(HttpServletResponse response) {// 设置响应类型// 获取怪物列表List<Monster> monsters = monsterService.listMonster();// 日志打印monsterslog.info("monsters: {}", monsters);// 响应JSON数据return monsters;}

5.Monster.java 实现序列化接口

CleanShot 2024-08-08 at 14.53.48@2x

6.引入jackson

        <dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.13.4</version> </dependency>

7.Adapter.java 如果有@ResponseBody注解就返回json

package com.sunxiansheng.springmvc.adaptor;import com.fasterxml.jackson.databind.ObjectMapper;
import com.sunxiansheng.springmvc.annotation.ResponseBody;
import com.sunxiansheng.springmvc.handler.HandlerMapping;
import com.sunxiansheng.springmvc.handler.SunHandler;
import com.sunxiansheng.springmvc.viewparser.ViewParser;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;/*** Description: 适配器** @Author sun* @Create 2024/8/8 14:13* @Version 1.0*/
public class Adapter {private static final Logger log = LoggerFactory.getLogger(Adapter.class);/*** 3.适配器请求分发** @param request* @param response*/public static void executeDispatch(HttpServletRequest request, HttpServletResponse response) {// 4.调用映射器获取映射关系HandlerMapping handlerMapping = SunHandler.getHandlerMapping(request);// 如果没有找到映射器,就返回404if (handlerMapping == null) {try {response.getWriter().write("404 NOT FOUND");} catch (Exception e) {throw new RuntimeException(e);}return;}// 匹配成功,调用目标方法Object controller = handlerMapping.getController();Method method = handlerMapping.getMethod();// 5.调用参数解析器,解析参数Object[] args = ResolveArguments.resolveMethodArguments(request, response, method);// 日志,打印实参列表数组List<Class<?>> argsList = new ArrayList<>();for (Object arg : args) {argsList.add(arg.getClass());}log.info("实参列表:{}", argsList);try {// 反射调用方法Object invoke = method.invoke(controller, args);// 先判断有没有@ResponseBody注解,如果有则返回JSONif (method.isAnnotationPresent(ResponseBody.class)) {// 使用 Jackson 进行 JSON 序列化ObjectMapper objectMapper = new ObjectMapper();String jsonResponse = objectMapper.writeValueAsString(invoke);// 设置响应内容类型和编码response.setContentType("application/json;charset=utf-8");response.setCharacterEncoding("UTF-8");// 将 JSON 响应数据写入到响应输出流response.getOutputStream().write(jsonResponse.getBytes());} else {// 6.调用视图解析器,进行视图解析if (invoke instanceof String) {ViewParser.parse(invoke.toString(), request, response);}}} catch (Exception e) {throw new RuntimeException(e);}}}

8.测试

CleanShot 2024-08-08 at 14.55.48@2x

CleanShot 2024-08-08 at 14.56.46@2x

9.SpringMVC执行流程

  • 中央控制器是一个Servlet,配置了,在Tomcat启动时调用init方法
  • init方法完成初始化Spring容器,初始化映射器的操作
  • 浏览器发送请求,交给适配器完成请求分发
  • 适配器首先从映射器中获取映射关系,其中映射关系包括url、目标对象、Method对象
  • 适配器调用参数解析器根据形参列表的类型来填充实参列表,然后反射调用方法
  • 适配器检测方法是否有**@ResponseBody注解,如果有则返回Json数据,如果没有则将结果交给视图解析器**处理
  • 视图解析器根据冒号进行分割,请求转发或者重定向到指定的视图

这篇关于自定义@ResponseBody以及SpringMVC总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102219

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory