當前位置: 首頁>>代碼示例>>PHP>>正文


PHP WP_User::get_error_message方法代碼示例

本文整理匯總了PHP中WP_User::get_error_message方法的典型用法代碼示例。如果您正苦於以下問題:PHP WP_User::get_error_message方法的具體用法?PHP WP_User::get_error_message怎麽用?PHP WP_User::get_error_message使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在WP_User的用法示例。


在下文中一共展示了WP_User::get_error_message方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: authenticate

 function authenticate($user, $username, $password)
 {
     // If previous authentication succeeded, respect that
     if (is_a($user, 'WP_User')) {
         return $user;
     }
     // Determine if user a local admin
     $local_admin = false;
     $user_obj = get_user_by('login', $username);
     if (user_can($user_obj, 'update_core')) {
         $local_admin = true;
     }
     if (empty($username) || empty($password)) {
         $error = new WP_Error();
         if (empty($username)) {
             $error->add('empty_username', __('<strong>ERROR</strong>: The username field is empty.'));
         }
         if (empty($password)) {
             $error->add('empty_password', __('<strong>ERROR</strong>: The password field is empty.'));
         }
         return $error;
     }
     // If high security mode is enabled, remove default WP authentication hook
     if (str_true($this->get_setting('high_security')) && !$local_admin) {
         remove_filter('authenticate', 'wp_authenticate_username_password', 20, 3);
     }
     // Sweet, let's try to authenticate our user and pass against LDAP
     $auth_result = $this->ldap_auth($username, $password, $this->get_setting('directory'));
     if ($auth_result) {
         // Authenticated, does user have required groups, if any?
         if ($this->user_has_groups($username, $this->get_setting('directory'))) {
             $user = get_user_by('login', $username);
             if (!$user || strtolower($user->user_login) !== strtolower($username)) {
                 if (!str_true($this->get_setting('create_users'))) {
                     do_action('wp_login_failed', $username);
                     return new WP_Error('invalid_username', __('<strong>Simple LDAP Login Error</strong>: LDAP credentials are correct, but there is no matching WordPress user and user creation is not enabled.'));
                 }
                 $new_user = wp_insert_user($this->get_user_data($username, $this->get_setting('directory')));
                 if (!is_wp_error($new_user)) {
                     // Successful Login
                     $new_user = new WP_User($new_user);
                     do_action_ref_array($this->prefix . 'auth_success', array($new_user));
                     return $new_user;
                 } else {
                     do_action('wp_login_failed', $username);
                     return new WP_Error("{$this->prefix}login_error", __('<strong>Simple LDAP Login Error</strong>: LDAP credentials are correct and user creation is allowed but an error occurred creating the user in WordPress. Actual error: ' . $new_user->get_error_message()));
                 }
             } else {
                 return new WP_User($user->ID);
             }
         } else {
             return new WP_Error("{$this->prefix}login_error", __('<strong>Simple LDAP Login Error</strong>: Your LDAP credentials are correct, but you are not in an authorized LDAP group.'));
         }
     } elseif (str_true($this->get_setting('high_security'))) {
         return new WP_Error('invalid_username', __('<strong>Simple LDAP Login</strong>: Simple LDAP Login could not authenticate your credentials. The security settings do not permit trying the WordPress user database as a fallback.'));
     }
     do_action($this->prefix . 'auth_failure');
     return false;
 }
開發者ID:zamentur,項目名稱:wordpress_ynh,代碼行數:59,代碼來源:Simple-LDAP-Login.php


注:本文中的WP_User::get_error_message方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。