neda299

ورود با شماره موبایل به جای ایمیل در وردپرس

12 پست در این موضوع قرار دارد

سلام دوستان

میخوام کد بخش ثبت نام سایت و لاگین رو طوری تغییر بدم که به جای ایمیل با شماره موبایل کار کنه یعنی هم ثبت نام کنه هم برای ورود شماره موبایل رو بگیره لاگین کنه

کدشو اگر کسی دارین ممنون میشم بدین یا اینکه راهنمایی کنین چطوری تغییرش بدم در حد متوسط یا خوب خود وردپرس و کدنویسیشو بلدم

0

به اشتراک گذاری این پست


لینک به پست

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

در بخش ثبت نام باید یک فیلد به اسم موبایل اضافه کنید و شماره موبایل رو در یوزر متا ذخیره کنید
برای لاگین هم باید از طریق شماره موبایل user_login رو بدست بیارین بعد از طریق تابع wp_signon لاگین کردن(یوزر و پسورد) رو چک و انجام بدین

3

به اشتراک گذاری این پست


لینک به پست

یک دنیا ممنون از کمکتون

من یک یوزر متا به فرم ثبت نام اضافه کردم که شماره موبایل رو تو دیتابیس ذخیره میکنه و تو پروفایل هر شخص هم قابل ادیت هست حالا فقط نمیدونم باید چطوری ایمیل رو حذف کنم از صفحه ثبت نام و فقط با شماره موبایل و پسورد کاربر وارد سایت بشه(تقریبا منظورم خط دوم صحبت شماست
راستی من این بخشو به صورت یک پلاگین تا الان نوشتم .

 

 

0

به اشتراک گذاری این پست


لینک به پست

ارسال شده در (ویرایش شده)

<?php
/*
Plugin Name: ورود با موبایل
/
*/
add_action( 'register_form', 'crf_registration_form' );
function crf_registration_form() { ?>
 <p>
        <label for="mpmobile">شماره موبایل<br/>
            <input type="text" class="form-control" name="mpmobile" id="reg_billing_mob_num" value="<?php if ( ! empty( $_POST['mpmobile'] ) ) esc_attr_e( $_POST['mpmobile'] ); ?>" />
        </label>
</p>
<?php
}
add_filter( 'registration_errors', 'crf_validate_mobnum_register', 10, 3 );
function crf_validate_mobnum_register( $errors, $sanitized_user_login, $user_email ) {
    if ( isset( $_POST['mpmobile'] ) && empty( $_POST['mpmobile'] ) ) {
        $errors->add( 'mpmobile_error', __( 'شماره تلفن همراه خود را وارد کنید.', 'woocommerce' ) );
    }
    elseif (isset( $_POST['mpmobile'] ) &&  !preg_match("/^09-?[0-9]{2}-?[0-9]{3}-?[0-9]{4}$/",  $_POST['mpmobile'] )) {
        $errors->add( 'mpmobile_error', __( 'شماره تلفن همراه خود را در قالب درست وارد کنید.', 'woocommerce' ) );
    }
    else {
        $yoursearchquery =  $_POST['mpmobile'] ;
        $args = array( 'meta_key' => 'mpmobile', 'meta_value' => $yoursearchquery, 'number' => 1 ) ;
 
        $user_query = new WP_User_Query( $args );
        // User Loop
        if ( ! empty( $user_query->results ) ) {
            $errors->add( 'mpmobile_error', __( 'این شماره تلفن در سیستم قبلا ثبت نام شده است.', 'woocommerce' ) );
        }
    }
    return $errors;
}

add_action( 'user_register', 'crf_user_register' );
function crf_user_register( $user_id ) {
    if ( isset( $_POST['mpmobile'] ) ) {
        update_user_meta( $user_id, 'mpmobile', sanitize_text_field( $_POST['mpmobile'] ) );
    }
}

add_action( 'show_user_profile', 'my_show_mobnum_profile_fields' );
add_action( 'edit_user_profile', 'my_show_mobnum_profile_fields' );
function my_show_mobnum_profile_fields ( $user ){
    ?>
<table class="form-table">
    <tr>
        <th><label for="mpmobile">شماره تلفن همراه</label></th>
        <td>
            <input type="text" name="mpmobile" id="mpmobile" value="<?php echo esc_attr( get_the_author_meta( 'mpmobile', $user->ID ) ); ?>" class="regular-text" />
            <span class="description">لطفا شماره تلفن همراه را وارد کنید ، به طور مثال : ۰91200000000</span>
        </td>
    </tr>
</table>
<?php }
add_action( 'personal_options_update', 'save_extra_user_profile_fields' );
add_action( 'edit_user_profile_update', 'save_extra_user_profile_fields' );
 
function save_extra_user_profile_fields( $user_id ) {
 
if ( !current_user_can( 'edit_user', $user_id ) ) { return false; }
 
update_user_meta( $user_id, 'mpmobile', $_POST['mpmobile'] );
}

ویرایش شده در توسط neda299
0

به اشتراک گذاری این پست


لینک به پست
در در 6/26/2018 at 10:32، lord_viper گفته است :

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

در بخش ثبت نام باید یک فیلد به اسم موبایل اضافه کنید و شماره موبایل رو در یوزر متا ذخیره کنید
برای لاگین هم باید از طریق شماره موبایل user_login رو بدست بیارین بعد از طریق تابع wp_signon لاگین کردن(یوزر و پسورد) رو چک و انجام بدین

سلام مجدد و تشکر بابت پاسخ دهیتون

امکانش هست در مورد خط دومتون بیشتر توضیح بدین؟
(برای لاگین هم باید از طریق شماره موبایل user_login رو بدست بیارین بعد از طریق تابع wp_signon لاگین کردن(یوزر و پسورد) رو چک و انجام بدین)

0

به اشتراک گذاری این پست


لینک به پست

ببینین WP_SIGNON 2 تا پارامتر میگیره user_login و password خب حرکت شما این هست که از شماره موبایل به user_login برسین تا بتونین لاگین رو انجام بدین

برای این کار با استفاده از شماره موبایل که تو جدول usermeta هست user_id رو بدست میارین و از طریق این user_id هم user_login مرتبط با اون شماره موبایل رو بدست میارین بعد با استفاده از user_loogin وpassword که کاربر وارد کرده به تابع wp_signop ارسال میکنین در صورتی که یوزر و پسورد صحیح باشه(برای 1 کاربر ) باشه لاگین میشه

این برای زمانی هست که بخش لاگین رو خودتون نوشته باشین

اگه میخواهید برای لاگینهای دیگه یا لاگین وردپرس این کار رو انجام بدین باید از هوک زیر استفاده کنید

add_action( 'wp_authenticate' , 'check_custom_authentication' );

 

2

به اشتراک گذاری این پست


لینک به پست

وقت بخیر

من این کد رو نوشتم ولی بازم وارد سایت نمیشه

// shortcode login form
add_shortcode('newloginform','myplugin_add_login_fields');
add_action( 'login_form', 'myplugin_add_login_fields' );
function myplugin_add_login_fields() {
    if ( isset( $_POST['wp-submit'] )) {
        $mobid = $_POST['mpmobile'];
        $redirectt = $_POST['redirect'];
        $formpwd = $_POST['pwd'];
        if ( ! empty($mobid) || ! empty($formpwd) ) {
            $args = array(
                'meta_query' => array(
                    array(
                        'key' => 'mpmobile',
                        'value' => $mobid,
                    )
                )
            );
            $user_query = new WP_User_Query( $args );
            if ( ! empty( $user_query->get_results() ) ) {
                    foreach ( $user_query->get_results() as $user ) {
                        $userlog = $user->user_login;
                        $userpa = $_POST['pwd'];
                    }
                add_action('wp_authenticate','tiny_login');
                function tiny_login() {
                    $creds = array();
                    $creds['user_login'] = $userlog;
                    $creds['user_password'] = $userpa;
                    $creds['remember'] = false;
                    $user = wp_signon( $creds );
                    echo $user;
                    if ( is_wp_error($user) ) {
                      $tiny_error = $user->get_error_message();
                    } else {
                        wp_redirect($redirectt);
                        echo $redirectt;
                    }
                }
            } else {
                echo 'این شماره در سیستم ثبت نشده است.';
            }
        }else{
            echo 'شماره تلفن همراه یا پسورد وارد نشده است.';
        }
}
  ?>
    <form id="login-form" action="<?php //echo wp_login_url();?>" method="post">
        شماره همراه : <input type="text" name="mpmobile" />
        پسورد : <input id="login-password" type="password" name="pwd" />
        <input type="text" name="redirect" value="/wp-admin/">
        <input id="login-submit" type="submit" name="wp-submit" value="ورود" />
        <a id="membership" href="<?php echo wp_login_url();?>?action=register">عضویت</a> <a href="<?php echo wp_login_url();?>?action=lostpassword">رمز خود را فراموش کرده ام!</a>
      </form>
<?php
}

دیگه واقعا نمیدونم باید چکار کنم

0

به اشتراک گذاری این پست


لینک به پست
در در 6/28/2018 at 19:17، lord_viper گفته است :

ببینین WP_SIGNON 2 تا پارامتر میگیره user_login و password خب حرکت شما این هست که از شماره موبایل به user_login برسین تا بتونین لاگین رو انجام بدین

برای این کار با استفاده از شماره موبایل که تو جدول usermeta هست user_id رو بدست میارین و از طریق این user_id هم user_login مرتبط با اون شماره موبایل رو بدست میارین بعد با استفاده از user_loogin وpassword که کاربر وارد کرده به تابع wp_signop ارسال میکنین در صورتی که یوزر و پسورد صحیح باشه(برای 1 کاربر ) باشه لاگین میشه

این برای زمانی هست که بخش لاگین رو خودتون نوشته باشین

اگه میخواهید برای لاگینهای دیگه یا لاگین وردپرس این کار رو انجام بدین باید از هوک زیر استفاده کنید


add_action( 'wp_authenticate' , 'check_custom_authentication' );

 

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

0

به اشتراک گذاری این پست


لینک به پست

منظورتون کدی که نوشتین هست؟

 

کدتون تقریبا به صورت زیر میشه

// shortcode login form
add_shortcode('newloginform','myplugin_add_login_fields');
add_action( 'login_form', 'myplugin_add_login_fields' );
function myplugin_add_login_fields() {
    if ( isset( $_POST['wp-submit'] )) {
        $mobid = $_POST['mpmobile'];
        $redirectt = $_POST['redirect'];
        $formpwd = $_POST['pwd'];
        if ( ! empty($mobid) || ! empty($formpwd) ) {

            $user_query = get_users(array('meta_key' => 'mpmobile', 'meta_value' => $mobid));
            if ( ! empty( $user_query) ) {

                    $creds = array();
                    $creds['user_login']    = $user_query->user_login;
                    $creds['user_password'] = $formpwd;
                    $creds['remember']      = false;
                    $user  = wp_signon( $creds );
                    echo $user;
                    if ( is_wp_error($user) ) {
                      $tiny_error = $user->get_error_message();
                    } else {
                        wp_redirect($redirectt);
                        echo $redirectt;
                    }
                }
            } else {
                echo 'این شماره در سیستم ثبت نشده است.';
            }
        }else{
            echo 'شماره تلفن همراه یا پسورد وارد نشده است.';
        }
  ?>
    <form id="login-form" action="<?php //echo wp_login_url();?>" method="post">
        شماره همراه : <input type="text" name="mpmobile" />
        پسورد : <input id="login-password" type="password" name="pwd" />
        <input type="text" name="redirect" value="/wp-admin/">
        <input id="login-submit" type="submit" name="wp-submit" value="ورود" />
        <a id="membership" href="<?php echo wp_login_url();?>?action=register">عضویت</a> <a href="<?php echo wp_login_url();?>?action=lostpassword">رمز خود را فراموش کرده ام!</a>
      </form>
<?php
}

 

1

به اشتراک گذاری این پست


لینک به پست

متاسفانه در همه حالات این تابع wp_signon اصلا کار نمیکنه من الان میخوام وقتی شماره موبایل و پسورد زده میشه وارد داشبورد یا یک لینکی که میدم ری دایرکت بشه اما هیچ تغییری اعمال نمیشه

در حال حاضر وقتی توی فرمم موبایل و پسورد میزنم ارور نمیده اما وارد هم نمیشه

در 58 دقیقه قبل، lord_viper گفته است :

منظورتون کدی که نوشتین هست؟

 

کدتون تقریبا به صورت زیر میشه


// shortcode login form
add_shortcode('newloginform','myplugin_add_login_fields');
add_action( 'login_form', 'myplugin_add_login_fields' );
function myplugin_add_login_fields() {
    if ( isset( $_POST['wp-submit'] )) {
        $mobid = $_POST['mpmobile'];
        $redirectt = $_POST['redirect'];
        $formpwd = $_POST['pwd'];
        if ( ! empty($mobid) || ! empty($formpwd) ) {

            $user_query = get_users(array('meta_key' => 'mpmobile', 'meta_value' => $mobid));
            if ( ! empty( $user_query) ) {

                    $creds = array();
                    $creds['user_login']    = $user_query->user_login;
                    $creds['user_password'] = $formpwd;
                    $creds['remember']      = false;
                    $user  = wp_signon( $creds );
                    echo $user;
                    if ( is_wp_error($user) ) {
                      $tiny_error = $user->get_error_message();
                    } else {
                        wp_redirect($redirectt);
                        echo $redirectt;
                    }
                }
            } else {
                echo 'این شماره در سیستم ثبت نشده است.';
            }
        }else{
            echo 'شماره تلفن همراه یا پسورد وارد نشده است.';
        }
  ?>
    <form id="login-form" action="<?php //echo wp_login_url();?>" method="post">
        شماره همراه : <input type="text" name="mpmobile" />
        پسورد : <input id="login-password" type="password" name="pwd" />
        <input type="text" name="redirect" value="/wp-admin/">
        <input id="login-submit" type="submit" name="wp-submit" value="ورود" />
        <a id="membership" href="<?php echo wp_login_url();?>?action=register">عضویت</a> <a href="<?php echo wp_login_url();?>?action=lostpassword">رمز خود را فراموش کرده ام!</a>
      </form>
<?php
}

 

 

0

به اشتراک گذاری این پست


لینک به پست

ببخشید چرا از پلاگین های آماده این کار استفاده نمی کنید؟

0

به اشتراک گذاری این پست


لینک به پست

اگه بخواهید از هوک استفاده کنید کد به صورت زیر میشه

add_action( 'wp_authenticate' , 'check_custom_authentication');

function check_custom_authentication (&$mobid ) {
        global $wpdb;
        if(!is_numeric($mobid) or strlen($mobid)!=11)
        return;
        $user_query = get_users(array('meta_key' => 'mpmobile', 'meta_value' => $mobid));
        if ( ! empty( $user_query) )
        $mobid = $user_query[0]->data->user_login;
}

کد شما هم به صورت زیر میشه

// shortcode login form
add_shortcode('newloginform','myplugin_add_login_fields');
add_action( 'login_form', 'myplugin_add_login_fields' );
function myplugin_add_login_fields() {
    if ( isset( $_POST['wp-submit'] )) {
        $mobid = $_POST['mpmobile'];
        $redirectt = $_POST['redirect'];
        $formpwd = $_POST['pwd'];
        if ( ! empty($mobid) || ! empty($formpwd) ) {

            $user_query = get_users(array('meta_key' => 'mpmobile', 'meta_value' => $mobid,'fields'=>['user_login']));
            if ( ! empty( $user_query) ) {

                    $creds = array();
                    $creds['user_login']    = $user_query[0]->user_login;
                    $creds['user_password'] = $formpwd;
                    $creds['remember']      = false;
                    $user  = wp_signon( $creds );
                    echo $user;
                    if ( is_wp_error($user) ) {
                      $tiny_error = $user->get_error_message();
                    } else {
                        wp_redirect($redirectt);
                        echo $redirectt;
                    }
                }
            } else {
                echo 'این شماره در سیستم ثبت نشده است.';
            }
        }else{
            echo 'شماره تلفن همراه یا پسورد وارد نشده است.';
        }
  ?>
    <form id="login-form" action="<?php //echo wp_login_url();?>" method="post">
        شماره همراه : <input type="text" name="mpmobile" />
        پسورد : <input id="login-password" type="password" name="pwd" />
        <input type="text" name="redirect" value="/wp-admin/">
        <input id="login-submit" type="submit" name="wp-submit" value="ورود" />
        <a id="membership" href="<?php echo wp_login_url();?>?action=register">عضویت</a> <a href="<?php echo wp_login_url();?>?action=lostpassword">رمز خود را فراموش کرده ام!</a>
      </form>
<?php
}

 

2

به اشتراک گذاری این پست


لینک به پست

برای ارسال نظر یک حساب کاربری ایجاد کنید یا وارد حساب خود شوید

برای اینکه بتوانید نظر ارسال کنید نیاز دارید که کاربر سایت شوید

ایجاد یک حساب کاربری

برای حساب کاربری جدید در انجمن ما ثبت نام کنید. عضویت خیلی ساده است !


ثبت نام یک حساب کاربری جدید

ورود به حساب کاربری

دارای حساب کاربری هستید؟ از اینجا وارد شوید


ورود به حساب کاربری

  • مطالب مشابه

    • توسط arash1224
      سلام به همه من میخواستم سامانه ای رو درست کنم که اطلاعاتی رو از کاربر می گیره و در جدولی در سایت نمایش میده و مدیر سایت فقط دو قسمت آخر جدول یعنی قسمت وضعیت و قسمت پیغام رو خودش قرار بده و البته تو قسمت پیغام hover که شد پیغام نمایش داده شود
      عکسش رو میفرستم ممنون میشم کمک کنید برای پروژه میخوام هر چه زودتر ممنون

    • توسط webdeveloper98
      سلام
      دوستان خوشحال می شم نظرتون رو درباره امنیت اطلاعات و امنیت وردپرس بدونم
      چقدر به بحث امنیت وردپرس و سایت های وردپرسی پرداخته می شه ؟
      چقدر به نظرتون اهمیت داره ؟
      اصلا بابت امنیت سایت های وردپرسی باید هزینه ای کرد یا خیر؟
      راه هایی که برای امنیت وردپرس و کلا سایت ها و سرورها که انجام میشه رو در چه حد و سطحی می دونید و می بینید ؟
       
      این سوالات ذهنم رو درگیر کرده و تمایل داشتم درموردشون جوابایی رو بشنوم
      ممنونم
    • توسط soshiant
      سلام 
      کد زیر یک دایو مربوط به بخش دسته های سایت من است
      <div class="post-page"> کدهای مربوطه </div> به دنبال یه تکه کد هستم که به اول این کد اضافه کنم تا محتوای این کد فقط در دسته های با آی‌دی مثلا 1 و 2 و 5 نمایش داده بشه و تو بقیه دسته ها این کد بی اثر باشه
      ممنون میشم کمک کنید
      تشکر
    • توسط ariux
      سلام دوستان ، من با استفاده از این مقاله اقدام به تعبیه ورود و ثبت نام در سایتم کردم ، اما با مشکلی رو به رو شدم .
      مشکل در واقع این هستش که فرم به خوبی کار میکنه و کاربر ورود ؛ و یا ثبت نام رو انجام میده اما صفحه به صورت اتوماتیک ری لود / ری فرش نمیشه تا اطلاعات کاربر لاگین شده رو نمایش بده .
      البته بعد از ری فرش صفحه توسط بروزر اطلاعات کاربر نمایش داده میشه اما مشکل همینجاست که ری لود باید اتوماتیک انجام بشه و نه توسط کاربر . 
      مورد عجیب اما این هستش که تمام مواردی که عرض کردم روی سایت آنلاین بروز پیدا میکنه و روی نسخه لوکال که توسط wamp ایجاد شده ، تمام موارد بدون کوچکترین مشکلی کار میکنند و جواب میدهند .
      این کدهایی هستش که بنده کمی شخصی سازیشون کردم اینجا قرار میدم ، امیدوارم دوستی بتونه کمک بکنه 
       
      function auth_user_login($user_login, $password, $login) { $info = array(); $info['user_login'] = $user_login; $info['user_password'] = $password; $info['remember'] = (isset( $_POST['rememberme'] ) && true == $_POST['rememberme'] ? true : false); $userdata = get_user_by('login', $info['user_login']); $result = wp_check_password($info['user_password'], $userdata->data->user_pass, $userdata->data->ID); if ( $result ) { auto_login( $userdata ); echo json_encode(array('loggedin'=>true, 'message'=>__('ورود موفقیت امیز بود ، در حال بارگذاری'))); } else { echo json_encode(array('loggedin'=>false, 'message'=>__(' اطلاعات وارد شده نادرست می باشد! '))); } die(); } function auto_login( $user ) { if ( !is_user_logged_in() ) { $user_id = $user->data->ID; $user_login = $user->data->user_login; wp_set_current_user( $user_id, $user_login ); wp_set_auth_cookie( $user_id ); } }  
      jQuery(document).ready(function ($) { // Display form from link inside a popup $('#pop_login, #pop_signup').on('click', function (e) { formToFadeOut = $('form#register'); formtoFadeIn = $('form#login'); if ($(this).attr('id') == 'pop_signup') { formToFadeOut = $('form#login'); formtoFadeIn = $('form#register'); } formToFadeOut.fadeOut(100, function () { formtoFadeIn.fadeIn(); }) return false; }); // Display lost password form $('#pop_forgot').click(function(){ formToFadeOut = $('form#login'); formtoFadeIn = $('form#forgot_password'); formToFadeOut.fadeOut(100, function () { formtoFadeIn.fadeIn(); }) return false; }); // Close popup $(document).on('click', '.close-any, .close', function () { $('form#login, form#register, form#forgot_password').fadeOut(100, function () { $('.close-any').remove(); }); return false; }); // Show the login/signup popup on click $('#show_login, #show_signup').on('click', function (e) { $('[canvas]').prepend('<div class="close-any"></div>'); if ($(this).attr('id') == 'show_login') $('form#login').fadeIn(100); else $('form#register').fadeIn(100); e.preventDefault(); }); // Perform AJAX login/register on form submit $('form#login, form#register').on('submit', function (e) { if (!$(this).valid()) return false; $('p.status', this).show().text(auth_script_object.loadingmessage); action = 'ajaxlogin'; username = $('form#login #username').val(); firstName = ''; lastName = ''; rememberme = ''; email = ''; password = $('form#login #password').val(); security = $('form#login #security').val(); if ($(this).attr('id') == 'register') { action = 'ajaxregister'; username = $('#signonname').val(); firstName = $('#signonfirstname').val(); lastName = $('#signonlastname').val(); password = $('#signonpassword').val(); email = $('#email').val(); security = $('#signonsecurity').val(); } ctrl = $(this); $.ajax({ type: 'POST', dataType: 'json', url: auth_script_object.ajaxurl, data: { 'action': action, 'username': username, 'password': password, 'email': email, 'firstName': firstName, 'lastName': lastName, 'security': security }, success: function (data) { $('p.status', ctrl).text(data.message); if (data.loggedin == true) { document.location.href = auth_script_object.redirecturl; window.location.reload(true); } } }); e.preventDefault(); }); // Perform AJAX forget password on form submit $('form#forgot_password').on('submit', function (e) { if (!$(this).valid()) return false; $('p.status', this).show().text(auth_script_object.loadingmessage); ctrl = $(this); $.ajax({ type: 'POST', dataType: 'json', url: auth_script_object.ajaxurl, data: { 'action': 'ajaxforgotpassword', 'user_login': $('#user_login').val(), 'security': $('#forgotsecurity').val(), }, success: function (data) { $('p.status', ctrl).text(data.message); } }); e.preventDefault(); return false; }); // Client side form validation if ($("#register").length) $("#register").validate( { rules: { password2: { equalTo: '#signonpassword' } } } ); else if ($("#login").length) $("#login").validate(); if ($('#forgot_password').length) $('#forgot_password').validate(); });  
      ممنون از شما
    • توسط shayan.m
      سلام
      وقت بخیر
      دوستان عزیز مشاهده وب سایت میهن وردپرس کنید در قسمت فوتر وب سایت میهن وردپرس یک قسمت هست با نام اجتماعی باشیم می خواهم با توجه به تصویر زیر و اون سایت دقیق دقیق و مثل تصویر زیر انجام بدید من کد نویسی بلد نیستم یکی از دوستان لطفا بهم کدش بده و بگه کجا قرار بدم درست کند و بهم بده
      لطفا انجام بدید
      مرسی مرسی مرسی مرسی مرسی مرسی
      مشابه تصویر زیر: