关于MongoDB图片URL存储异常问题以及解决

 更新时间:2025年04月25日 16:10:27   作者:L_!!!  
这篇文章主要介绍了关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

MongoDB图片URL存储异常问题

项目场景

在开发一个在线考试系统时,前端需要提交学生的答题截图到后端,后端使用 MinIO 存储图片并保存图片 URL 到 MongoDB 数据库。

系统需要支持多次提交图片,并将所有图片 URL 以数组形式存储在 MongoDB 的 screenShot 字段中。

问题描述

当存储少量图片时,URL 显示正常(如 @http://10.100.157.90:9200/test-bucket/exam_1.png

但当图片数量增多后,screenShot 字段存储的内容变成了多层嵌套的 JSON 字符串,包含大量转义字符和斜杠

例如:

"screenShot": ["{\"screenShot\": [\"{\\\"screenShot\\\": [\\\"{\\\\\\\"screenShot\\\\\\\": [\\\\\\\"...\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"]}\"]}"]

原因分析

  1. 数据序列化问题:每次保存新图片时,系统从数据库获取现有的 screenShot 字段内容,但没有正确处理可能已经存在的 JSON 字符串
  2. 嵌套序列化:每次更新时,整个数组被错误地序列化为 JSON 字符串,然后作为新元素添加到数组中
  3. 缺乏数据清理:系统没有对从数据库读取的已有数据进行清理和验证,导致问题不断累积
  4. MongoDB 操作不当:更新 MongoDB 字段时,可能使用了不恰当的序列化方式

解决方案

1.使用 MongoDB 的数组操作符(如 $push)直接更新数组,而不是替换整个字段

2.或者使用数据清理(可选,不建议)

预防措施

  1. 在数据存储前进行严格的格式验证
  2. 添加单元测试验证数据序列化和反序列化逻辑
  3. 对数据库中的现有数据进行定期检查和清理

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java 反射调用静态方法的简单实例

    Java 反射调用静态方法的简单实例

    下面小编就为大家带来一篇Java 反射调用静态方法的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • 基于SpringBoot和Vue3的博客平台文章列表与分页功能实现

    基于SpringBoot和Vue3的博客平台文章列表与分页功能实现

    在前面的教程中,我们已经实现了基于Spring Boot和Vue3的发布、编辑、删除文章功能。本教程将继续引导您实现博客平台的文章列表与分页功能,需要的朋友可以参考阅读
    2023-04-04
  • mybatisplus+pgsql查询bug的解决

    mybatisplus+pgsql查询bug的解决

    本文主要介绍了mybatisplus+pgsql查询bug的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • Java实现经典游戏飞机大战-I的示例代码

    Java实现经典游戏飞机大战-I的示例代码

    《飞机大战-I》是一款融合了街机、竞技等多种元素的经典射击手游。本文将利用java语言实现这游戏,文中采用了swing技术进行了界面化处理,感兴趣的可以了解一下
    2022-02-02
  • mybatis单笔批量保存实体数据的方法

    mybatis单笔批量保存实体数据的方法

    这篇文章主要介绍了mybatis单笔批量保存实体数据的相关知识,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-01-01
  • 使用@RequiredArgsConstructor注解来取代繁琐的@Autowrired

    使用@RequiredArgsConstructor注解来取代繁琐的@Autowrired

    有了@RequiredArgsConstructor注解,我们就可以减少@Autowired的书写,本文主要介绍了使用@RequiredArgsConstructor注解来取代繁琐的@Autowrired,感兴趣的可以了解一下
    2022-04-04
  • Flutter实现容器组件、图片组件 的代码

    Flutter实现容器组件、图片组件 的代码

    容器组件(Container)可以理解为在Android中的RelativeLayout或LinearLayout等,在其中你可以放置你想布局的元素控件,从而形成最终你想要的页面布局。这篇文章主要介绍了Flutter实现容器组件、图片组件 的代码,需要的朋友可以参考下
    2019-07-07
  • 详解Spring注解驱动开发之属性赋值

    详解Spring注解驱动开发之属性赋值

    今天带大家学习Spring注解驱动开发的相关知识,文中有非常详细的代码示例,对正在学习Java的小伙伴们很有帮助,需要的朋友可以参考下
    2021-05-05
  • 浅谈FileItem类的常用方法

    浅谈FileItem类的常用方法

    下面小编就为大家带来一篇浅谈FileItem类的常用方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • IDEA创建的maven项目中pom.xml增加新依赖无效问题及解决

    IDEA创建的maven项目中pom.xml增加新依赖无效问题及解决

    在IDEA中,解决maven项目pom.xml增加依赖但外部库未更新的问题,可以通过设置"构建脚本更改后同步项目"选项为"任何更改",然后刷新Maven项目来解决
    2025-01-01

最新评论