اولین مدل هوش مصنوعی ضد حملات XSS ایرانی رایگان از تیم ابدال
در این مقاله، به معرفی و بررسی Abdal XSS AI Engine، یک مدل هوش مصنوعی تخصصی برای شناسایی و جلوگیری از حملات XSS، میپردازیم. این مدل توسط ابراهیم شفیعی.....
لیست مطالب
در دنیای امروز که هر روز بر حجم و پیچیدگی حملات سایبری افزوده میشود، امنیت وب یکی از مهمترین اولویتهای هر سازمان و توسعهدهنده وب است. حملات XSS (Cross-Site Scripting) از جمله حملات رایجی هستند که به مهاجم اجازه میدهد اسکریپتهای مخرب را به صفحات وب تزریق کرده و اطلاعات حساس کاربران را سرقت کند. در این راستا، مدلهای پیشرفته هوش مصنوعی و یادگیری ماشین به یکی از ابزارهای حیاتی برای مقابله با چنین حملاتی تبدیل شدهاند.
در این مقاله، به معرفی و بررسی Abdal XSS AI Engine، یک مدل هوش مصنوعی تخصصی برای شناسایی و جلوگیری از حملات XSS، میپردازیم. این مدل توسط ابراهیم شفیعی (EbraSha)، مدیر تیم امنیتی ابدال، طراحی و پیادهسازی شده است. هدف از توسعه این مدل، ارائه یک راهکار پیشرفته و رایگان برای مقابله با حملات XSS است که با توجه به نیازهای امنیتی کاربران ایرانی طراحی شده است.
Abdal XSS AI Engine چیست؟
Abdal XSS AI Engine یک مدل یادگیری عمیق است که با استفاده از الگوریتمهای پیشرفته قادر به شناسایی الگوهای مختلف حملات XSS میباشد. این مدل بهطور مداوم بهروزرسانی میشود تا بتواند در مقابل تهدیدات جدید و متنوع مقاومت کند. با استفاده از تکنیکهای پردازش متن مانند TF-IDF (Term Frequency-Inverse Document Frequency)، این مدل ویژگیهای حملات XSS را از متون استخراج کرده و آنها را به صورت دادههای ورودی برای مدل یادگیری عمیق آماده میکند.
این مدل دارای معماری چند لایهای است که شامل لایههای Dense و Dropout است و با استفاده از بهینهساز Adam آموزش دیده است. همچنین، این مدل قابلیت بهروزرسانی و بهبود مداوم با دادههای جدید را داراست و میتواند در محیطهای مختلف برای شناسایی و جلوگیری از حملات XSS استفاده شود.
ویژگیهای کلیدی Abdal XSS AI Engine:
- شناسایی الگوهای حملات XSS: این مدل قادر به شناسایی صدها هزار الگوی مختلف حملات XSS است و با دادههای جدید بهطور مداوم بهروزرسانی میشود.
- استفاده از تکنیک TF-IDF: مدل از تکنیک TF-IDF برای استخراج ویژگیهای متنی استفاده میکند که به بهبود دقت شناسایی کمک میکند.
- مدل یادگیری عمیق: معماری مدل شامل لایههای Dense و Dropout است که با استفاده از دادههای حملات XSS آموزش داده شدهاند.
- بهینهسازی با Adam: مدل با استفاده از الگوریتم بهینهسازی Adam آموزش دیده و دقت بالایی در شناسایی حملات دارد.
- ذخیره مدل و وکتورایزر: مدل و وکتورایزر بهطور جداگانه ذخیره شده و میتوان آنها را در آینده برای شناسایی حملات جدید استفاده کرد.
چرایی ساخت Abdal XSS AI Engine
یکی از دلایل اصلی توسعه Abdal XSS AI Engine، نبود ابزارهای رایگان و پیشرفته برای شناسایی و جلوگیری از حملات XSS در ایران بود. حملات XSS یکی از مهمترین تهدیدات امنیتی برای وبسایتها هستند که میتوانند به سرقت اطلاعات حساس کاربران منجر شوند. با توجه به افزایش تعداد و پیچیدگی این حملات، نیاز به یک مدل هوش مصنوعی با قابلیت شناسایی سریع و دقیق حملات، به شدت احساس میشد.
Abdal XSS AI Engine با هدف ارائه یک راهکار بومی و رایگان برای کاربران ایرانی طراحی شد تا بتواند نیازهای امنیتی در مقابله با حملات XSS را برطرف کند. این مدل میتواند به عنوان یک ابزار مفید برای توسعهدهندگان وب و متخصصان امنیتی در محیطهای مختلف مورد استفاده قرار گیرد.
نحوه استفاده از Abdal XSS AI Engine
برای استفاده از این مدل، ابتدا باید فایلهای مدل و وکتورایزر را از مخزن گیتهاب از اینجا دانلود کنید. سپس با استفاده از کد زیر میتوانید از مدل به صورت یک API برای شناسایی حملات XSS استفاده کنید:
from flask import Flask, request, jsonify
import tensorflow as tf
import pickle
import numpy as np
app = Flask(__name__)
# Load the model and vectorizer
model = tf.keras.models.load_model('Abdal_XSS_AI_Engine.h5')
with open('vectorizer.pkl', 'rb') as f:
vectorizer = pickle.load(f)
@app.route('/predict', methods=['POST'])
def predict():
data = request.json
sentences = data['sentences']
# Preprocess the input data using the vectorizer
X_new = vectorizer.transform(sentences).toarray()
# Make predictions
predictions = (model.predict(X_new) > 0.5).astype(int)
# Prepare and return the response
response = {
'predictions': ['XSS Detected' if pred == 1 else 'No XSS Detected' for pred in predictions.flatten()]
}
return jsonify(response)
if __name__ == '__main__':
app.run(debug=True)
توضیح کد:
این API به شما امکان میدهد که متونی را به صورت ورودی به مدل ارسال کرده و مدل پس از پردازش، حملات XSS را شناسایی کند. ابتدا مدل و وکتورایزر بارگذاری میشوند و سپس با استفاده از درخواستهای HTTP، دادههای متنی دریافت شده و پیشپردازش میشوند. در نهایت مدل پیشبینی میکند که آیا حمله XSS در متن وجود دارد یا خیر.
استفاده از فایل متنی:
علاوه بر API، میتوانید از مدل برای خواندن دادهها از یک فایل متنی و شناسایی حملات استفاده کنید. کد زیر نمونهای از این استفاده است:
import os
import tensorflow as tf
import pickle
# Disable oneDNN custom operations
os.environ['TF_ENABLE_ONEDNN_OPTS'] = '0'
# Set TensorFlow logging level to 'ERROR' to suppress the info and warning messages
os.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'
# Check if model and vectorizer files exist
model_path = 'Abdal_XSS_AI_Engine.keras'
vectorizer_path = 'vectorizer.pkl'
if not os.path.exists(model_path):
raise FileNotFoundError(f"Model file not found: {model_path}")
if not os.path.exists(vectorizer_path):
raise FileNotFoundError(f"Vectorizer file not found: {vectorizer_path}")
# Load the model from the Keras format
model_name = "Abdal XSS AI Engine"
model = tf.keras.models.load_model(model_path)
# Load the vectorizer
with open(vectorizer_path, 'rb') as f:
vectorizer = pickle.load(f)
# Read new data (sentences) from a file (e.g., 'attack-xss-payload.txt')
input_file = 'attack-xss-payload.txt'
if not os.path.exists(input_file):
raise FileNotFoundError(f"Input file not found: {input_file}")
with open(input_file, 'r', encoding='utf-8') as file:
new_sentences = [line.strip() for line in file if line.strip()] # Reading each line from file
# Check if any sentence exists for prediction
if not new_sentences:
raise ValueError("No data available for prediction.")
# Preprocess the new data using the loaded TF-IDF vectorizer
X_new = vectorizer.transform(new_sentences).toarray()
# Predict using the loaded model
predictions = (model.predict(X_new) > 0.5).astype(int)
# Print predictions
for i, sentence in enumerate(new_sentences):
print(f"Sentence: {sentence}")
print(f"Prediction: {'XSS Detected' if predictions[i] == 1 else 'No XSS Detected'}\n")
در این کد، مدل و وکتورایزر از فایل بارگذاری میشوند و دادههای جدید از یک فایل متنی خوانده شده و پردازش میشوند. پس از پیشبینی مدل، نتیجه برای هر جمله به نمایش درمیآید.
Abdal XSS AI Engine یک ابزار هوش مصنوعی قدرتمند برای شناسایی و جلوگیری از حملات XSS است. این مدل با استفاده از تکنیکهای پیشرفته یادگیری ماشین و پردازش متن میتواند الگوهای حملات مختلف را شناسایی کرده و به کاربران و توسعهدهندگان وب کمک کند تا از حملات سایبری محافظت شوند. توسعه و انتشار این مدل به صورت رایگان نشان از اهمیت مقابله با تهدیدات سایبری و تأمین امنیت وب برای همه کاربران، به ویژه در ایران، دارد.
دسترسی و دانلود Abdal XSS AI Engine
برای استفاده از Abdal XSS AI Engine، میتوانید به مخزن گیتهاب این پروژه به آدرس زیر مراجعه کنید:
https://github.com/ebrasha/abdal-xss-ai-engine
در این مخزن، کدهای مربوط به مدل، فایلهای لازم برای بارگذاری و اجرای مدل، و فایلهای راهنمای استفاده موجود هستند. برای دانلود و استفاده از این مدل، مراحل زیر را دنبال کنید:
مراحل دانلود و نصب:
کلون کردن مخزن گیتهاب: ابتدا مخزن پروژه را با استفاده از دستور زیر کلون کنید:
git clone https://github.com/ebrasha/abdal-xss-ai-engine.git
نصب وابستگیها: پس از کلون کردن مخزن، وارد پوشه پروژه شوید و وابستگیهای مورد نیاز را نصب کنید:
cd abdal-xss-ai-engine
pip install -r requirements.txt
دانلود مدل و وکتورایزر: فایلهای Abdal_XSS_AI_Engine.h5 و Abdal_XSS_AI_Engine.keras (مدل ذخیرهشده) و vectorizer.pkl (وکتورایزر TF-IDF) در مخزن موجود است. این فایلها را از مخزن گیتهاب دانلود کنید و در دایرکتوری اصلی پروژه قرار دهید.
دیدگاه های مربوط به این مقاله (برای ارسال دیدگاه در سایت حتما باید عضو باشید و پروفایل کاربری شما تکمیل شده باشد)
تعداد 2 دیدگاه ثبت شده
استاد وقت بخیر
استاد یک سوال
این مدلی که ساختید باید به طور مداوم روی سروری که سایت روش بالا اومده فعال باشه یا جور دیگهای هستش
میشه در این مورد یکم توضیح بدید
ممنون♥️😘
سلام به امیر عزیز ، شما می تونید هر زمان که نیاز دارید مدل رو فراخوانی کنید ، خیر نیاز نیست همیشه اجرا باشه . بستگی به خواسته شما و نوع پروژه داره .