网站源码-图片-资料下载-学习资料-牛资料网!只做精品资料网
  • 首 页
  • wordpress开发教程:优化用户注册体验(自定义密码)
    时间:2017-04-11 16:54 来源:www.xyhndec.com 编辑:免费资料 浏览:
    今天有位小伙伴在群中询问wordpress新用户注册显示密码的问题,由于wordpress默认的是不让用户自己去填写密码的,而是系统自动给用户生成一个密码并且发送到用户邮箱,相对来说可能有些用户会不习惯,今天小V就来教大家优化wordpress的用户注册体验,让用户自己设置账户密码,其实很简单只需要在主题的function.php加上以下代码:
     
    <?php
    add_action( 'register_form', 'v7v3_show_register' );
    function v7v3_show_register(){
    ?>
        <p>
            <label for="password">密码:<br/>
            <input id="password" class="input" type="password" tabindex="30" size="25" value="" name="password" />
            </label>
        </p>
        <p>
            <label for="repeat_password">确认密码<br/>
            <input id="repeat_password" class="input" type="password" tabindex="40" size="25" value="" name="repeat_password" />
            </label>
        </p>
        <p>
            <label for="are_you_human" style="font-size:11px">挖掘机技术哪家强?(蓝翔)<br/>
            <input id="are_you_human" class="input" type="text" tabindex="40" size="25" value="" name="are_you_human" />
            </label>
        </p>
    <?php
    }
    add_action( 'register_post', 'ts_check_extra_register_fields', 10, 3 );
    function ts_check_extra_register_fields($login, $email, $errors) {
        if ( $_POST['password'] !== $_POST['repeat_password'] ) {
            $errors->add( 'passwords_not_matched', "<strong>ERROR</strong>: 两次密码不一致" );
        }
        if ( strlen( $_POST['password'] ) < 8 ) {
            $errors->add( 'password_too_short', "<strong>ERROR</strong>: 密码长度小于8位!" );
        }
        if ( $_POST['are_you_human'] !== '蓝翔' ) {
            $errors->add( 'not_human', "<strong>ERROR</strong>: 回答错误,请重新填写注册信息!" );
        }
    }
     
    为了保证不被注册机骚扰此代码中还自带了一个验证问题字段,防止注册机批量注册垃圾用户。虽然让用户可以自己填写密码,但是有些用户更加喜欢让系统为他生成密码,为了给这些用户提供方便,我们可以判断下当前用户注册时是否填了密码,如果没填再让系统生成一个,代码如下:
    add_action( 'user_register', 'v7v3_register_extra_pass', 100 );
    function v7v3_register_extra_pass( $user_id ){
        $userdata = array();
        
        $userdata['ID'] = $user_id;
        if ( $_POST['password'] !== '' ) {
            $userdata['user_pass'] = $_POST['password'];
        }
        $new_user_id = wp_update_user( $userdata );
    }
     
    当然为了给用户更好的体验,我们可以在注册框下方加个提示,代码如下:
    add_filter( 'gettext', 'v7v3_edit_text' );
    function v7v3_edit_text( $text ) {
        if ( $text == 'A password will be e-mailed to you.' ) {
            $text = '如果您不填写密码,系统将为您生成一个密码, 并发送至您的邮箱。';
        }
        return $text;

    郑重声明:
    牛资料网所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,不存在任何商业目的与商业用途。 若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
    我们不承担任何技术及版权问题,且不对任何资源负法律责任。
    如无法下载,联系牛资料网索要。
    如有侵犯您的版权,请及时联系QQ:964613048,我们尽快处理。

    wordpress主题调用内置自带jquery库的代码方法wordpress主题调用内置自带jquery库的
    适用于阿里云ACE的WordPress Rewrite规则适用于阿里云ACE的WordPress Rewrite规
    wordpress开发教程:优化用户注册体验(自定义密码)wordpress开发教程:优化用户注册体验
    推荐栏目
    • 客服:我们竭诚为您服务!
    • 客服:我们竭诚为您服务!