博客
关于我
springmvc之如何确定目标方法Pojo类型的参数?
阅读量:478 次
发布时间:2019-03-06

本文共 755 字,大约阅读时间需要 2 分钟。

SpringMVC在确定目标方法POJO类型入参的过程中,遵循以下步骤:

  • 确定Key:首先,SpringMVC检查POJO参数是否使用了@ModelAttribute注解。如果使用了,Key由注解的value属性值决定;如果未使用,则Key为POJO类名的第一个字母小写。这一步确保了Key的准确性和一致性。

  • 查找ImplicitModel中的Key:SpringMVC在ImplicitModel中查找与Key匹配的对象。如果找到对应的对象,直接将其作为方法入参。这一步利用了前置处理器的存储机制,确保数据的高效获取。

  • 检查SessionAttributes注解:如果ImplicitModel中未找到对应的对象,SpringMVC检查Handler是否使用了@SessionAttributes注解。若使用了,并且SessionAttributes的value中包含Key,SpringMVC从HttpSession中获取对应的值作为入参。这一步确保了在Stateless方法中的状态维护。

  • 创建POJO参数:如果Handler未使用@SessionAttributes注解,或者SessionAttributes的value中不包含Key,SpringMVC通过反射创建POJO类型的参数。这一步自动处理了参数类型的检测和值的获取,减少了手动配置的需求。

  • 保存Key和值:SpringMVC将确定的Key和对应的值保存到ImplicitModel中,进而保存到请求范围内。这一步确保了数据的持久化和可用性,便于在后续处理中重用。

  • 通过以上步骤,SpringMVC确保了请求参数与方法参数的高效、准确地映射和转换,支持灵活的数据绑定需求。这种机制不仅提升了开发效率,也为应用的扩展性和维护性提供了有力支持。

    转载地址:http://mcsbz.baihongyu.com/

    你可能感兴趣的文章
    multi swiper bug solution
    查看>>
    MySQL Binlog 日志监听与 Spring 集成实战
    查看>>
    MySQL binlog三种模式
    查看>>
    multi-angle cosine and sines
    查看>>
    Mysql Can't connect to MySQL server
    查看>>
    mysql case when 乱码_Mysql CASE WHEN 用法
    查看>>
    Multicast1
    查看>>
    mysql client library_MySQL数据库之zabbix3.x安装出现“configure: error: Not found mysqlclient library”的解决办法...
    查看>>
    MySQL Cluster 7.0.36 发布
    查看>>
    Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
    查看>>
    MySQL Cluster与MGR集群实战
    查看>>
    multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
    查看>>
    mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
    查看>>
    Multiple websites on single instance of IIS
    查看>>
    mysql CONCAT()函数拼接有NULL
    查看>>
    multiprocessing.Manager 嵌套共享对象不适用于队列
    查看>>
    multiprocessing.pool.map 和带有两个参数的函数
    查看>>
    MYSQL CONCAT函数
    查看>>
    multiprocessing.Pool:map_async 和 imap 有什么区别?
    查看>>
    MySQL Connector/Net 句柄泄露
    查看>>