ویرگول
ورودثبت نام
عرفان اسم خانی
عرفان اسم خانینیمچه برنامه نویس JS
عرفان اسم خانی
عرفان اسم خانی
خواندن ۳ دقیقه·۱۰ ماه پیش

ذخیره سازی توکن ها در مرورگر و بهترینشان از نظر امنیت

توکن‌های ذخیره‌شده در مرورگر معمولاً برای مدیریت احراز هویت (Authentication) و حفظ وضعیت ورود کاربر (Session Management) استفاده می‌شوند. این توکن‌ها می‌توانند شامل توکن‌های دسترسی (Access Tokens)، توکن‌های بازسازی (Refresh Tokens) و سایر اطلاعات مرتبط با احراز هویت باشند. در ادامه به بررسی روش‌های ذخیره‌سازی این توکن‌ها و بهترین روش‌ها می‌پردازیم.


روش‌های ذخیره‌سازی توکن‌ها در مرورگر

  1. کوکی‌ها (Cookies)
    توضیح
    : کوکی‌ها یکی از رایج‌ترین روش‌ها برای ذخیره‌سازی توکن‌ها هستند. کوکی‌ها می‌توانند به صورت امن (Secure) و فقط از طریق HTTPS (HttpOnly) تنظیم شوند تا از دسترسی JavaScript به آن‌ها جلوگیری شود.
    مزایا:
    به طور خودکار با هر درخواست به سرور ارسال می‌شوند.
    می‌توانند به صورت امن و فقط از طریق HTTPS ارسال شوند.
    امکان تنظیم تاریخ انقضا (Expiration) دارند.
    معایب:
    در معرض حملات CSRF (Cross-Site Request Forgery) قرار دارند.
    اگر به درستی تنظیم نشوند، ممکن است در معرض حملات XSS (Cross-Site Scripting) قرار بگیرند.
  2. ذخیره‌سازی محلی (Local Storage)
    توضیح
    : Local Storage یک مکانیسم ذخیره‌سازی سمت کلاینت است که داده‌ها را به صورت دائمی ذخیره می‌کند (تا زمانی که به طور دستی پاک نشوند).
    مزایا:
    ظرفیت ذخیره‌سازی بیشتر نسبت به کوکی‌ها.
    دسترسی آسان از طریق JavaScript.
    معایب:
    در معرض حملات XSS قرار دارد.
    داده‌ها به طور خودکار با درخواست‌ها ارسال نمی‌شوند.
  3. ذخیره‌سازی جلسه (Session Storage)
    توضیح
    : Session Storage مشابه Local Storage است، اما داده‌ها فقط برای مدت زمان باز بودن تب یا پنجره مرورگر ذخیره می‌شوند.
    مزایا:
    داده‌ها پس از بسته شدن تب یا پنجره پاک می‌شوند.
    دسترسی آسان از طریق JavaScript.
    معایب:
    در معرض حملات XSS قرار دارد.
    داده‌ها به طور خودکار با درخواست‌ها ارسال نمی‌شوند.

4. ذخیره سازی در IndexDB
توضیح
: IndexedDB یک پایگاه داده سمت کلاینت است که می‌تواند مقادیر زیادی داده ساختاریافته را ذخیره کند.
مزایا:
ظرفیت ذخیره‌سازی بسیار بالا.
امکان ذخیره‌سازی داده‌های پیچیده و ساختاریافته.
معایب:
پیچیدگی بیشتر در پیاده‌سازی.
در معرض حملات XSS قرار دارد.


بهترین روش‌ها برای ذخیره‌سازی توکن‌ها

  1. استفاده از کوکی‌های امن (Secure و HttpOnly)
    دلیل
    : کوکی‌های امن (Secure) فقط از طریق HTTPS ارسال می‌شوند و کوکی‌های HttpOnly از دسترسی JavaScript به آن‌ها جلوگیری می‌کنند. این روش خطر حملات XSS را کاهش می‌دهد.
    نکته: برای جلوگیری از حملات CSRF، از توکن‌های ضد CSRF (CSRF Tokens) استفاده کنید.
  2. استفاده از Local Storage با احتیاط
    دلیل
    : اگر از Local Storage استفاده می‌کنید، باید مطمئن شوید که کد شما در معرض حملات XSS قرار ندارد. این روش برای برنامه‌های تک صفحه‌ای (SPA) که از توکن‌های دسترسی (Access Tokens) استفاده می‌کنند، مناسب است.
    نکته: توکن‌ها را در Local Storage ذخیره کنید و از HTTPS برای انتقال داده‌ها استفاده کنید.
  3. استفاده از Refresh Tokens در کوکی‌های امن
    دلیل
    : Refresh Tokens باید در کوکی‌های امن و HttpOnly ذخیره شوند تا از دسترسی JavaScript به آن‌ها جلوگیری شود. این توکن‌ها برای دریافت توکن‌های دسترسی جدید استفاده می‌شوند.
    نکته: توکن‌های دسترسی (Access Tokens) می‌توانند در Local Storage ذخیره شوند، اما باید عمر کوتاهی داشته باشند تا در صورت سرقت، آسیب‌پذیری کاهش یابد.
  4. استفاده از توکن‌های کوتاه‌عمر (Short-lived Tokens)
    دلیل
    : توکن‌های دسترسی باید عمر کوتاهی داشته باشند (مثلاً ۱۵ دقیقه) تا در صورت سرقت، زمان کافی برای سوء استفاده محدود شود.
    نکته: از Refresh Tokens برای دریافت توکن‌های دسترسی جدید استفاده کنید.

نتیجه‌گیری

بهترین روش برای ذخیره‌سازی توکن‌ها در مرورگر، استفاده از کوکی‌های امن (Secure و HttpOnly) برای ذخیره‌سازی Refresh Tokens و استفاده از Local Storage برای ذخیره‌سازی توکن‌های دسترسی (Access Tokens) با عمر کوتاه است. این روش تعادل مناسبی بین امنیت و کارایی ایجاد می‌کند. همچنین، همیشه از HTTPS برای انتقال داده‌ها استفاده کنید و از توکن‌های ضد CSRF برای جلوگیری از حملات CSRF استفاده نمایید.

local storagetokenbrowser
۱
۰
عرفان اسم خانی
عرفان اسم خانی
نیمچه برنامه نویس JS
شاید از این پست‌ها خوشتان بیاید