ویژگی تصویر

تابع add_user_meta در وردپرس

  /  وردپرس   /  تابع add_user_meta در وردپرس
بنر تبلیغاتی الف
wp - wordpress - وردپرس

در وردپرس، مدیریت اطلاعات کاربران یکی از بخش‌های کلیدی و حیاتی برای توسعه‌دهندگان است. یکی از ابزارهای قدرتمند برای اضافه کردن اطلاعات سفارشی به کاربران، تابع add_user_meta() است. در این مقاله، به بررسی کامل این تابع، کاربردها، نحوه استفاده، و بهترین شیوه‌ها خواهیم پرداخت.

تابع add_user_meta() چیست؟

تابع add_user_meta() به شما اجازه می‌دهد داده‌های سفارشی (metadata) را به کاربران وردپرس اضافه کنید. این داده‌ها در جدول wp_usermeta ذخیره می‌شوند و می‌توانند شامل اطلاعاتی مانند شماره تلفن، آدرس، سطح دسترسی سفارشی یا هر نوع اطلاعات دیگر باشند.

ساختار تابع

add_user_meta( int $user_id, string $meta_key, mixed $meta_value, bool $unique = false )

پارامترهای این تابع عبارتند از:

  • $user_id: شناسه کاربری که می‌خواهید متا برای آن اضافه شود.
  • $meta_key: کلید متا که شناسایی داده را مشخص می‌کند.
  • $meta_value: مقدار متا که می‌تواند هر نوع داده‌ای باشد (رشته، عدد، آرایه و غیره).
  • $unique: اگر مقدار true باشد، اجازه تکراری بودن این متا برای همان کاربر داده نمی‌شود.

نمونه استفاده ساده

$user_id = 10;
add_user_meta($user_id, 'phone_number', '09123456789');

در این مثال، برای کاربری با شناسه ۱۰، یک متای جدید به نام phone_number اضافه شده است که مقدار آن 09123456789 است. اگر پارامتر $unique برابر true قرار می‌گرفت، وردپرس از اضافه شدن متای مشابه جلوگیری می‌کرد.

استفاده از پارامتر $unique

$user_id = 10;
add_user_meta($user_id, 'phone_number', '09123456789', true);

با تنظیم $unique = true، اگر متای phone_number برای کاربر از قبل وجود داشته باشد، وردپرس آن را اضافه نمی‌کند. این روش برای جلوگیری از داده‌های تکراری بسیار مفید است.

اضافه کردن چند مقدار به یک کاربر

گاهی نیاز داریم چند مقدار متفاوت با همان کلید متا برای یک کاربر ذخیره کنیم. در این حالت پارامتر $unique را false می‌کنیم:

$user_id = 10;
add_user_meta($user_id, 'favorite_color', 'red');
add_user_meta($user_id, 'favorite_color', 'blue');

در این مثال، کاربر می‌تواند چند رنگ مورد علاقه داشته باشد، زیرا $unique به صورت پیش‌فرض false است.

بهترین شیوه‌ها و نکات

  • همیشه قبل از اضافه کردن متا، بررسی کنید که آیا داده مشابه قبلاً وجود دارد یا خیر.
  • برای داده‌های حساس از sanitize_text_field() و توابع مشابه استفاده کنید.
  • برای داده‌های عددی و بولین، نوع داده را قبل از ذخیره‌سازی بررسی کنید.
  • نام کلید متا باید منحصر به فرد و توصیفی باشد تا بعدها بتوان به راحتی آن را مدیریت کرد.
  • استفاده از update_user_meta() در مواقعی که قصد به‌روزرسانی داده وجود دارد، کارایی بهتری دارد.

مقایسه add_user_meta() و update_user_meta()

ویژگیadd_user_meta()update_user_meta()
عملکرداضافه کردن مقدار جدیداضافه یا به‌روزرسانی مقدار موجود
پارامتر $uniqueداردندارد
استفاده مناسبزمانی که مطمئن هستید مقدار تکراری نداریدزمانی که می‌خواهید مقدار موجود را به‌روز کنید یا اضافه کنید

نمونه ترکیبی با بررسی وجود متا

$user_id = 10;
$meta_key = 'phone_number';
$meta_value = '09123456789';

if (!get_user_meta($user_id, $meta_key, true)) {
    add_user_meta($user_id, $meta_key, $meta_value, true);
}

در این مثال ابتدا بررسی می‌کنیم که آیا متای phone_number برای کاربر وجود دارد یا خیر. اگر وجود نداشته باشد، آن را اضافه می‌کنیم. این روش از خطا و داده‌های تکراری جلوگیری می‌کند.

نتیجه‌گیری

تابع add_user_meta() یک ابزار قدرتمند در مدیریت داده‌های سفارشی کاربران در وردپرس است. با رعایت بهترین شیوه‌ها و استفاده درست از پارامتر $unique، می‌توان از ذخیره‌سازی صحیح و منظم داده‌ها اطمینان حاصل کرد. ترکیب این تابع با توابع دیگری مانند get_user_meta() و update_user_meta() می‌تواند یک سیستم مدیریت داده کاربر بسیار منعطف و قابل توسعه ایجاد کند.

آیا این مطلب برای شما مفید بود ؟

خیر
بله
موضوعات شما در انجمن: