discuz图片顺序混乱问题

553 查看

说明

  • discuz在发表帖子的时候,添加多张图片,然后直接发表帖子,图片顺序有时候会乱掉
  • 即使上传图片窗口中图片顺序正确,发布之后还是会乱掉

分析

  1. 看url,程序代码中看不出什么
  2. 将图片名改为序号上传,顺序乱了,记下帖子中乱掉的图片顺序为:76123458
  3. 然后在数据库找到bbs_forum_attachment_1表,发现默认的顺序也为此:
  4. 竟然也不按aid排序,有可能取的时候就直接取了没有order by
  5. 找到直接操作此表的php:source\class\table\table_forum_attachment_n.php
  6. 通过writelog('文件名','log')方法,发现,每刷新一次帖子,fetch_all_by_id,此方法就执行一次
  7. 原来查看帖子的时候,没有插入到帖子中的附件地址是每次都要从数据库读的

解决

  • 修改fetch_all_by_id方法的传入默认参数:order_by='aid'
  • 刷新刚才图片顺序乱掉的帖子,发现顺序正常了