דלג לתוכן הראשידלג לצור קשר
    פרק 16 מתוך 20 · 10.7
    דברים שוייב קודינג לא ילמד אתכם

    CORS

    למה השכן לא יכול להיכנס לדירה שלכם עם המפתח שלו

    פרק 16 / 20

    אודות הפרק

    למה הדפדפן חוסם בקשות מאתרים אחרים ואיך פותרים את זה.

    הבעיה: הקוד עובד, אבל בדפדפן נכשל

    הקוד עובד, ה-API עובד, הכל תקין — אבל ברגע שאתם נכנסים לדפדפן והוא שולח את הבקשה, פתאום זה נכשל. כמו להגיע לכניסה למועדון לבושים יפה ומתוקתקים עם כרטיס, ואז המאבטח אומר: "אתם לא ברשימה".

    למה זה קורה

    הדפדפן מגן עליכם — זה נקרא Same-Origin Policy. הכלל פשוט: אם האתר שלכם בכתובת אחת ומנסה לדבר עם שרת בכתובת אחרת, הדפדפן חוסם את זה אוטומטית. אחרת אתר זדוני היה יכול לשלוח בקשה לשרת בשמכם, עם הקוקיז ופרטי ההזדהות שלכם, בלי שתדעו.

    הפתרון: CORS

    עם CORS (Cross-Origin Resource Sharing) השרת אומר לדפדפן "מהכתובת הזאת מותר לך לדבר איתי". זה Header אחד בתגובה של השרת: Access-Control-Allow-Origin.

    טיפ: הטעות שכולם עושים — לשים כוכבית (*) שמתירה לכולם. בפיתוח זה עובד, אבל ב-production זה מתכון לצרות. רשמו רשימה מדויקת של הכתובות המותרות.

    "כוכבית ב-CORS זה כמו להגיד למאבטח 'תכניס את כולם, אל תבדוק'. בפיתוח זה עובד — ב-production זו פרצה."

    כל הפרקים

    מערכת תורים — Message Queue
    תור בדואר ישראל
    27.3
    1
    מטמון — Caching
    למה שומרים חלב במקרר ולא הולכים לסופר כל 5 דקות
    3.4
    2
    הגבלת קצב — Rate Limiting
    סדרן בכניסה למועדון
    10.4
    3
    אינדקסים במסד נתונים — Database Indexing
    תוכן עניינים בספר של 10,000 עמודים
    17.4
    4
    ניהול שגיאות וניסיונות חוזרים — Retry Logic
    GPS שמחשב מסלול מחדש
    24.4
    5
    אימות מול הרשאות — Auth vs AuthZ
    תעודת זהות מול כרטיס VIP
    1.5
    6
    משתני סביבה — Environment Variables
    למה לא כותבים את הסיסמה על הדלת
    8.5
    7
    מיגרציות — Database Migrations
    שיפוץ דירה בזמן שגרים בה
    15.5
    8
    איזון עומסים — Load Balancing
    קופות בסופר — למה לא פותחים רק אחת
    22.5
    9
    Webhooks
    ההבדל בין לבדוק כל 5 דקות אם הפיצה הגיעה לבין שהשליח מתקשר
    29.5
    10
    עסקאות — Transactions
    למה לא מעבירים כסף בלי לוודא שהצד השני קיבל
    5.6
    11
    Idempotency
    למה לחיצה כפולה על "שלם" לא צריכה לחייב פעמיים
    12.6
    12
    תנאי מירוץ — Race Conditions
    שני אנשים שמתיישבים על אותו כיסא באותו רגע
    19.6
    13
    לוגים וניטור — Logging & Monitoring
    מצלמות אבטחה לקוד שלכם
    26.6
    14
    CI/CD
    פס ייצור במפעל — לא שולחים מוצר בלי בדיקת איכות
    3.7
    15
    CORS
    למה השכן לא יכול להיכנס לדירה שלכם עם המפתח שלו
    10.7
    16
    SQL Injection
    מה קורה כשכותבים קוד בתוך שדה "שם משתמש"
    17.7
    17
    Background Jobs
    למה המלצר לא מבשל לכם את האוכל בעצמו
    24.7
    18
    מיקרוסרביסים מול מונוליט
    מסעדה ענקית אחת מול פוד קורט
    31.7
    19
    DNS ודומיינים
    ספר הטלפונים של האינטרנט
    7.8
    20

    נהנים מהסדרה?

    עקבו לתכנים נוספים על AI וטכנולוגיה