اموزشگاه برتر استان البرز

امنیت پایتون: اصول پایه رمزگذاری، احراز هویت و مدیریت نقش‌ها (Authorization)

برچسب ها


ICDL آموزش برنامه نویسی آموزش برنامه نویسی به کودکان آموزش برنامه نویسی در کرج آموزش برنامه نویسی در گلشهر کرج آموزش حسابداری آموزش حسابداری بازارکار در کرج آموزش حسابداری بازار کار در کرج آموزش حسابداری تکمیلی آموزش حسابداری در کرج آموزش حسابداری در گلشهر کرج آموزش حسابداری صنعتی آموزش حسابداری مقدماتی در کرج آموزش طلاسازی آموزش پایتون آموزش پایتون کرج آموزش کامپیوتر در کرج آموزش کامپیوتر در گلشهر کرج آموزشگاه حسابداری آموزشگاه حسابداری در کرج آموزشگاه حسابداری در گلشهر کرج آموزشگاه فنی و حرفه ای آموزشگاه فنی و حرفه ای البرز آموزشگاه فنی و حرفه ای در البرز آموزشگاه فنی و حرفه ای در کرج آموزشگاه فنی و حرفه ای در گلشهر کرج آموزشگاه فنی و حرفه ای گلشهر آموزشگاه فنی و حرفه ای گلشهر کرج آموزشگاه کامپیوتر در البرز آموزشگاه کامپیوتر در کرج آموزشگاه کامپیوتر در گلشهر کرج آموزشگاه کامپیوتر و حسابداری البرز آموزشگاه کامپیوتر گلشهر کرج آموزشگاه کامیپوتر کرج بهترین آموزشگاه حسابداری در کرج حسابداری حسابداری بازار کار حسابداری بازارکار در کرج حسابداری صنعتی حسابداری مالی دوره آموزش حسابداری طراحی سایت و سئو فروشندگی طلا مدرک فنی و حرفه ای پایتون

شبکه های اجتماعی


آموزشگاه برنامه نویسی در کرج

امنیت پایتون: اصول پایه رمزگذاری، احراز هویت و مدیریت نقش‌ها (Authorization) 🔒🔑

پایتون زبانی قدرتمند است که در همه چیز، از توسعه وب و علم داده گرفته تا اتوماسیون، نفوذ کرده است. اما این قدرت با مسئولیتی بزرگ همراه است: امنیت. ساختن یک اپلیکیشن پایتون که “کار می‌کند” یک چیز است، و ساختن اپلیکیشنی که “امن” است، چیزی کاملاً متفاوت. نادیده گرفتن اصول امنیتی می‌تواند منجر به نشت داده‌های کاربران، از دست رفتن اعتبار و ضررهای مالی جبران‌ناپذیر شود. خوشبختانه، پایتون ابزارهای قدرتمندی برای پیاده‌سازی سه ستون اصلی امنیت در اختیار ما قرار می‌دهد: احراز هویت (Authentication)، مدیریت نقش‌ها (Authorization) و رمزگذاری (Encryption).


۱. احراز هویت (Authentication): “شما چه کسی هستید؟” 👤

احراز هویت فرآیند تأیید هویت یک کاربر است. به زبان ساده، سیستم می‌پرسد “آیا شما همان کسی هستید که ادعا می‌کنید؟” رایج‌ترین شکل آن، استفاده از نام کاربری و رمز عبور است.
بزرگترین اشتباه امنیتی: ذخیره کردن رمزهای عبور به صورت متن ساده (Plain Text) در دیتابیس. اگر دیتابیس شما هک شود (که اتفاق می‌افتد)، رمز عبور تمام کاربران شما لو می‌رود.

