سلام دوستان؛
همه ی ما برای ورود به سایتمون فرم ورود داریم که قبلا با ثبت نام برامون باز میشه! اما همه ی ما به عنوان یه کاربر در مرحله ی اول ثبت نام میکنیم.همونطور که می بینید سیستم مدیریت محتوای وردپرس خودش فرم ثبت نامی رو برای کاربران سایت ها محیا داره که میشه هر تعداد کاربر در سایت ثبت نام کنند. اما چطوری میتونیم این فرم رو به میل و خواست خودمون جوری سفارشی سازی کنیم که تنظیماتش مخصوص خودمون بشه؟
در این مقاله آموزشی، مقصود نحوه ی سفارشی سازی فرم ثبت نام با استفاده از برچسب های پوسته و کدهای کوتاه شده (shortcode) ها هستش.
فرم ثبت نام به صورت پیش فرض از دو بخش نام کاربری و آدرس ایمیل تشکیل شده که در تصویر مشاهده می کنید.
درخواست فقط نام کاربری و ایمیل از کاربر امری فوق العاده ساده است. در واقع میگه اول، نام کاربری و ایمیل رو وارد کنید سپس پسورد رو براتون ارسال خواهیم کرد تا بتونین باقی مشخصات پروفایل رو تکمیل کنید! خب چرا به جای این کار از همون اول کاربر همه ی مشخصات رو در مرحله ی اول وارد کنه و مرحله ی ثبت نام رو در یک گام انجام بدیم.
امروز قصدمون اینه که فرم ثبت نامی بسازیم که شامل موارد زیر باشه:
نام کاربری،رمز عبور،ایمیل،آدرس سایت، نام و نام خانوادگی، نام مستعار و بیوگرافی!
این فرم ثبت نام رو میتونیم از طریق شورت کد یا تگ های قالب نمایش بدیم.
با استفاده از شورت کدها قادر به ایجاد برگه ای رسمی از حالت ثبت نام در سایت خواهید بود. شما میتونید از این شورت کد در پست خود استفاده کنید تا کاربر بتونه به محض وارد شدن، نوشته یا مقاله را بخواند.
ساخت افزونه
بی مقدمه میریم سراغ ساخت افزونه! کدهای زیر به عنوان بخش معرفی افزونه به کار میرند:
<?php /* Plugin Name: Custom Registration Plugin URI: http://code.tutsplus.com Description: Updates user rating based on number of posts. Version: 1.0 Author: Agbonghama Collins Author URI: http://tech4sky.com */
سپس تابع پی اچ پی که شامل کدهای اچ تی ام ال برای فرم ثبت نام هست رو ایجاد میکنیم:
function registration_form( $username, $password, $email, $website, $first_name, $last_name, $nickname, $bio ) { echo ' <style> div { margin-bottom:2px; } input{ margin-bottom:4px; } </style> '; echo ' <form action="' . $_SERVER['REQUEST_URI'] . '" method="post"> <div> <label for="username">Username <strong>*</strong></label> <input type="text" name="username" value="' . ( isset( $_POST['username'] ) ? $username : null ) . '"> </div> <div> <label for="password">Password <strong>*</strong></label> <input type="password" name="password" value="' . ( isset( $_POST['password'] ) ? $password : null ) . '"> </div> <div> <label for="email">Email <strong>*</strong></label> <input type="text" name="email" value="' . ( isset( $_POST['email']) ? $email : null ) . '"> </div> <div> <label for="website">Website</label> <input type="text" name="website" value="' . ( isset( $_POST['website']) ? $website : null ) . '"> </div> <div> <label for="firstname">First Name</label> <input type="text" name="fname" value="' . ( isset( $_POST['fname']) ? $first_name : null ) . '"> </div> <div> <label for="website">Last Name</label> <input type="text" name="lname" value="' . ( isset( $_POST['lname']) ? $last_name : null ) . '"> </div> <div> <label for="nickname">Nickname</label> <input type="text" name="nickname" value="' . ( isset( $_POST['nickname']) ? $nickname : null ) . '"> </div> <div> <label for="bio">About / Bio</label> <textarea name="bio">' . ( isset( $_POST['bio']) ? $bio : null ) . '</textarea> </div> <input type="submit" name="submit" value="Register"/> </form> '; }
فیلد ثبت نام در بالا دارای متغیرهای متفاوتی است. در کدهای عملکردی شما میتونید نمونه ی کدها رو ببنید.به طور مثال:
( isset( $_POST['lname'] ) ? $last_name : null )
فرم ثبت نام هرگز به مرحله ی تکامل نمیرسه مگر اینکه شما بهش اعتبار ببخشید تا کاربران حق ورود پیدا کنند. در نتیجه، باید تابع اعتباری با عنوان Registration_validation بهش داده بشه.
۱- ایجاد تابع و عبور از بخش ثبت نام در آرگومان تابع.
function registration_validation( $username, $password, $email, $website, $first_name, $last_name, $nickname, $bio ) {
۲- استفاده از کلاس wp_error برای دسترسی به توابع.
global $reg_errors; $reg_errors = new WP_Error;
۳- یادآوری: باید اعلام کنیم که ثبت نام کاربری و پسورد و ایمیل اجباری است و نباید فراموش بشه. برای اجرای این قانون، نیاز به چک کردن تمامی فیلدهای خالی داریم. اگر خالی بود باید پیغام خطایی اعلام بشه که مربوط به کلاس wp-error هستش.
if ( empty( $username ) || empty( $password ) || empty( $email ) ) { $reg_errors->add('field', 'Required form field is missing'); }
۴- البته ما باید چک کنیم که تعداد کاراکترهای نام کاربری کمتر از ۴ تا نباشه.
if ( 4 > strlen( $username ) ) { $reg_errors->add( 'username_length', 'Username too short. At least 4 characters is required' ); }
۵- چک کردن زمان به وجود اومدن نام کاربری
if ( username_exists( $username ) ) $reg_errors->add('user_name', 'Sorry, that username already exists!');
۶- ایجاد خدمات وردپرس با تابع validation_username برای ایجاد نام کاربری معتبر.
if ( ! validate_username( $username ) ) { $reg_errors->add( 'username_invalid', 'Sorry, the username you entered is not valid' ); }
۷- رمز عبور انتخابی توسط کاربر نباید کمتر از ۵ کاراکتر باشد.
if ( 5 > strlen( $password ) ) { $reg_errors->add( 'password', 'Password length must be greater than 5' ); }
۸- ایمیل وارد شده معتبر باشد.
if ( !is_email( $email ) ) { $reg_errors->add( 'email_invalid', 'Email is not valid' ); }
۹- اعلام موفقیت ثبت ایمیل.
if ( email_exists( $email ) ) { $reg_errors->add( 'email', 'Email Already in use' ); }
۱۰- اگر بخش آدرس سایت پر شد باید اعتبار آن چک شود.
if ( ! empty( $website ) ) { if ( ! filter_var( $website, FILTER_VALIDATE_URL ) ) { $reg_errors->add( 'website', 'Website is not a valid URL' ); } }
۱۱- در پایان، هر کدام از موارد ذکر شده مشکل داشت باید پیغام خطایی اعلام شود.
if ( is_wp_error( $reg_errors ) ) { foreach ( $reg_errors->get_error_messages() as $error ) { echo '<div>'; echo '<strong>ERROR</strong>:'; echo $error . '<br/>'; echo '</div>'; } }
سپس تابع ()complete_registration در افزونه برای ثبت نام کاربر باید در نظر گرفته شود. در واقع ثبت نام کاربر به وسیله تابع wp_insert_user مورد تایید قرار گیرد.
function complete_registration() { global $reg_errors, $username, $password, $email, $website, $first_name, $last_name, $nickname, $bio; if ( 1 > count( $reg_errors->get_error_messages() ) ) { $userdata = array( 'user_login' => $username, 'user_email' => $email, 'user_pass' => $password, 'user_url' => $website, 'first_name' => $first_name, 'last_name' => $last_name, 'nickname' => $nickname, 'description' => $bio, ); $user = wp_insert_user( $userdata ); echo 'Registration complete. Goto <a href="' . get_site_url() . '/wp-login.php">login page</a>.'; } }
در مرحله ی بعدی، تابع ()custom_registration_function برای تمامی توابع ایجاد شده در کد بالا کاربرد دارد.
function custom_registration_function() { if ( isset($_POST['submit'] ) ) { registration_validation( $_POST['username'], $_POST['password'], $_POST['email'], $_POST['website'], $_POST['fname'], $_POST['lname'], $_POST['nickname'], $_POST['bio'] ); // sanitize user form input global $username, $password, $email, $website, $first_name, $last_name, $nickname, $bio; $username = sanitize_user( $_POST['username'] ); $password = esc_attr( $_POST['password'] ); $email = sanitize_email( $_POST['email'] ); $website = esc_url( $_POST['website'] ); $first_name = sanitize_text_field( $_POST['fname'] ); $last_name = sanitize_text_field( $_POST['lname'] ); $nickname = sanitize_text_field( $_POST['nickname'] ); $bio = esc_textarea( $_POST['bio'] ); // call @function complete_registration to create the user // only when no WP_error is found complete_registration( $username, $password, $email, $website, $first_name, $last_name, $nickname, $bio ); } registration_form( $username, $password, $email, $website, $first_name, $last_name, $nickname, $bio ); }
حال فرم ثبت نام به صورت زیر در میاد:
// Register a new shortcode: [cr_custom_registration] add_shortcode( 'cr_custom_registration', 'custom_registration_shortcode' ); // The callback function that will replace [book] function custom_registration_shortcode() { ob_start(); custom_registration_function(); return ob_get_clean(); }
استفاده از افزونه
برای استفاده و نمایش افزونه از شورت کد [cr_custom_registration] استفاده کنید.در صورت تمایل میتونید از کد پی اچ پی نیز استفاده کنید:
<?php custom_registration_function(); ?>
در این مقاله سعی شد فرم ثبت نام وردپرس رو توسعه بدیم و فرم بهتر و بهینه تری رو ایجاد کنیم. امیدوارم با رعایت نکات ایمینی و همچنین آگاهی دقیق بتونین از این امکان بهره مند بشید.
موفق باشید
امیرحسین
مرسی از مطلب خوبتون.
من میخوام از یه افزونه ثبت نام آماده استفاده کنم برای یه سایت ثبت نام کلاسها و میخوام آخر ثبت نام به درگاه یک بانک وصل بشه و هزینه پرداخت بشه.پیشنهاد شما چیه؟از چه افزونه ای استفاده کنم و برای پرداخت آنلاین چیکار کنم؟ آیا لازمه حتما از ووکامرس استفاده کنم؟چیزی برای فروش ندارم!
بهاره کوهستانی 11 سال عضو همیار وردپرس
سلام
برای اینکار میتونید از اشتراک وی آی پی استفاده کنید.
افزونه ی وی آی پی
سعید
سلام و ممنون از آموزشتون
ولی خیلی بهتر می شد که خروجی این پلاگین رو هم آپلود می کردید یا یک مقدمه ای از ساخت پلاگین وردپرس در این مقاله می گزاشتید… بالاخره تازه کار ها هم میخوان بفهمند دیگه 😉
شاهید
سلام
ضمن خسته نباشید
در سایت بنده کابران بعداز ثبت نام ایمیلی حاوی نام کاربری دریافت می کنند
اما کاربرانی که رمز عبور را فراموش کرده اند ، در بخش بازیابی رمزعبور ،با ثبت ایمیل و تایید ،هیچ ایمیلی دریافت نمی کنند .
کدام قسمت را باید تنظیم نماییم
من را راهنمایی بفرمایید سپاسگزارم
یاحق
بهاره کوهستانی 11 سال عضو همیار وردپرس
سلام
ارسال ایمیل یک خاصیت اتوماتیک در وردپرس هست و تنظیماتی نداره. داخل این فرم هم برنامه ای جهت این کار نوشته نشده.
بهنام
سلام من یه سایت دارم که تویه اون افراد برای همایش ثبت نام می کنند
و به یک سری پارامتر های خاص نیاز داریم برای مثال نام نام خانوادگی نام همایش شماره تماس نیازی به ثبت نام در ورد پرس نیست ایا همچین امکانی وجود داره و چطور؟
بهاره کوهستانی 11 سال عضو همیار وردپرس
سلام
پیشنهاد میکنم از امکانات captainform استفاده نمایید.
MINA
با سلام
من نیاز به افزونه ی دارم که از طریق اون یه سری کلاس ها رو تعریف کنم و کاربر بتونه در اونها ثبت نام کنه و مبلغ کلاس رو پرداخت کنه.
شما میشناسین همچین افزونه ای؟
ممنون از راهنمایی
حسین رحیمی 11 سال عضو همیار وردپرس
با احترام
می توانید از ووکامرس و سیستم sensei (که با ووکامرس کار می کند) استفاده کنید.
سیستم سنسی پولی هست و در همیار وردپرس موجود نیست.
http://hamyarwp.com/آموزش-ووکامرس
matin
سلام من می خوام یه افزونه واسه عضویت افراد داشته باشم ک از اون طریق هر فردی ی پنل کاربری داشته باشه تا من بتونم بطور مثال توی پنلش مشکلاتشو رفع کنم و مثلا نمودار پیشرفتو …. شو بزارم میشه کمکم کنید…
ممنون
بهاره کوهستانی 11 سال عضو همیار وردپرس
سلام
این چیزی گه شما میخواید به صورت افزونه وجود نداره و باید برنامه نویس، بنویسه
msoheili071126 10 سال عضو همیار وردپرس
سلام، چطور میتونم توی فرم ثبت نام وردپرس، فیلد ایمل رو غیر اجباری کنم ؟ یعنی اگه کاربر موقع ثبت نام ایمیل رو وارد نکرد و فیلد خالی باشه بهش گیر نده.
Bahar 11 سال عضو همیار وردپرس
سلام
عنوان ایمیل رو در فانکشن به حالت غیر ضروری تبدیل کنید
یعنی بر روی این بخش باید تغییر ایجاد کنید :
novinkeshtsepahan752 10 سال عضو همیار وردپرس
سلام مرسی از همه ی راهنمایی هاتون . میشه آموزش این افزونه رو تصویری بزارین .
Bahar 11 سال عضو همیار وردپرس
سلام
در اسرع وقت بررسی و در اختیار دوستان برای ساخت ویدئو قرار میگیره
mehrab_125338 10 سال عضو همیار وردپرس
سلام
من یه cms دارم می خوام داخل وردپرس بیارمش
باید چی کار کنم
بعد یه مرجع می خواستم برای اینکه cms هم رو قوی کنم نیاز داشتم
ممنون
Bahar 11 سال عضو همیار وردپرس
سلام
وردپرس خودش سی ام اس هست! یعنی چی که سی ام اس رو داخل وردپرس بیارید ؟
porya
با سلام می شه یه آموزش برای ثبت نام با ajax هم بزارین ممنون می شم .