您现在的位置是:首页 > cms教程 > Discuz教程Discuz教程

discuz抱歉该附件无法读取的解决方法

冷安2025-07-08Discuz教程已有人查阅

导读最近升级了x2.0的补丁,发现普通用户在下载附件的时候会出现‘抱歉,该附件无法读取’的提示,但下载分已经扣了 搞得大家非常不满。但管理员之类的不扣下载分的是可以下载的。

最近升级了x2.0的补丁,发现普通用户在下载附件的时候会出现‘抱歉,该附件无法读取’的提示,但下载分已经扣了 搞得大家非常不满。但管理员之类的不扣下载分的是可以下载的。
于是开始网上搜索了,发现也有类似问题,但不是路径不对,就是附件本身有问题。 要么就是同样的问题没人解答。 没办法,只好自己想办法了。
先是在 forum_attachment.php 里看了半天,确定那个提示是从这里报出的。报这个提示的情况有很多处,我遇到的是附件不存在, 奇怪? 附件不存在怎么管理员可以下载呢? 于是进一步跟踪数据库,终于发现了问题。 discuz 的附件是分表存放的,表名像这样 pre_forum_attachment_0, pre_forum_attachment_1, 我这里共有0~9, 10个表,另外有一个表 pre_forum_attachment,保存了全是编号,像aid(附件ID),tid(帖子ID),uid(用户ID),tableid(这个就是表示具体附件信息保存在哪个表中)。 于是我找出下载失败的附件的id, 搜索 pre_fourm_attachment,得到tableid, 再从相应的附件表中查找, 发现没有找到, 但在另一个附件表中找到了, 说明这个问题的原因是附件表中的tableid不同步造成的。 这样的话解决方法就明朗了,就是同步tabeid。
解决方法就是执行几条sql语句,像这样:
update pre_forum_attachment a, pre_forum_attachment_0 b set a.tableid = 0 where a.aid = b.aid;
update pre_forum_attachment a, pre_forum_attachment_1 b set a.tableid = 1 where a.aid = b.aid;
......
update pre_forum_attachment a, pre_forum_attachment_9 b set a.tableid = 9 where a.aid = b.aid;
方法有点土,执行了很多次类似的语句,注意其中的两个数字要相同,否则麻烦大了。 执行后,问题解决。
PS: 我的版本是 discuz! x2, 安装的时候表前缀是可以改的,所以你的表前缀可能不是 pre_,所以注意查看实际的表前缀。

本文标签:

很赞哦! ()

相关源码

  • pbootcms模板PC+WAP娱乐新闻资讯类博客网站源码该模板基于PbootCMS内核开发,专为娱乐新闻、健康生活类资讯网站设计,同时支持快速适配其他行业(如企业官网、博客门户等),仅需替换图文内容即可完成转型。查看源码
  • pbootcms模板(PC+WAP)微信小程序开发公司网站本模板为微信小程序开发代理、软件开发公司等企业设计,基于PbootCMS内核开发,支持PC+WAP双端响应式布局,数据实时同步,适用于多行业快速建站。查看源码
  • 响应式HTML5家居建材办公家具桌椅pbootcms模板为家居建材、办公家具企业打造的响应式网站模板,同时支持多行业快速适配通过替换文字图片即可转型为其他行业官网,大幅降低开发成本。查看源码
  • (PC+WAP)高端餐饮美食小吃加盟网站模板下载pbootcms本模板基于PbootCMS内核开发,为餐饮美食品牌加盟、小吃连锁企业量身打造。通过精致的美食视觉呈现与加盟业务流程展示,帮助餐饮企业建立专业线上门户,实现品牌形象与加盟业务的双重展示。查看源码
  • (自适应)品牌策划网络设计作品公司个人pbootcms网站源码下载本款基于PbootCMS开发的网站模板专为品牌策划、设计公司打造,特别适合展示创意作品、设计案例和企业服务。模板采用现代化设计风格查看源码
  • (响应式)蓝色智能摄像头安防防盗电子设备免费pbootcms源码下载这是一款针对智能安防行业特点设计的网站模板,采用蓝色系配色方案,体现科技感和安全性。模板包含产品展示、解决方案、技术支持和新闻中心等核心模块,能够全面展示智能安防设备的技术特点和行业应用。查看源码
分享笔记 (共有 篇笔记)
验证码:

本栏推荐