راه حل: هَش کردن (Hashing)
شما هرگز نباید رمز عبور را ذخیره کنید؛ بلکه باید “هَش” آن را ذخیره کنید. هَش یک تابع یک‌طرفه است؛ تبدیل رمز عبور به هَش آسان است، اما تبدیل هَش به رمز عبور تقریباً غیرممکن است. برای امنیت بیشتر، همیشه باید از “سالت” (Salt) استفاده کنید—یک رشته تصادفی منحصربه‌فرد که قبل از هَش کردن به رمز عبور اضافه می‌شود تا جلوی حملات “جداول رنگین‌کمانی” (Rainbow Table) گرفته شود.

مثال کد: هَش کردن رمز عبور با `hashlib` و Salt

پایتون کتابخانه داخلی `hashlib` را برای این کار ارائه می‌دهد. (توجه: در پروژه‌های واقعی، استفاده از کتابخانه‌هایی مانند `passlib` یا قابلیت‌های داخلی فریم‌ورک‌ها (مثل جنگو) که مدیریت Salt را خودکار می‌کنند، توصیه می‌شود).

import hashlib
import os

def hash_password(password):
    # 1. Generate a random salt
    salt = os.urandom(32) # A 32-byte salt
    
    # 2. Combine password and salt
    # 3. Hash using a strong algorithm (SHA-256)
    key = hashlib.pbkdf2_hmac(
        'sha256', 
        password.encode('utf-8'), 
        salt, 
        100000 # Number of iterations (to make it slow for attackers)
    )
    
    # 4. Store the salt and the key
    return salt + key # Store them together in the database

def check_password(stored_password_hash, provided_password):
    # 1. Extract the salt (first 32 bytes)
    salt = stored_password_hash[:32]
    
    # 2. Extract the key (the rest)
    stored_key = stored_password_hash[32:]
    
    # 3. Hash the provided password with the *same* salt
    new_key = hashlib.pbkdf2_hmac(
        'sha256',
        provided_password.encode('utf-8'),
        salt,
        100000
    )
    
    # 4. Compare the keys
    return new_key == stored_key

# --- Usage ---
password_to_store = hash_password("MySuperSecret123")
# print(password_to_store) # Store this in your database

# --- Verification ---
is_correct = check_password(password_to_store, "MySuperSecret123")
print(f"Password is correct: {is_correct}") # Output: True

is_wrong = check_password(password_to_store, "WrongPassword")
print(f"Password is correct: {is_wrong}") # Output: False
        

۲. مدیریت نقش‌ها (Authorization): “چه کارهایی مجازید انجام دهید؟” 🛡️

Authorization فرآیندی است که *بعد* از احراز هویت اتفاق می‌افتد. سیستم اکنون می‌داند شما چه کسی هستید، اما باید تصمیم بگیرد که آیا شما اجازه دسترسی به یک منبع خاص یا انجام یک عمل خاص را دارید یا خیر.
رایج‌ترین روش پیاده‌سازی این کار، کنترل دسترسی مبتنی بر نقش (Role-Based Access Control – RBAC) است.

  • نقش (Role): یک برچسب برای گروهی از کاربران (مثلاً: `admin`, `user`, `guest`).
  • مجوز (Permission):** یک اقدام خاص (مثلاً: `can_delete_post`, `can_view_dashboard`).

در توسعه وب با پایتون، این کار اغلب با استفاده از “دکوراتورها” (Decorators) پیاده‌سازی می‌شود.

مثال کد: دکوراتور ساده برای بررسی نقش (مانند Flask)

این دکوراتور چک می‌کند که آیا کاربر وارد شده نقش “admin” را دارد یا خیر.

from functools import wraps

# --- Mock user session ---
# In a real app, this would come from the database or session
current_user = {
    "username": "bob",
    "role": "user" # Try changing this to "admin"
}

# 1. The decorator function
def requires_role(required_role):
    def decorator(f):
        @wraps(f)
        def decorated_function(*args, **kwargs):
            # 2. Check the user's role
            if current_user.get("role") != required_role:
                return "Access Denied: You do not have permission.", 403
            # 3. If role matches, run the original function
            return f(*args, **kwargs)
        return decorated_function
    return decorator

