![]() |
X-Sendfile שומר cache?
אני משתמש באתר שלי בX-Sendfile להורדות. זה עובד טוב חוץ מלפעמים זיופים:
לפעמים למרות שהוא נשלח לקובץ X הוא מוריד קובץ Y שזה מאד מוזר. שיניתי את ההדר: קוד:
header("Cache-Control: no-cache"); יכול להיות שהשרת שומר איזה מטמון? השמות של הקבצים שונים. |
תשתמש ב
Content-Disposition |
ציטוט:
קוד:
header("Content-disposition: attachment; filename=\"".$filename."\""); |
בהנחה שזה קשור למטמון, תנסה לפתור את זה באמצעות ההגדרות הרלוונטיות שבעמוד הבא:
https://tn123.org/mod_xsendfile אם תספק קצת יותר קוד ואפילו העתק של התגובות שהשרת מחזיר לך אולי נהיה קצת יותר חכמים. |
זה הקוד שאני משתמש בו:
קוד:
<?php בhttpd.conf מוגדר: XSendFileIgnoreEtag on ותוצאות השליחה: קוד:
Array ( [wrapper_data] => Array ( [0] => HTTP/1.1 200 OK [1] => Date: Sat, 08 Sep 2012 12:27:48 GMT [2] => Server: Apache/2.2.3 (CentOS) [3] => X-Powered-By: PHP/5.3.3 [4] => Pragma: public [5] => Expires: 0 [6] => Content-disposition: attachment; filename="[the filename]" [7] => Connection: close [8] => Cache-Control: must-revalidate, post-check=0, pre-check=0 [9] => Cache-Control: private [10] => Content-Description: File Transfer [11] => Content-Transfer-Encoding: Binary [12] => Accept-Ranges: none [13] => X-Powered-By: PleskLin [14] => Last-Modified: Wed, 04 Jul 2012 22:45:13 GMT [15] => ETag: "3c08018-4f5d5d-4c408c8b61040" [16] => Content-Length: 5201245 [17] => Content-Type: application/octet-stream ) [wrapper_type] => http [stream_type] => tcp_socket/ssl [mode] => r [unread_bytes] => 7584 [seekable] => [uri] => [the url] |
הנתונים שמוזנים לסקריפט (file_url, filename) תואמים לנתונים שהשרת שולח לך בתגובה?
האם מדובר בקבצים קבועים שנשלחים כקבצים אחרים או שזה משתנה ואתה לא מזהה איזשהי תבנית קבועה? על פניו הקוד נראה בסדר, אולי יש איזשהי בעיה לוגית בהצבת הערכים של המשתנים שגורמת לשליחת קבצים אחרים. תעשה קצת דיבאגינג לקוד ותנסה לאתר את הבעיה, יהיה מאוד קשה (עד בלתי אפשרי) לעזור לך בלי גישה למערכת. |
filename תואם, file_url זה הקובץ php שממנו הx-sendfile יוצא והוא בסדר.
לא מצאתי תבנית. שיניתי לreadfile במקום x-sendfile והקובץ הנכון ירד, כך שזה בוודאות הx-sendfile. יש רעיון / כיוון? |
מזאת אומרת: "file_url זה הקובץ php שממנו הx-sendfile יוצא"?
filename אמור להכיל את השם של הקובץ, file_url אמור להכיל את המיקום של הקובץ. |
חלק מהיתרון של x-sendfile זה שלא יודעים את מיקום הקובץ..
מה שיש בfile_url זה הdownload.php |
אחרי שהחזרתי מreadfile לx-sendfile זה הסתדר אבל אני די בטוח שזה יקרה שוב וקשה לנטר את זה.
|
כשאתה אומר "לא יודעים את המיקום של הקובץ" למי אתה מתכוון?
כמובן שהגולשים לא ידעו את המיקום של הקובץ, הכותר x-sendfile לא מגיע אליהם. אם אתה מעביר את הקובץ באמצעות download.php ושם אתה קורא אותו עם readfile (או משהו בסגנון) אני לא רואה איך אתה מרוויח מ- x-sendfile, הרי בסופו של דבר הקובץ אצלך עדיין נשלח באמצעות ה- php. file_url אמור להכיל את הנתיב המלא לקובץ, ואז המודול משדר אותו לגולש בשם שהגדרת ב- content-disposition. |
בreadfile השתמשתי בתור ניסוי וזה עבד טוב.
x-sendfile עושה את הבעיות. אני כנראה פשוט אחפור בגוגל מה הקטע של המטמון בx-sendfile או שאחפש שיטה אחרת להוריד. |
לפי מה שאתה מתאר עושה רושם שאין שום בעיה עם המטמון.
file_url אמור להכיל את הנתיב המלא לקובץ, זה למעשה הקובץ שהמודול משדר. אם אתה מזין בו ערך אחר, זאת הבעיה. |
אני כן מזין בו את הנתיב המלא של הקובץ אבל בתגובת השרת הוא לא מחזיר את הנתיב הזה אלא את הנתיב של הקובץ PHP שממנו זה יצא (וזה בסדר גמור).
|
פעם הבאה שזה יקרה אני אנסה להוריד את הETAG:
קוד:
Header unset ETag |
מה הקשר ל-ETag?
Apache/nginx לא מתייחס ל-ETag ב-x-sendfile, הדפדפן של הגולש מתייחס ל-ETag (בהנחה שהוא הוריד בעבר את הקובץ, Etag דורס Cache-control ו-Expires), הרוב לא ממליצים להשתמש ב-ETag, כי Cache-control עושה את העבודה בהנחה שלא מדובר ביותר משרת אחד. |
הבנתי, טעות שלי..
יש לך רעיון מה יכול לעזור? |
נתחיל מ:
קובץ הקונפיג של אפצ'י. הסקריפט המלא. ה-PATH המלא של הקובץ. |
כל הזמנים הם GMT +2. הזמן כעת הוא 19:05. |
מופעל באמצעות VBulletin גרסה 3.8.6
כל הזכויות שמורות ©
כל הזכויות שמורות לסולל יבוא ורשתות (1997) בע"מ