לוגו אתר Fresh          
 
 
  אפשרות תפריט  ראשי     אפשרות תפריט  צ'אט     אפשרות תפריט  מבזקים     אפשרות תפריט  צור קשר     חץ שמאלה ‎print ‎"Hello World!"; if‎ ‎not rules.‎know ‎then rules.‎read(); חץ ימינה  

לך אחורה   לובי הפורומים > מחשבים > תכנות ובניית אתרים
שמור לעצמך קישור לדף זה באתרי שמירת קישורים חברתיים
תגובה
 
כלי אשכול חפש באשכול זה



  #5  
ישן 22-04-2011, 11:58
  intval intval אינו מחובר  
 
חבר מתאריך: 19.11.10
הודעות: 48
בתגובה להודעה מספר 1 שנכתבה על ידי ronenw1 שמתחילה ב "הימנעות מ-BACK"

קוד PHP:
 if( isset($_POST) ) : 
// All your actions
header("Location: somewhereelse.php");
endif; 


העניין הוא שאתה לוחץ back הדפדן מנסה לעשות את הבקשה האחרונה שלו לשרת עוד פעם.
כשאתה שולח טופס, הבקשה האחרונה שלו הייתה post לסקריפט שלך. ברגע שאתה לוחץ back הוא מנסה לבצע את הבקשה הזו שוב פעם (לעשות עוד post).
הheader גורם לדפדפן לעשות בקשת get אחרי בקשת הpost, ככה שהבקשה האחרונה תהיה get
ואם תחלץ משהו (back / refresh) הוא יבצע את הבקשה הזו שוב ולא את הpost

כמובן שהמשתמש יכול ללחוץ פעמיים back ואז אין לך שום דרך לעצור את זה,
פרט להוספת שדה נוסף בטופס עם ערך רנדומלי כלשהו ובעת שמירת התגובה לשמור בסשן את הערך הזה. עם יגיע טופס עם ערך זהה שוב (שכבר רשום בסשן) כנראה שההודעה הזאת כבר נשמרה במסד ואפשר להתעלם ממנה.
תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #6  
ישן 22-04-2011, 13:43
צלמית המשתמש של Eran
  משתמש זכר Eran Eran אינו מחובר  
 
חבר מתאריך: 27.02.02
הודעות: 4,536
שלח הודעה דרך ICQ אל Eran
בתגובה להודעה מספר 5 שנכתבה על ידי intval שמתחילה ב "[PHP] if( isset($_POST) ) :..."

ופרט לעוד הרבה דברים שהוא יכול לעשות...:

*אם אנחנו רוצים להשאר בצד לקוח אז אפשר לשלוח גם את זמן השליחה ולחשב למשל 5 שניות שהדף יקח לו להטען אם עבר אותם אז להחזיר הודעת שגיאה

*בצד שרת אפשר לבדוק את ההודעות האחרונות של השולח ולבדוק את זמן שליחת ההודעה האחרונה ולקיים הגבלת זמן (חצי דקה) ואז לאפשר שליחה
*אפשר לשדרג את זה ולבדוק ממש את ההודעה האחרונה אם היא שווה לזו הנשלחת...

אני מניח שאתה תוכל להבין בעצמך יתרונות וחסרונות של כל דבר
תראה מה מתאים לך...
_____________________________________

[התמונה הבאה מגיעה מקישור שלא מתחיל ב https ולכן לא הוטמעה בדף כדי לשמור על https תקין: http://fresh.clanteam.com/list.png]

[התמונה הבאה מגיעה מקישור שלא מתחיל ב https ולכן לא הוטמעה בדף כדי לשמור על https תקין: http://fresh.clanteam.com/?https://2010-uploaded.fresh.co.il/2010/09/21/52868411.gif,http://www.boredpanda.com/blog/wp-content/themes/mimbo2.2/images/subscribe-panda-605px.png]

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
  #8  
ישן 23-04-2011, 20:02
צלמית המשתמש של Eran
  משתמש זכר Eran Eran אינו מחובר  
 
חבר מתאריך: 27.02.02
הודעות: 4,536
שלח הודעה דרך ICQ אל Eran
בתגובה להודעה מספר 7 שנכתבה על ידי intval שמתחילה ב "מילא הייתה אומר במקום להוסיף..."

ה"פרט" הזה שלך לא מוצדק
זה שאתה מגביל את עצמך למשהו אחד זו בעיה שלך.
לא חייבים להיות מקובעים לדבר אחד אז העלתי עוד רעיונות...
והנה אתה עזרת לחדד אותו
גם אני הייתי משווה הודעות דרך MD5 בזה אתה צודק, זה לא נכון לבדוק את ההודעות כמו שהן.
ואפילו הרעיון של המספר רנדומלי אפילו טוב יותר בעניין הזה אבל את זה שהוא יבחר
בכל אופן אני לא בטוח שהוא יישם את זה כמו שאתה מיישם את זה.


ועכשיו תקשיב טוב. מה הבעיה לעשות שהדף הבא יקבל את זמן שליחת הדף?
כן גם כאן אתה עושה שדה חבוי שמכיל את הזמן -> בעת שליחת הדף (זה יצריך javascript), אבל ברגע שיעשו רענן הזמן לא ישתנה כי זה קרה כבר בדף של השליחה... ולא צריך לשמור מידע בשום מקום.


דבר נוסף שאני שם דגש עליו זה לא להשתמש בסיישן. מה קורה אם הדפדפן לא מאפשר עוגיות?
ומה אם אני פותח 2 חלונות ושולח 2 הודעות ובשניהם אני עושה רענן?
עכשיו תתחיל לעשות לי מערך בתוך סיישן? אני מעדיף לנהל דבר כזה במסד נתונים.


זהו, תהיה פתוח ! אל תהיה אטום .

_____________________________________

[התמונה הבאה מגיעה מקישור שלא מתחיל ב https ולכן לא הוטמעה בדף כדי לשמור על https תקין: http://fresh.clanteam.com/list.png]

[התמונה הבאה מגיעה מקישור שלא מתחיל ב https ולכן לא הוטמעה בדף כדי לשמור על https תקין: http://fresh.clanteam.com/?https://2010-uploaded.fresh.co.il/2010/09/21/52868411.gif,http://www.boredpanda.com/blog/wp-content/themes/mimbo2.2/images/subscribe-panda-605px.png]

תגובה ללא ציטוט תגובה עם ציטוט חזרה לפורום
תגובה

כלי אשכול חפש באשכול זה
חפש באשכול זה:

חיפוש מתקדם
מצבי תצוגה דרג אשכול זה
דרג אשכול זה:

מזער את תיבת המידע אפשרויות משלוח הודעות
אתה לא יכול לפתוח אשכולות חדשים
אתה לא יכול להגיב לאשכולות
אתה לא יכול לצרף קבצים
אתה לא יכול לערוך את ההודעות שלך

קוד vB פעיל
קוד [IMG] פעיל
קוד HTML כבוי
מעבר לפורום



כל הזמנים המוצגים בדף זה הם לפי איזור זמן GMT +2. השעה כעת היא 09:09

הדף נוצר ב 0.08 שניות עם 12 שאילתות

הפורום מבוסס על vBulletin, גירסא 3.0.6
כל הזכויות לתוכנת הפורומים שמורות © 2024 - 2000 לחברת Jelsoft Enterprises.
כל הזכויות שמורות ל Fresh.co.il ©

צור קשר | תקנון האתר