# --- Usage in a (pseudo) Flask app ---
@requires_role("admin")
def view_admin_dashboard():
    return "Welcome to the Admin Dashboard!"

@requires_role("user")
def view_user_profile():
    return f"Welcome to your profile, {current_user['username']}!"

# --- Test ---
print(view_admin_dashboard())
print(view_user_profile())
        

۳. رمزگذاری (Encryption): “محافظت از داده‌های حساس” 🤫

رمزگذاری فرآیند تبدیل داده‌های خوانا (Plaintext) به داده‌های ناخوانا (Ciphertext) با استفاده از یک “کلید” (Key) است. این کار از داده‌های شما محافظت می‌کند، چه در حال انتقال باشند (Data in Transit) و چه در دیتابیس ذخیره شده باشند (Data at Rest).
رمزگذاری متقارن (Symmetric): از یک کلید یکسان برای رمزگذاری و رمزگشایی استفاده می‌شود. سریع است، اما مدیریت کلید چالش‌برانگیز است.
رمزگذاری نامتقارن (Asymmetric):** از یک جفت کلید (عمومی برای رمزگذاری، خصوصی برای رمزگشایی) استفاده می‌شود. کندتر است اما برای تبادل کلید امن، عالی است (پایه و اساس HTTPS).
برای رمزگذاری داده‌های حساس در دیتابیس (مانند شماره کارت ملی یا اطلاعات پزشکی)، کتابخانه `cryptography` در پایتون استاندارد طلایی است.

مثال کد: رمزگذاری متقارن ساده با `cryptography.fernet`

`Fernet` یک سیستم رمزگذاری متقارن سطح بالاست که استفاده از آن بسیار ساده و امن است.

# First, install it: pip install cryptography
from cryptography.fernet import Fernet

# 1. Generate a key (MUST be kept secret!)
# Store this key securely (e.g., environment variable), don't generate it every time.
key = Fernet.generate_key()
# print(key)

cipher_suite = Fernet(key)

# 2. Encrypt Data (e.g., a sensitive message)
message = b"This is a secret message (like user's private data)"
encrypted_message = cipher_suite.encrypt(message)

print(f"Encrypted: {encrypted_message}")

# 3. Decrypt Data (e.g., when the user requests their data)
decrypted_message = cipher_suite.decrypt(encrypted_message)

print(f"Decrypted: {decrypted_message.decode('utf-8')}")
        

جمع‌بندی ✅

امنیت یک فرآیند مداوم است، نه یک چک‌لیست یک‌بار مصرف. پایتون ابزارهای لازم برای پیاده‌سازی یک امنیت قوی را فراهم می‌کند. با استفاده صحیح از هَش کردن برای احراز هویت، مدیریت نقش‌ها برای مجوزدهی، و رمزگذاری برای حفاظت از داده‌ها، می‌توانید اپلیکیشن‌هایی بسازید که نه تنها قدرتمند، بلکه قابل اعتماد و امن باشند. یادگیری این اصول امنیتی، مهارتی ضروری برای هر توسعه‌دهنده پایتون است که در دوره‌های آموزش پایتون در آموزشگاه البرز به آن پرداخته می‌شود.

اپلیکیشن‌های پایتون امن بسازید! 🛡️

با یادگیری اصول امنیت در پایتون، از داده‌های کاربران خود محافظت کنید. تسلط بر کتابخانه‌های `hashlib` و `cryptography` و درک مفاهیم احراز هویت، مهارتی حیاتی در توسعه نرم‌افزار است.

  • ✅ آموزش پایتون از مقدماتی تا پیشرفته
  • ✅ درک مفاهیم کلیدی امنیت (Hashing, Encryption)
  • ✅ پروژه‌های عملی توسعه وب امن با پایتون

ثبت‌نام در دوره پایتون پیشرفته
fa_IR