Discuz!官方免费开源建站系统

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

[插件] 远程附件上传 For D4

[复制链接]
魔焰男孩 发表于 2006-1-28 11:34:52 | 显示全部楼层 |阅读模式
看很多朋友都需要这个东西,就帮大家把这个插件从2.5F转到4.0了。等下就要走了,就把这个东西作为新年礼物送给大家吧!我会回来的。

原作者不是我,是happy0429,我只是把它转到4.0来并加以修改。后台没有转到,前台的功能应该正常了(感谢lixp帮忙测试),请大家谅解。

安装比较麻烦,而且有风险,请大家仔细一点。


安装方法:

首先到后台,升级数据库,执行以下SQL:
  1. ALTER TABLE cdb_attachments ADD ftp Integer(2) DEFAULT '0' NOT NULL;
复制代码
  1. ALTER TABLE cdb_forums ADD ftp Integer(2) DEFAULT '0' NOT NULL;
复制代码
  1. CREATE TABLE cdb_attacherror (
  2. aid Integer(5) NOT NULL AUTO_INCREMENT,
  3. attachment Varchar(100) NOT NULL,
  4. dateline Integer(10) NOT NULL,
  5. ftp Integer(2) DEFAULT '0' NOT NULL,
  6. PRIMARY KEY (aid)
  7. );
复制代码



1、把 attchftp.php 文件放在论坛根目录,并修改里面的值。

2、打开 common.inc.php,找到:
  1. require_once DISCUZ_ROOT.'./config.inc.php';
复制代码

在上面添加:
  1. require_once DISCUZ_ROOT.'./attchftp.php';
复制代码


3、打开 admincp.lang.php 文件,找:
  1.         'forums_threadtypes_forums' => '关联论坛',
复制代码

在下面添加:
  1.         'forums_edit_ftp' => '附件FTP服务器设置',
  2.         'forums_edit_ftp_comment' => '请确认FTP服务器能正常工作,否则请使用本地服务器',
复制代码


4、打开 admin/forum.inc.php,找:
  1.                         foreach($perms as $perm) {
  2.                                 $num = -1;
复制代码

在上面添加:
  1.                         if(!$forum['ftp']) {
  2.                                 $forum['ftpname'] = '本地服务器';
  3.                         } else {
  4.                                 $forum['ftpname'] = $ftplist[$forum['ftp']]['name'];
  5.                         }
  6.                         $ftpselect = "<select name="ftpnew"><option value={$forum[ftp]}>{$forum[ftpname]}</option>";
  7.                         $num = 1;
  8.                         foreach ($ftplist as $ftpserver){
  9.                                 $ftpselect .= "<option value={$ftpserver[number]}>{$ftpserver[name]}</option>";
  10.                         }
  11.                         $ftpselect .= '<option value=0>本地服务器</option></select>';
复制代码


再找:
  1.                         showsetting('forums_edit_replycredits', 'replycreditsstatus', $forum['replycredits'], 'radio');
复制代码

在下面添加:
  1.                         showsetting('forums_edit_ftp', 'ftpnew', '', $ftpselect);
复制代码

再找:
  1. jammer='$jammernew',
复制代码

在后面加上:
  1. ftp='$ftpnew',
复制代码

再找:
  1.                 $tids = 0;
  2.                 $query = $db->query("SELECT tid FROM {$tablepre}threads WHERE attachment>'0' AND fid='$fid'");
  3.                 while($thread = $db->fetch_array($query)) {
  4.                         $tids .= ','.$thread['tid'];
  5.                 }

  6.                 if($tids) {
  7.                         $query = $db->query("SELECT filename FROM {$tablepre}attachments WHERE tid IN ($tids)");
  8.                         while($attach = $db->fetch_array($query)) {
  9.                                 @unlink($attachdir.'/'.$attach['filename']);
  10.                         }
  11.                         $db->query("DELETE FROM {$tablepre}attachments WHERE tid IN ($tids)");
  12.                 }
复制代码
修改成:
  1.                 $tids = 0;
  2.                 $query = $db->query("SELECT tid FROM {$tablepre}threads WHERE attachment>'0' AND fid='$fid'");
  3.                 while($thread = $db->fetch_array($query)) {
  4.                         $tids .= ','.$thread['tid'];
  5.                 }

  6.                 if($tids) {
  7.                         if(!$attach['ftp']) {
  8.                                 $query = $db->query("SELECT filename FROM {$tablepre}attachments WHERE tid IN ($tids)");
  9.                                 while($attach = $db->fetch_array($query)) {
  10.                                         @unlink($attachdir.'/'.$attach['filename']);
  11.                                 }
  12.                                 $db->query("DELETE FROM {$tablepre}attachments WHERE tid IN ($tids)");
  13.                         } else {
  14.                                 del_ftp_attach($attach['ftp'], $attach['attachment']);
  15.                         }
  16.                 }
复制代码


5、打开 include/cache.inc.php ,找:
  1.                 case 'forums':
  2.                         $table = 'forums f';
  3.                         $cols = 'f.fid, f.type, f.name, f.fup, ff.viewperm, a.uid';
复制代码

在 a.uid 后面加上:
  1. , f.ftp
复制代码


6、打开post.php,找:
  1. require_once DISCUZ_ROOT.'./include/post.func.php';
复制代码

在下面加上:
  1. require DISCUZ_ROOT.'./forumdata/cache/cache_forums.php';

  2. $ftp = $_DCACHE['forums'][$fid][ftp];
  3. unset($_DCACHE['forums']);
复制代码


7、打开 include/post.func.php,找到:
  1.         // watermark filename
复制代码

在上面加上:
  1.         global $ftplist, $ftp, $fid, $timestamp;
复制代码

再找:
  1.                 $target = $attachdir.'/'.stripslashes($attach['attachment']);
复制代码

在下面加上:
  1.                 if(!$ftp) {
复制代码

再找:
  1.                                 $attacharray[] = $attach;
  2.                         }
  3.                 } else {
  4.                         showmessage('post_attachment_save_error');
  5.                 }
