תיאור
אפשר להשתמש ב-API של chrome.cookies כדי לשלוח שאילתות לגבי קובצי Cookie ולשנות אותם, ולקבל התראה כשהם משתנים.
הרשאות
cookiesכדי להשתמש ב-Cookies API, צריך להצהיר על ההרשאה "cookies" במניפסט, יחד עם הרשאות מארח לכל המארחים שרוצים לגשת לקובצי ה-Cookie שלהם. לדוגמה:
{
  "name": "My extension",
  ...
  "host_permissions": [
    "*://*.google.com/"
  ],
  "permissions": [
    "cookies"
  ],
  ...
}
חלוקה למחיצות
קובצי Cookie מחולקים למחיצות מאפשרים לאתר לסמן קובצי Cookie מסוימים שצריכים להיות מוגדרים לפי המקור של המסגרת ברמה העליונה. המשמעות היא שאם אתר א' מוטמע באמצעות iframe באתר ב' ובאתר ג', הגרסאות המוטמעות של קובץ Cookie עם חלוקה למחיצות מאתר א' יכולות לקבל ערכים שונים באתר ב' ובאתר ג'.
כברירת מחדל, כל שיטות ה-API פועלות על קובצי Cookie לא מחולקים. אפשר להשתמש במאפיין partitionKey כדי לשנות את ההתנהגות הזו.
פרטים על ההשפעה הכללית של חלוקה למחיצות על תוספים זמינים במאמר בנושא אחסון וקובצי Cookie.
דוגמאות
דוגמה פשוטה לשימוש ב-Cookies API נמצאת בספרייה examples/api/cookies. דוגמאות נוספות ועזרה בצפייה בקוד המקור זמינות במאמר דוגמאות.
סוגים
Cookie
מייצג מידע על קובץ HTTP Cookie.
מאפיינים
- 
    דומייןמחרוזת הדומיין של קובץ ה-Cookie (למשל, www.google.com או example.com). 
- 
    expirationDateמספר אופציונלי תאריך התפוגה של קובץ ה-Cookie כמספר השניות מאז ראשית זמן יוניקס. לא מסופק לקובצי Cookie של סשן. 
- 
    hostOnlyבוליאני הערך הוא True אם קובץ ה-Cookie הוא קובץ Cookie שמוגבל למארח (כלומר, המארח של הבקשה חייב להתאים בדיוק לדומיין של קובץ ה-Cookie). 
- 
    httpOnlyבוליאני הערך הוא True אם קובץ ה-Cookie מסומן כ-HttpOnly (כלומר, אין לסקריפטים בצד הלקוח גישה לקובץ ה-Cookie). 
- 
    שםמחרוזת השם של קובץ ה-Cookie. 
- 
    partitionKeyCookiePartitionKey אופציונלי Chrome 119 ואילךמפתח המחיצה לקריאה או לשינוי של קובצי Cookie עם המאפיין Partitioned. 
- 
    נתיבמחרוזת הנתיב של קובץ ה-Cookie. 
- 
    sameSiteChrome 51+הסטטוס של קובץ ה-Cookie מבחינת SameSite (כלומר, אם קובץ ה-Cookie נשלח עם בקשות בין אתרים). 
- 
    מאובטחבוליאני הערך הוא True אם קובץ ה-Cookie מסומן כמאובטח (כלומר, ההיקף שלו מוגבל לערוצים מאובטחים, בדרך כלל HTTPS). 
- 
    סשןבוליאני הערך הוא True אם קובץ ה-Cookie הוא קובץ Cookie זמני, ולא קובץ Cookie קבוע עם תאריך תפוגה. 
- 
    storeIdמחרוזת המזהה של מאגר קובצי ה-Cookie שמכיל את קובץ ה-Cookie הזה, כפי שמופיע ב-getAllCookieStores(). 
- 
    ערךמחרוזת הערך של קובץ ה-Cookie. 
CookieDetails
פרטים לזיהוי קובץ ה-Cookie.
מאפיינים
- 
    שםמחרוזת שם קובץ ה-Cookie שאליו רוצים לגשת. 
