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

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



  #4  
ישן 24-04-2008, 22:05
  Dark Knight Dark Knight אינו מחובר  
 
חבר מתאריך: 30.07.05
הודעות: 949
שלח הודעה דרך ICQ אל Dark Knight
בתגובה להודעה מספר 1 שנכתבה על ידי Builds שמתחילה ב "שאלה | מה זה sql injections?"

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

אתה מקבל שם משתמש וסיסמא משדות טקסט name ו-pass ואז אתה בודק האם חוזר משהו משאילתא כמו:

קוד PHP:
 SELECT FROM users_table WHERE Username '<name>' AND Password '<pass>' 


(מכיוון שאני לא יודע ASP, פשוט כתבתי <name> ו-<pass> שהם משתנים שמתקבלים ישירות מתיבות הטקסט)

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

אלא שקוד כזה יוצר לך בעיה חמורה! מה יקרה אם משתמש זדוני ינסה להכניס לך:
קוד:
User: Admin Pass: bla' OR '1' = '1


השאילתא הנ"ל תקבל את הצורה הבאה:

קוד PHP:
 SELECT FROM users_table WHERE Username 'Admin' AND Password 'bla' OR '1' '1' 



מכיוון שהמשתמש הזדוני השתמש ב-OR ומכיוון ש 1 תמיד יהיה שווה ל-1, הרי שהתנאי יחזיר לך את כל השדות במסד הנתונים - לא אפס שדות => הוא מקבל גישה, ועוד של Admin.

השימוש בקלט שמהווה נסיון של שבירת השאילתא שלך נקרא SQL INJECTION כי למעשה מזריקים לך לשאילתא פרמטרים לא צפויים.

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

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

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

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

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

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

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



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

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

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

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