<!DOCTYPE html>
    <html lang="vi" xmlns="http://www.w3.org/1999/xhtml" prefix="og: http://ogp.me/ns#">
    <head>
<title>Tìm và xóa file thừa trong PHPBB3</title>
<meta name="description" content="Tìm và xóa file thừa trong PHPBB3 - Savefile - Tin Tức - https&#x3A;&#x002F;&#x002F;mangvn.org&#x002F;savefile&#x002F;Thiet-ke-Web&#x002F;Tim-va-xoa-file-thua-trong-PHPBB3-341.html">
<meta name="author" content="MangVN">
<meta name="copyright" content="MangVN [admin@vinades.vn]">
<meta name="generator" content="NukeViet v4.5">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta property="og:title" content="Tìm và xóa file thừa trong PHPBB3">
<meta property="og:type" content="website">
<meta property="og:description" content="Savefile - Tin Tức - https&#x3A;&#x002F;&#x002F;mangvn.org&#x002F;savefile&#x002F;Thiet-ke-Web&#x002F;Tim-va-xoa-file-thua-trong-PHPBB3-341.html">
<meta property="og:site_name" content="MangVN">
<meta property="og:url" content="https://mangvn.org/savefile/Thiet-ke-Web/Tim-va-xoa-file-thua-trong-PHPBB3-341.html">
<link rel="shortcut icon" href="https://mangvn.org/favicon.ico">
<link rel="canonical" href="https://mangvn.org/savefile/Thiet-ke-Web/Tim-va-xoa-file-thua-trong-PHPBB3-341.html">
<link rel="alternate" href="https://mangvn.org/rss/" title="Tin Tức" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Tin-nhanh-Cong-nghe/" title="Tin Tức - Tin nhanh Công nghệ" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Virut-Hacker-Bao-mat/" title="Tin Tức - Virut, Hacker & Bảo mật" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/CNTT/" title="Tin Tức - CNTT" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Vien-thong/" title="Tin Tức - Viễn thông" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/May-tinh/" title="Tin Tức - Máy tính" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Dien-thoai/" title="Tin Tức - Điện thoại" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/May-anh/" title="Tin Tức - Máy ảnh" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Thu-thuat-Phan-mem/" title="Tin Tức - Thủ thuật - Phần mềm" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Phan-mem-Tin-hoc/" title="Tin Tức - Phần mềm Tin học" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Thu-thuat-tin-hoc/" title="Tin Tức - Thủ thuật tin học" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Thiet-ke-Web/" title="Tin Tức - Thiết kế Web" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Kien-thuc-co-ban/" title="Tin Tức - Kiến thức cơ bản" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/PHP-HTML-JavaScript/" title="Tin Tức - PHP, HTML & JavaScript" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Quang-cao-tang-thu-nhap/" title="Tin Tức - Quảng cáo tăng thu nhập" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Tao-Web-bang-NukeViet/" title="Tin Tức - Tạo Web NukeViet" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Ban-tin-an-ninh/" title="Tin Tức - Bản tin an ninh" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Tin-tuc-NukeViet/" title="Tin Tức - Tin tức NukeViet" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Nhan-vat-su-kien/" title="Tin Tức - Nhân vật & sự kiện" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Huong-dan-su-dung/" title="Tin Tức - Hướng dẫn sử dụng" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/He-thong-NukeViet-20/" title="Tin Tức - Hệ thống NukeViet 2.0" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/He-thong-NukeViet-10/" title="Tin Tức - Hệ thống NukeViet 1.0" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/NukeViet-co-ban/" title="Tin Tức - NukeViet cơ bản" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Web-Internet/" title="Tin Tức - Web & Internet" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Thu-thuat-Internet/" title="Tin Tức - Thủ thuật Internet" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Dich-vu-tien-ich/" title="Tin Tức - Dịch vụ & tiện ích" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Website-nen-vao/" title="Tin Tức - Website nên vào" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Thong-tin-khuyen-mai/" title="Tin Tức - Thông tin khuyến mại" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/thuong-mai-dien-tu/" title="Tin Tức - Thương mại điện tử" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Hau-truong/" title="Tin Tức - Hậu trường" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Blog-Admin/" title="Tin Tức - Blog Admin" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Cong-tac-vien/" title="Tin Tức - Cộng tác viên" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Chuyen-cong-nghe/" title="Tin Tức - Chuyện công nghệ" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Chuyen-kinh-doanh/" title="Tin Tức - Chuyện kinh doanh" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Cuoc-song-quanh-ta/" title="Tin Tức - Cuộc sống quanh ta" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Cuoi-thu-gian/" title="Tin Tức - Cười thư giãn" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Lang-nghe-va-suy-ngam/" title="Tin Tức - Lắng nghe và suy ngẫm" type="application/rss+xml">
<link rel="alternate" href="https://mangvn.org/rss/Kien-thuc-Song/" title="Tin Tức - Kiến thức Sống" type="application/rss+xml">
<link rel="preload" as="style" href="https://mangvn.org/assets/css/font-awesome.min.css" type="text/css">
<link rel="preload" as="style" href="https://mangvn.org/themes/default/css/bootstrap.min.css" type="text/css">
<link rel="preload" as="style" href="https://mangvn.org/themes/default/css/style.css" type="text/css">
<link rel="preload" as="style" href="https://mangvn.org/themes/default/css/style.responsive.css" type="text/css">
<link rel="preload" as="style" href="https://mangvn.org/themes/default/css/news.css" type="text/css">
<link rel="preload" as="style" href="https://mangvn.org/themes/default/css/custom.css" type="text/css">
<link rel="preload" as="script" href="https://mangvn.org/assets/js/jquery/jquery.min.js" type="text/javascript">
<link rel="preload" as="script" href="https://mangvn.org/assets/js/language/vi.js" type="text/javascript">
<link rel="preload" as="script" href="https://mangvn.org/assets/js/DOMPurify/purify3.js" type="text/javascript">
<link rel="preload" as="script" href="https://mangvn.org/assets/js/global.js" type="text/javascript">
<link rel="preload" as="script" href="https://mangvn.org/assets/js/site.js" type="text/javascript">
<link rel="preload" as="script" href="https://mangvn.org/themes/default/js/news.js" type="text/javascript">
<link rel="preload" as="script" href="https://mangvn.org/themes/default/js/main.js" type="text/javascript">
<link rel="preload" as="script" href="https://mangvn.org/themes/default/js/custom.js" type="text/javascript">
<link rel="preload" as="script" href="https://mangvn.org/themes/default/js/bootstrap.min.js" type="text/javascript">
<link rel="stylesheet" href="https://mangvn.org/assets/css/font-awesome.min.css">
<link rel="stylesheet" href="https://mangvn.org/themes/default/css/bootstrap.min.css">
<link rel="stylesheet" href="https://mangvn.org/themes/default/css/style.css">
<link rel="stylesheet" href="https://mangvn.org/themes/default/css/style.responsive.css">
<link rel="StyleSheet" href="https://mangvn.org/themes/default/css/news.css">
<link rel="stylesheet" href="https://mangvn.org/themes/default/css/custom.css">
<style type="text/css">
	body{background: #fff;}
</style>
    </head>
    <body>
<div id="print">
	<div id="hd_print">
		<h2 class="pull-left">MangVN</h2>
		<p class="pull-right"><a title="MangVN" href="https://mangvn.org/">https://mangvn.org</a></p>
	</div>
	<div class="clear"></div>
	<hr />
	<div id="content">
		<h1>Tìm và xóa file thừa trong PHPBB3</h1>
		<ul class="list-inline">
			<li>Chủ nhật - 18/11/2007 08:51</li>
			<li class="hidden-print txtrequired"><em class="fa fa-print">&nbsp;</em><a title="In ra" href="javascript:;" onclick="window.print()">In ra</a></li>
			<li class="hidden-print txtrequired"><em class="fa fa-power-off">&nbsp;</em><a title="Đóng cửa sổ này" href="javascript:;" onclick="window.close()">Đóng cửa sổ này</a></li>
		</ul>
		<div class="clear"></div>
		<div id="hometext">
			Bài toán đặt ra: Làm sao xóa các file thừa & bù file thiếu trong hệ thống PHPBB3 mà hiện CSDL của PHPBB3 không thể phát hiện ra? Bạn hãy thử giải pháp này xem sao.
		</div>
		<div id="bodytext" class="clearfix">
			Đây là giải pháp của NEDKA ở vinabb

<br />

<br />Ý tưởng là, phải so sánh filename của những file còn trong DB và những

file có trong thư mục files/ là sẽ biết được những "file rác" có trong

thư mục files/ (có trong files/ mà không có trong DB, nghĩa là không hề

được sử dụng đến. Cái này do rất nhiều nguyên nhân mà nó có, ví dụ:

thành viên upload file trong khi đang soạn dang dở, rồi bỏ không gửi ;

cấp phép sai thư mục files, dẫn đến không thể xóa file trong thư mục

vật lí...)

<br />

<br />Đầu tiên là tạo danh sách những file có trong DB (đây là tất cả những file đang sử dụng - active). Tạo một file PHP như sau:

<br />

<div class="codetitle"><strong>Code:</strong>

</div>

<div class="codecontent">&lt;?php
  <br />

  <br />define('IN_PHPBB', true);
  <br />$phpbb_root_path = './';
  <br />$phpEx = substr(strrchr(__FILE__, '.'), 1);
  <br />include($phpbb_root_path . 'common.' . $phpEx);
  <br />

  <br />// Start session management
  <br />$user-&gt;session_begin();
  <br />$auth-&gt;acl($user->data);
  <br />$user-&gt;setup();
  <br />

  <br />$sql = 'SELECT physical_filename
  <br />&nbsp; &nbsp;FROM ' . ATTACHMENTS_TABLE . '
  <br />&nbsp; &nbsp;WHERE is_orphan = 0
  <br />&nbsp; &nbsp;ORDER BY physical_filename ASC';
  <br />$result = $db-&gt;sql_query($sql);
  <br />

  <br />while ($row = $db-&gt;sql_fetchrow($result))
  <br />{
  <br />&nbsp; &nbsp;&nbsp; &nbsp;echo($row['physical_filename'] . '&lt;br /&gt;');
  <br />}
  <br />

  <br />?&gt;

</div>

<br />Upload lên host rồi chạy nó từ trình duyệt, copy tất cả kết quả xuất ra rồi save thành file FILE_DB.txt để trên máy.

<br />

<br />Tiếp

theo, tạo tiếp file php khác để xuất ra tất cả các file hiện có trong

thư mục files/ (mà nhiều cái chắc chắn sẽ không còn trong DB - nghĩa là

"file rác"). Mấu chốt là do các file đính kèm của phpBB sau khi upload

đã không còn phần mở rộng (click từ trình duyệt nó sẽ hiểu nhầm là thư

mục con - do không có đuôi tập tin đi kèm), do đó phải dùng hàm <span style="font-weight: bold;">scandir - chỉ có trong PHP5</span> để hiện tên thực:

<br />

<div class="codetitle"><strong>Code:</strong>

</div>

<div class="codecontent">&lt;?php
  <br />

  <br />define('IN_PHPBB', true);
  <br />$phpbb_root_path = './';
  <br />$phpEx = substr(strrchr(__FILE__, '.'), 1);
  <br />

  <br />$dir&nbsp; &nbsp; = $phpbb_root_path . 'files/';
  <br />$files = scandir($dir);
  <br />

  <br />foreach ($files as $files_list =&gt; $file_ary)
  <br />{
  <br />&nbsp; &nbsp;printf($file_ary . '&lt;br /&gt;');
  <br />}
  <br />

  <br />?&gt;

</div>

<br />Upload lên host, chạy từ trình duyệt rồi copy kết quả thành file FILE_DIR.txt để trên máy.

<br />

<br />Cuối cùng, dùng một phần mềm so sánh văn bản, như <a href="http://sourceforge.net/projects/winmerge" class="postlink">WinMerge<img inline;="" display:="" top;="" vertical-align:="" visible;="" visibility:="" none;="" text-decoration:="" no-repeat;="" background-repeat:="" 0pt;="" -787px="" background-position:="" 12px;="" height:="" 14px;="" width:="" transparent;="" background-color:="" palette.gif);="" ice="" theme="" v3.3="" images="" i.ixnp.com="" url(http:="" background-image:="" normal;="" line-height:="" auto;="" top:="" left:="" static;="" position:="" float:="" ,arial,helvetica,sans-serif;="" ms="" trebuchet="" id="snap_com_shot_link_icon" src="http://i.ixnp.com/images/v3.3/t.gif" style="border: 0pt none ; margin: 0pt ! important; padding: 1px 0pt 0pt; font-style: normal; font-weight: normal;" class="snap_preview_icon" /></a> để so sánh 2 file này, bên trái là file FILE_DB.txt, bên phải là file DB_DIR.txt:

<br />

<br />

<div class="attachcontent"><a href="http://www.vinabb.com/download.php?id=1944&mode=view"><img src="http://www.vinabb.com/download.php?id=1944&t=1" alt="WINMERGE.gif" title="WINMERGE.gif" /></a>

  <br /><span class="gensmall">&nbsp;</span>

  <br />

</div><span style="font-weight: bold;">KẾT QUẢ KHI SO SÁNH:</span>

<br />Nếu

chỉ có bên phải, không có bên trái: nghĩa là những cái bên phải này là

file rác không hề sử dụng tới, hãy lưu lại tên nó rồi dò tìm và xóa đi

(xóa từ công cụ quản lý file trong hosting, qua FTP...).

<br />Nếu chỉ có

bên trái, không có bên phải: trường hợp này nghĩa là có lỗi, 1 file có

trong DB (phần hồn) nhưng lại khộng có trong thư mục files (phần xác),

thành ra nếu ai đó click vào link download của nó sẽ báo lỗi "Not

found". Hãy tra tìm theo tên đó và upload lại.

<br />
		</div>
				<div id="author">
						<p>
				<strong>Nguồn tin:</strong>
				Nedka@vinabb
			</p>
		</div>
	</div>
	<div id="footer" class="clearfix">
		<div id="url">
			<strong>URL của bản tin này: </strong><a href="https://mangvn.org/savefile/Thiet-ke-Web/Tim-va-xoa-file-thua-trong-PHPBB3-341.html" title="Tìm và xóa file thừa trong PHPBB3">https://mangvn.org/savefile/Thiet-ke-Web/Tim-va-xoa-file-thua-trong-PHPBB3-341.html</a>

		</div>
		<div class="clear"></div>
		<div class="copyright">
			&copy; MangVN
		</div>
		<div id="contact">
			<a href="mailto:admin@vinades.vn">admin@vinades.vn</a>
		</div>
	</div>
</div>
        <div id="timeoutsess" class="chromeframe">
            Bạn đã không sử dụng Site, <a onclick="timeoutsesscancel();" href="https://mangvn.org/#">Bấm vào đây để duy trì trạng thái đăng nhập</a>. Thời gian chờ: <span id="secField"> 60 </span> giây
        </div>
        <div id="openidResult" class="nv-alert" style="display:none"></div>
        <div id="openidBt" data-result="" data-redirect=""></div>
<script src="https://mangvn.org/assets/js/jquery/jquery.min.js"></script>
<script>var nv_base_siteurl="/",nv_lang_data="vi",nv_lang_interface="vi",nv_name_variable="nv",nv_fc_variable="op",nv_lang_variable="language",nv_module_name="news",nv_func_name="savefile",nv_is_user=0, nv_my_ofs=-4,nv_my_abbr="EDT",nv_cookie_prefix="nv4c_b41EI",nv_check_pass_mstime=1738000,nv_area_admin=0,nv_safemode=0,theme_responsive=1,nv_recaptcha_ver=2,nv_recaptcha_sitekey="6LfaEikpAAAAAB7BnT8L5ijh2CCG0esJquuWj9ZJ",nv_recaptcha_type="image",XSSsanitize=1;</script>
<script src="https://mangvn.org/assets/js/language/vi.js"></script>
<script src="https://mangvn.org/assets/js/DOMPurify/purify3.js"></script>
<script src="https://mangvn.org/assets/js/global.js"></script>
<script src="https://mangvn.org/assets/js/site.js"></script>
<script src="https://mangvn.org/themes/default/js/news.js"></script>
<script src="https://mangvn.org/themes/default/js/main.js"></script>
<script src="https://mangvn.org/themes/default/js/custom.js"></script>
<script type="application/ld+json">
        {
            "@context": "https://schema.org",
            "@type": "Organization",
            "url": "https://mangvn.org",
            "logo": "https://mangvn.org/uploads/logo-mangvn.png"
        }
        </script>
<script src="https://mangvn.org/themes/default/js/bootstrap.min.js"></script>
</body>
</html>