سبد دانلود 0

تگ های موضوع توابع کار با فیلترها در

توابع کار با فیلترها در PHP


فیلترها در PHP ابزاری قدرتمند برای اعتبارسنجی و تصفیه داده‌ها هستند. این توابع به شما امکان می‌دهند که ورودی‌ها را بررسی کرده و آن‌ها را تصحیح کنید. از این رو، استفاده از فیلترها می‌تواند به افزایش امنیت و کیفیت داده‌ها کمک کند.

استفاده از توابع فیلتر


PHP شامل یک مجموعه از توابع فیلتر است که می‌توانید برای اهداف مختلف از آن‌ها استفاده کنید. مهم‌ترین توابع شامل:
  1. filter_var(): این تابع برای اعتبارسنجی و تصفیه یک متغیر استفاده می‌شود.
- مثال:
```php
$email = "test@example.com";
if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
echo "ایمیل معتبر است.";
} else {
echo "ایمیل نامعتبر است.";
}
```
  1. filter_input(): این تابع برای دریافت ورودی‌ها از superglobals مانند `$_GET`, `$_POST`, و `$_COOKIE` استفاده می‌شود.
- مثال:
```php
$user_input = filter_input(INPUT_POST, 'user', FILTER_SANITIZE_STRING);
```
  1. filter_var_array(): این تابع برای فیلترکردن یک آرایه از مقادیر به کار می‌رود.
- مثال:
```php
$data = [
'username' => 'user123',
'email' => 'user@example.com'
];
$filters = [
'username' => FILTER_SANITIZE_STRING,
'email' => FILTER_VALIDATE_EMAIL
];
$filtered_data = filter_var_array($data, $filters);
```

انواع فیلترها


PHP انواع مختلفی از فیلترها را ارائه می‌دهد که شامل:
- FILTER_VALIDATE_EMAIL: برای اعتبارسنجی ایمیل.
- FILTER_SANITIZE_STRING: برای حذف کاراکترهای غیرمجاز.
- FILTER_VALIDATE_URL: برای اعتبارسنجی URL.

جمع‌بندی


استفاده از توابع فیلتر در PHP نه تنها به اعتبارسنجی داده‌ها کمک می‌کند بلکه می‌تواند جلوی حملات SQL Injection و XSS را بگیرد. بنابراین، این توابع بخش مهمی از هر برنامه PHP هستند. با درک و استفاده صحیح از آن‌ها، می‌توانید امنیت و کیفیت برنامه‌های خود را بهبود ببخشید.

توابع کار با فیلترها در PHP: راهکاری قدرتمند برای اعتبارسنجی و پاکسازی داده‌ها


در PHP، فیلترها (Filters) ابزارهایی هستند که برای اعتبارسنجی (Validation) و پاکسازی (Sanitization) داده‌ها به کار می‌روند. این توابع باعث می‌شوند تا ورودی‌های کاربران یا داده‌های خارجی به شکل ایمن‌تر و منظم‌تر پردازش شوند. به طور کلی، فیلترها به دو دسته اصلی تقسیم می‌شوند: فیلترهای اعتبارسنجی و فیلترهای پاکسازی.

اعتبارسنجی داده‌ها با فیلترها (Validation Filters)


این نوع فیلترها بررسی می‌کنند که داده ورودی با شرایط خاصی تطابق داشته باشد یا خیر. به عنوان مثال، بررسی اینکه یک ایمیل معتبر است، یا یک عدد در بازه مشخصی قرار دارد. اگر داده ورودی معتبر نباشد، تابع مربوطه مقدار false بازمی‌گرداند.
مثال:
```php
$email = "example@domain.com";
if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
echo "ایمیل معتبر است.";
} else {
echo "ایمیل نامعتبر است.";
}
```

پاکسازی داده‌ها با فیلترها (Sanitization Filters)


این فیلترها داده‌ها را از کاراکترهای ناخواسته پاک می‌کنند یا تغییر می‌دهند تا برای ذخیره یا نمایش امن باشند. مثلا حذف کاراکترهای خاص از رشته‌ها یا تبدیل آنها به شکل ایمن.
مثال:
```php
$str = "<h1>Hello!</h1>";
$clean_str = filter_var($str, FILTER_SANITIZE_STRING);
echo $clean_str; // خروجی: Hello!
```
> توجه: در نسخه‌های جدیدتر PHP، FILTER_SANITIZE_STRING منسوخ شده و بهتر است از راهکارهای دیگر مثل `htmlspecialchars()` استفاده شود.

تابع اصلی: filter_var()


تابع `filter_var()` مهم‌ترین و پرکاربردترین تابع برای اعمال فیلترهاست. این تابع دو آرگومان اصلی می‌گیرد: مقدار ورودی و نوع فیلتر.
```php
filter_var(mixed $variable, int $filter = FILTER_DEFAULT, array|int $options = 0): mixed
```
- `$variable`: داده‌ای که باید فیلتر شود.
- `$filter`: نوع فیلتر مورد نظر، مثل `FILTER_VALIDATE_INT` یا `FILTER_SANITIZE_EMAIL`.
- `$options`: آرایه‌ای از گزینه‌ها که می‌تواند رفتار فیلتر را تنظیم کند.

فیلترهای مهم و پرکاربرد


- `FILTER_VALIDATE_INT`: بررسی عدد صحیح
- `FILTER_VALIDATE_EMAIL`: بررسی صحت ایمیل
- `FILTER_VALIDATE_URL`: بررسی صحت آدرس وب
- `FILTER_SANITIZE_STRING`: پاکسازی رشته (در نسخه‌های جدید منسوخ شده)
- `FILTER_SANITIZE_EMAIL`: پاکسازی ایمیل
- `FILTER_SANITIZE_URL`: پاکسازی URL

استفاده از آرایه گزینه‌ها برای تنظیمات پیشرفته


مثلاً برای اعتبارسنجی عدد در بازه خاص:
```php
$options = array(
"options" => array(
"min_range" => 1,
"max_range" => 100
)
);
$number = 50;
if (filter_var($number, FILTER_VALIDATE_INT, $options) !== false) {
echo "عدد معتبر است.";
} else {
echo "عدد نامعتبر است.";
}
```

توابع مرتبط با فیلترها


- `filter_input()`: برای دریافت و فیلتر کردن داده‌های ورودی (مثل GET، POST)
- `filter_input_array()`: برای فیلتر کردن آرایه‌ای از ورودی‌ها
- `filter_var_array()`: برای فیلتر کردن آرایه‌ای از داده‌ها
مثال:
```php
$inputs = filter_input_array(INPUT_POST, [
'age' => ['filter' => FILTER_VALIDATE_INT, 'options' => ['min_range' => 18]],
'email' => FILTER_VALIDATE_EMAIL
]);
```

جمع‌بندی


توابع فیلتر در PHP، راهی ساده و در عین حال قدرتمند برای مدیریت و کنترل داده‌های ورودی هستند. آن‌ها باعث می‌شوند تا کدهای شما ایمن‌تر، خواناتر و قابل اطمینان‌تر باشند. استفاده از این توابع، به خصوص هنگام کار با داده‌های کاربران، توصیه بسیار مهمی است که نباید نادیده گرفته شود.
اگر می‌خواهید برنامه‌های PHP حرفه‌ای‌تر و امن‌تری بنویسید، یادگیری و تسلط بر توابع فیلترها ضروری است. این ابزارها، ستون فقرات اعتبارسنجی و پاکسازی داده‌ها در PHP محسوب می‌شوند.
مشاهده بيشتر