- 
    partitionKeyCookiePartitionKey אופציונלי Chrome 119 ואילךמפתח המחיצה לקריאה או לשינוי של קובצי Cookie עם המאפיין Partitioned. 
- 
    storeIdמחרוזת אופציונלי המזהה של מאגר קובצי ה-Cookie שבו צריך לחפש את קובץ ה-Cookie. כברירת מחדל, ייעשה שימוש במאגר קובצי ה-Cookie של הקשר הנוכחי של ההרצה. 
- 
    כתובת אתרמחרוזת כתובת ה-URL שאליה משויך קובץ ה-Cookie שאליו רוצים לגשת. הארגומנט הזה יכול להיות כתובת URL מלאה, ובמקרה כזה המערכת פשוט מתעלמת מכל הנתונים שמופיעים אחרי נתיב כתובת ה-URL (למשל, מחרוזת השאילתה). אם הרשאות המארח לכתובת ה-URL הזו לא צוינו בקובץ המניפסט, הקריאה ל-API תיכשל. 
CookiePartitionKey
מייצג את מפתח המחיצה של קובץ Cookie עם חלוקה למחיצות.
מאפיינים
- 
    hasCrossSiteAncestorboolean אופציונלי Chrome 130 ואילךמציין אם קובץ ה-Cookie הוגדר בהקשר של אתר שאינו חסום לגישה מדומיינים אחרים. כך נמנעת גישה של אתר ברמה העליונה שמוטמע בהקשר חוצה-אתרים לקובצי Cookie שהוגדרו על ידי האתר ברמה העליונה בהקשר של אתר מאותו הדומיין. 
- 
    topLevelSiteמחרוזת אופציונלי האתר ברמה העליונה שקובץ ה-Cookie עם החלוקה למחיצות זמין בו. 
CookieStore
מייצג מאגר קובצי Cookie בדפדפן. לדוגמה, חלון במצב פרטי משתמש במאגר קובצי Cookie נפרד מזה של חלון שלא במצב פרטי.
מאפיינים
- 
    id [מזהה]מחרוזת המזהה הייחודי של מאגר קובצי ה-Cookie. 
- 
    tabIdsnumber[] מזהים של כל הכרטיסיות בדפדפן שמשתמשות באותו מאגר קובצי Cookie. 
FrameDetails
פרטים לזיהוי המסגרת.
מאפיינים
- 
    documentIdמחרוזת אופציונלי המזהה הייחודי של המסמך. אם מסופקים frameId או tabId, המערכת תבדוק שהם תואמים למסמך שנמצא לפי מזהה המסמך שסופק. 
- 
    frameIdמספר אופציונלי המזהה הייחודי של המסגרת בכרטיסייה. 
- 
    tabIdמספר אופציונלי המזהה הייחודי של הכרטיסייה שמכילה את המסגרת. 
OnChangedCause
הסיבה הבסיסית לשינוי בקובץ ה-Cookie. אם קובץ Cookie הוכנס או הוסר באמצעות קריאה מפורשת אל chrome.cookies.remove, הערך של cause יהיה explicit. אם קובץ Cookie הוסר אוטומטית בגלל תפוגה, הערך של 'סיבה' יהיה 'פג תוקף'. אם קובץ Cookie הוסר כי הוא הוחלף בתאריך תפוגה שכבר חלף, הערך של 'סיבה' יהיה 'expired_overwrite'. אם קובץ Cookie הוסר אוטומטית בגלל איסוף אשפה, הערך של 'סיבה' יהיה 'הוצאה'. אם קובץ Cookie הוסר באופן אוטומטי בגלל קריאה ל-'set' שדרסה אותו, הערך של 'cause' יהיה 'overwrite'. חשוב לתכנן את התשובה בהתאם.
Enum
"evicted" 
 
'expired' 
 
"explicit" 
 
"expired_overwrite" 
 
"overwrite" 
 