复制代码

下面加上:
  1.                 } else {
  2.                         $attach_fname = substr($filename, 0, 64) . '_' . random(12) . '.' . $extension;
  3.                         $result = ftpconnect($ftplist[$ftp]);
  4.                         ftp_cdup($result);
  5.                         if($attach_subdir) {
  6.                                 if(!@ftp_chdir($result, $attach_subdir)) {
  7.                                         ftp_mkdir($result, $attach_subdir);
  8.                                         ftp_chdir($result, $attach_subdir);
  9.                                 }
  10.                                 $attach_fname0 = $attach_subdir . '/' . $attach_fname;
  11.                         } else {
  12.                                 $attach_fname0 = $attach_fname;
  13.                         }
  14.                         $db->query("INSERT INTO {$tablepre}attacherror(attachment, dateline, ftp) VALUES('{$attach_fname0}', '{$timestamp}', '{$ftp}')");
  15.                         $teid = $db->insert_id();
  16.                         if(@ftp_put($result, $attach_fname, $attach['tmp_name'], FTP_BINARY)) {
  17.                                 @ftp_close($result);                     
  18.                                 $db->query("DELETE FROM {$tablepre}attacherror WHERE aid={$teid}");
  19.                                 $attach['filename'] = $attach['name'];
  20.                                 $attach['filesize'] = $attach['size'];
  21.                                 $attach['perm'] = $allowsetattachperm ? $attachperm[$key] : 0;
  22.                                 $attach['description'] = cutstr(dhtmlspecialchars($attachdesc[$key]), 100);
  23.                                 $attach['attachment'] = $attach_fname0;
  24.                                 $attacharray[] = $attach;
  25.                         } else {
  26.                                 showmessage('post_attachment_save_error');
  27.                         }
  28.                 }
复制代码


8、打开 include/editpost.inc.php,找:
  1.                         @unlink($attachdir.'/'.$attach['attachment']);
复制代码

改成:
  1.                                         if(!$attach['ftp']) {
  2.                                                 @unlink($attachdir.'/'.$attach['attachment']);
  3.                                         } else {
  4.                                                 del_ftp_attach($attach['ftp'], $attach['attachment']);
  5.                                         }
复制代码


再找:
  1.                 $query = $db->query("SELECT pid, attachment FROM {$tablepre}attachments WHERE tid='$tid'");
复制代码

改成:
  1.                 $query = $db->query("SELECT * FROM {$tablepre}attachments WHERE tid='$tid'");
复制代码

再找:
  1. @unlink($attachdir.'/'.$attach['attachment']);
复制代码

改成:
  1.                                 if(!$att['ftp']) {
  2.                                         @unlink($attachdir.'/'.$attach['attachment']);
  3.                                 } else {
  4.                                         del_ftp_attach($attach['ftp'], $attach['attachment']);
  5.                                 }
复制代码

再找:
  1.                                 $query = $db->query("SELECT aid, attachment FROM {$tablepre}attachments WHERE aid IN ($deleteaids) AND pid='$pid'");
复制代码

改成:
  1.                                 $query = $db->query("SELECT * FROM {$tablepre}attachments WHERE aid IN ($deleteaids) AND pid='$pid'");
复制代码

9、打开topicadmin.php,找:
  1.                                 $query = $db->query("SELECT attachment FROM {$tablepre}attachments WHERE tid IN ($moderatetids)");
复制代码
在 attachment 后面插入:
  1. , ftp
复制代码

再找:
  1.                                 $query = $db->query("SELECT attachment FROM {$tablepre}attachments WHERE pid IN ($pids)");
复制代码

在 attachment 后面插入:
  1. , ftp
复制代码
找(共两处):
  1. @unlink($attachdir.'/'.$attach['attachment']);
复制代码

改成:
  1.                                         if(!$attach['ftp']) {
  2.                                                 @unlink($attachdir.'/'.$attach['attachment']);
  3.                                         } else {
  4.                                                 del_ftp_attach($att[ftp],$att['attachment']);
  5.                                         }