SameSiteStatus
המצב של קובץ Cookie מסוג SameSite (https://tools.ietf.org/html/draft-west-first-party-cookies). 'no_restriction' מתאים לקובץ Cookie שהוגדר עם 'SameSite=None', 'lax' מתאים ל-'SameSite=Lax', ו-'strict' מתאים ל-'SameSite=Strict'. הערך 'unspecified' מתאים לקובץ Cookie שהוגדר ללא מאפיין SameSite.
Enum
"no_restriction" 
 
"lax" 
 
"strict" 
 
"unspecified" 
 
Methods
get()
chrome.cookies.get(
details: CookieDetails,
): Promise<Cookie | undefined>
אחזור מידע על קובץ Cookie יחיד. אם קיימים יותר מקובץ Cookie אחד עם אותו שם עבור כתובת ה-URL שצוינה, יוחזר קובץ ה-Cookie עם הנתיב הארוך ביותר. אם יש כמה קובצי Cookie עם אותו אורך נתיב, קובץ ה-Cookie עם זמן היצירה המוקדם ביותר יוחזר.
פרמטרים
- 
    פרטים
החזרות
- 
            Promise<Cookie | undefined> Chrome 88 ואילך
getAll()
chrome.cookies.getAll(
details: object,
): Promise<Cookie[]>
מאחזר את כל קובצי ה-Cookie משמירה אחת של קובצי Cookie, שתואמים למידע מסוים. קובצי ה-Cookie שיוחזרו ימוינו, וקובצי ה-Cookie עם הנתיב הארוך ביותר יוצגו ראשונים. אם לכמה קובצי Cookie יש אורך נתיב זהה, קובצי ה-Cookie עם זמן היצירה המוקדם ביותר יופיעו ראשונים. השיטה הזו מאחזרת רק קובצי Cookie לדומיינים שהתוסף קיבל לגביהם הרשאות מארח.
פרמטרים
- 
    פרטיםאובייקט המידע לסינון קובצי ה-Cookie שאוחזרו. - 
    דומייןמחרוזת אופציונלי מגביל את קובצי ה-Cookie שאוחזרו לאלה שהדומיינים שלהם תואמים לדומיין הזה או שהם תתי-דומיינים שלו. 
- 
    שםמחרוזת אופציונלי סינון קובצי ה-Cookie לפי שם. 
- 
    partitionKeyCookiePartitionKey אופציונלי Chrome 119 ואילךמפתח המחיצה לקריאה או לשינוי של קובצי Cookie עם המאפיין Partitioned. 
- 
    נתיבמחרוזת אופציונלי מגביל את קובצי ה-Cookie שאוחזרו לאלה שהנתיב שלהם תואם בדיוק למחרוזת הזו. 
- 
    מאובטחboolean אופציונלי מסנן את קובצי ה-Cookie לפי המאפיין Secure. 
- 
    סשןboolean אופציונלי מסנן קובצי Cookie זמניים לעומת קובצי Cookie קבועים. 
- 
    storeIdמחרוזת אופציונלי חנות קובצי ה-Cookie שממנה יאוחזרו קובצי ה-Cookie. אם לא מציינים ערך, המערכת תשתמש בחנות קובצי ה-Cookie של הקשר הנוכחי של ההפעלה. 
- 
    כתובת אתרמחרוזת אופציונלי מגביל את קובצי ה-Cookie שאוחזרו לאלה שתואמים לכתובת ה-URL שצוינה. 
 
- 
    
החזרות
- 
            Promise<Cookie[]> Chrome 88 ואילך
getAllCookieStores()
chrome.cookies.getAllCookieStores(): Promise<CookieStore[]>
רשימה של כל מאגרי קובצי ה-Cookie הקיימים.
החזרות
- 
            Promise<CookieStore[]> Chrome 88 ואילך
getPartitionKey()
chrome.cookies.getPartitionKey(
details: FrameDetails,
): Promise<object>
מפתח המחיצה של המסגרת שצוינה.
פרמטרים
- 
    פרטים
החזרות
- 
            Promise<object> 
remove()
chrome.cookies.remove(
details: CookieDetails,
): Promise<object | undefined>
מחיקת קובץ Cookie לפי שם.
פרמטרים
- 
    פרטים
החזרות
- 
            Promise<object | undefined> Chrome 88 ואילך
set()
chrome.cookies.set(
details: object,
): Promise<Cookie | undefined>
הגדרה של קובץ Cookie עם נתוני קובץ ה-Cookie שצוינו. יכול להיות שקובצי Cookie מקבילים יוחלפו אם הם קיימים.
פרמטרים
- 
    פרטיםאובייקט פרטים על קובץ ה-Cookie שמוגדר. - 
    דומייןמחרוזת אופציונלי הדומיין של קובץ ה-cookie. אם לא מציינים את הפרמטר הזה, קובץ ה-Cookie הופך לקובץ Cookie שמוגבל למארח. 
- 
    expirationDateמספר אופציונלי תאריך התפוגה של קובץ ה-Cookie כמספר השניות מאז ראשית זמן יוניקס. אם לא מציינים ערך, קובץ ה-Cookie הופך לקובץ Cookie זמני. 
- 
    httpOnlyboolean אופציונלי האם קובץ ה-Cookie צריך להיות מסומן כ-HttpOnly. ברירת המחדל היא False. 
- 
    שםמחרוזת אופציונלי השם של קובץ ה-Cookie. אם לא מציינים ערך, ברירת המחדל היא ריק. 
- 
    partitionKeyCookiePartitionKey אופציונלי Chrome 119 ואילךמפתח המחיצה לקריאה או לשינוי של קובצי Cookie עם המאפיין Partitioned. 
- 
    נתיבמחרוזת אופציונלי הנתיב של קובץ ה-Cookie. ברירת המחדל היא החלק של הנתיב בפרמטר של כתובת ה-URL. 
- 
    sameSiteSameSiteStatus אופציונלי Chrome 51+הסטטוס של קובץ ה-Cookie מבחינת SameSite. ברירת המחדל היא unspecified, כלומר, אם לא מציינים ערך, קובץ ה-cookie מוגדר בלי לציין מאפיין SameSite. 
- 
    מאובטחboolean אופציונלי האם קובץ ה-Cookie צריך להיות מסומן כמאובטח. ברירת המחדל היא False. 
- 
    storeIdמחרוזת אופציונלי המזהה של מאגר קובצי ה-Cookie שבו צריך להגדיר את קובץ ה-Cookie. כברירת מחדל, קובץ ה-Cookie מוגדר בחנות קובצי ה-Cookie של הקשר הנוכחי של ההפעלה. 
- 
    כתובת אתרמחרוזת כתובת ה-URI של הבקשה לשיוך להגדרת קובץ ה-Cookie. הערך הזה יכול להשפיע על ערכי ברירת המחדל של הדומיין והנתיב של קובץ ה-Cookie שנוצר. אם הרשאות המארח לכתובת ה-URL הזו לא צוינו בקובץ המניפסט, הקריאה ל-API תיכשל. 
- 
    ערךמחרוזת אופציונלי הערך של קובץ ה-Cookie. אם לא מציינים ערך, ברירת המחדל היא ריק. 
 
- 
    
החזרות
- 
            Promise<Cookie | undefined> Chrome 88 ואילך
אירועים
onChanged
chrome.cookies.onChanged.addListener(
callback: function,
)
מופעל כשקובץ Cookie מוגדר או מוסר. שימו לב: במקרה מיוחד, עדכון המאפיינים של קובץ Cookie מיושם כתהליך של שני שלבים: קובץ ה-Cookie שצריך לעדכן מוסר קודם לגמרי, ונוצרת הודעה עם הערך overwrite בפרמטר cause. לאחר מכן, נכתב קובץ Cookie חדש עם הערכים המעודכנים, ונוצרת התראה שנייה עם ה'סיבה' 'מפורשת'.
פרמטרים
- 
    callbackפונקציה הפרמטר callbackנראה כך:(changeInfo: object) => void - 
    changeInfoאובייקט - 
    causeהסיבה הבסיסית לשינוי בקובץ ה-Cookie. 
- 
    קובץ Cookieמידע על קובץ ה-Cookie שהוגדר או הוסר. 
- 
    הוסרבוליאני הערך הוא True אם קובץ Cookie הוסר. 
 
- 
    
 
-