复制代码


10、打开attachment.php,找:
  1. if(is_readable($filename) && $attachexists) {
复制代码

在上面添加:
  1. if(!$attach['ftp']) {
复制代码

再找:
  1. } else {

  2.         showmessage('attachment_nonexistence');

  3. }
复制代码
在下面添加:
  1. } else {
  2. ob_end_clean();
  3. header('Expires: Mon, 26 Jul 1997 05:00:00 GMT');
  4. header('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT');
  5. header('Cache-Control: private');
  6. header('Pragma: no-cache');
  7. header('Content-Encoding: none');
  8. if(!$download && $isimage) {
  9.         header('Content-Disposition: '.(strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE') ? 'inline; ' : 'attachment; ').'filename='.$attach['filename']);
  10. } else {
  11.         header('Content-Disposition: attachment; filename='.$attach['filename']);
  12. }
  13. header('Content-Type: '.$attach['filetype']);
  14. if($download) {
  15.         $result = ftpconnect($ftplist[$attach[ftp]]);
  16.         $ftp_path = dirname($attach[attachment]);
  17.         $ftp_file = basename($attach[attachment]);
  18.         ftp_chdir($result,$ftp_path);
  19.         $tmpfile = tempnam( getcwd()."/", "temp" );
  20.         if(ftp_get($result, $tmpfile, $ftp_file, FTP_BINARY)){
  21.                 ftp_quit($result);
  22.                 readfile($tmpfile);
  23.                 unlink($tmpfile);
  24.                 exit;
  25.                } else {
  26.                 showmessage('attachment_nonexistence');
  27.         }
  28.         unlink($tmpfile);
  29.         ftp_quit($result);
  30. } else {
  31.         readfile($ftplist[$attach[ftp]][url].$attach['attachment']);
  32. }
  33. if(!$isimage) {       
  34.         updatecredits($discuz_uid, $creditspolicy['getattach'], -1);
  35. }
  36. }
复制代码

11、分别打开include目录下的newthread.inc.php、newreply.inc.php以及editpost.inc.php,查找:
  1.                         $db->query("INSERT INTO {$tablepre}attachments (tid, pid, dateline, readperm, filename, description, filetype, filesize, attachment, downloads)
  2.                                 VALUES ('$tid', '$pid', '$timestamp', '$attach[perm]', '$attach[name]', '$attach[description]', '$attach[type]', '$attach[size]', '$attach[attachment]', '0')");
复制代码

都改成:

  1.                         $db->query("INSERT INTO {$tablepre}attachments (tid, pid, dateline, readperm, filename, description, filetype, filesize, attachment, downloads, ftp)
  2.                                 VALUES ('$tid', '$pid', '$timestamp', '$attach[perm]', '$attach[name]', '$attach[description]', '$attach[type]', '$attach[size]', '$attach[attachment]', '0', '$ftp')");
复制代码


12、完成。

====================================
付上卸载代码:
  1. ALTER TABLE cdb_attachments DROP ftp;
复制代码
  1. ALTER TABLE cdb_forums DROP ftp;
复制代码
  1. DROP TABLE cdb_attacherror;
复制代码

[ 本帖最后由 魔焰男孩 于 2006-2-2 13:49 编辑 ]
lixp 发表于 2006-1-28 11:35:11 | 显示全部楼层
最严重的感谢楼主。
我发出的帖子1个多月,终于有了回应。
经调试,完全正常。
再感谢。
dz有希望了。

[ 本帖最后由 lixp 于 2006-1-28 11:36 编辑 ]
回复

使用道具 举报

Q.magic 发表于 2006-1-28 11:50:15 | 显示全部楼层
这种好东西,不顶不是人!
回复

使用道具 举报

MopPP.Com 发表于 2006-1-28 11:55:25 | 显示全部楼层
板凳板凳!
回复

使用道具 举报

MopPP.Com 发表于 2006-1-28 11:56:49 | 显示全部楼层
顺便问一下 解释一下有什么用 怎么用
回复

使用道具 举报

Q.magic 发表于 2006-1-28 11:58:33 | 显示全部楼层
我记得好象以前有很多人找这个插件的D4版本。
这个插件就是把用户上传的附件保存到其他的服务器上。
回复

使用道具 举报

karl907 发表于 2006-1-28 12:02:05 | 显示全部楼层
hehe !!!辛苦!
回复

使用道具 举报

kenron 发表于 2006-1-28 12:19:27 | 显示全部楼层
谢谢,是个不错的插件
回复

使用道具 举报

jimmyjimmyqqq 发表于 2006-1-28 13:08:44 | 显示全部楼层
Good Thing.........mfBoy...........Keep Going
回复

使用道具 举报

linsie 发表于 2006-1-28 13:24:39 | 显示全部楼层
好东西
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|Discuz! 官方站 ( 皖ICP备16010102号 )star

GMT+8, 2024-5-4 10:18 , Processed in 0.125493 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

快速回复 返回顶部 返回列表