11.08.2013, 15:11
|
Интересующийся
|
|
Регистрация: 09.08.2013
Сообщений: 18
|
|
Сообщение от danik.js
|
Ruslan_xDD, логин из четырех пробелов спокойно пройдет проверку
|
Проверка на символы у меня есть, только латиница, цифры и нижний дефис. Вот только не пойму как в
action="<?php $template->the_action_url( 'register' ); ?>"
из строки
<form name="registerform" id="registerform<?php $template->the_instance(); ?>" action="<?php $template->the_action_url( 'register' ); ?>" method="post">
вставить
action="reg.php"
ну или хотя бы где в готовом коде прописать
if(strlen($_POST['user_login']) < 4) exit('Слишком короткий логин!');
|
|
11.08.2013, 15:18
|
|
Профессор
|
|
Регистрация: 11.09.2010
Сообщений: 8,804
|
|
Сообщение от liringea
|
ну или хотя бы где в готовом коде прописать
|
На пятой строчке - не ошибёшся инфа 146%
|
|
11.08.2013, 15:33
|
Интересующийся
|
|
Регистрация: 09.08.2013
Сообщений: 18
|
|
Сообщение от danik.js
|
На пятой строчке - не ошибёшся инфа 146%
|
Вписываю свойство action прямо в input форму
<input type="text" name="user_login" id="user_login<?php $template->the_instance(); ?>" class="input" value="<?php $template->the_posted_value( 'user_login' ); ?>" action="<?php if(strlen($_POST['user_login']) < 4) exit('Слишком короткий логин!'); ?>" size="20" />
ничего не работает, объясни пожалуйста куда там надо её вписать. А то инфа может и 146%, но я не пойму как ей воспользоваться.
|
|
11.08.2013, 15:56
|
|
Профессор
|
|
Регистрация: 30.04.2012
Сообщений: 3,018
|
|
liringea, зачем php скрипт проверки логина вставлять в action?
Вставляйте скрипт туда, куда отсылается запрос.
if(!preg_match('/^[a-z0-9_-]{4,15}$/i', $_POST['login'])) exit('Неверно заполнено поле «Логин»');
|
|
11.08.2013, 16:51
|
Интересующийся
|
|
Регистрация: 09.08.2013
Сообщений: 18
|
|
Сообщение от Ruslan_xDD
|
liringea, зачем php скрипт проверки логина вставлять в action?
Вставляйте скрипт туда, куда отсылается запрос.
if(!preg_match('/^[a-z0-9_-]{4,15}$/i', $_POST['login'])) exit('Неверно заполнено поле «Логин»');
|
В файле wp-login.php всё это проверяет строка
$key = preg_replace('/[^a-z0-9]/i', '', $key);
я пробую её поменять на
$key = preg_replace('/^[a-z0-9_-]{4,15}$/i', '', $key);
но ничего не работает
наешл здесь тему http://mywordpress.ru/support/viewtopic.php?id=19746 , человек пытается добавить кирилические символы в имена пользователей, ему советуют в functions.php добавить код
function allow_cyrillic_usernames($username, $raw_username, $strict) {
$username = wp_strip_all_tags( $raw_username );
$username = remove_accents( $username );
$username = preg_replace( '|%([a-fA-F0-9][a-fA-F0-9])|', '', $username );
$username = preg_replace( '/&.+?;/', '', $username );
if ( $strict )
$username = preg_replace( '|[^a-zа-я0-9 _.\-@]|iu', '', $username );
$username = trim( $username );
$username = preg_replace( '|\s+|', ' ', $username );
return $username;
}
add_filter('sanitize_user', 'allow_cyrillic_usernames', 10, 3);
как нибудь этот код можно переделать под мои нужды?
|
|
11.08.2013, 16:56
|
|
Профессор
|
|
Регистрация: 30.04.2012
Сообщений: 3,018
|
|
Сообщение от liringea
|
я пробую её поменять на
|
Вот так попробуйте поменять:
if(!preg_match('/^[a-z0-9_-]{4,15}$/i', $key)) exit('Неверно заполнено поле «Логин»');
$key = preg_replace('/[^a-z0-9]/i', '', $key);
|
|
11.08.2013, 18:56
|
Интересующийся
|
|
Регистрация: 09.08.2013
Сообщений: 18
|
|
Сообщение от Ruslan_xDD
|
Вот так попробуйте поменять:
if(!preg_match('/^[a-z0-9_-]{4,15}$/i', $key)) exit('Неверно заполнено поле «Логин»');
$key = preg_replace('/[^a-z0-9]/i', '', $key);
|
Сильно извиняюсь, я не те строки нашел, я нашел строки от восстановления пароля. Вот строки функции создания аккауна
/**
* Handles registering a new user.
*
* @param string $user_login User's username for logging in
* @param string $user_email User's email address to send password and add
* @return int|WP_Error Either user's ID or error on failure.
*/
function register_new_user( $user_login, $user_email ) {
$errors = new WP_Error();
$sanitized_user_login = sanitize_user( $user_login );
$user_email = apply_filters( 'user_registration_email', $user_email );
// Check the username
if ( $sanitized_user_login == '' ) {
$errors->add( 'empty_username', __( '<strong>ERROR</strong>: Please enter a username.' ) );
} elseif ( ! validate_username( $user_login ) ) {
$errors->add( 'invalid_username', __( '<strong>ERROR</strong>: This username is invalid because it uses illegal characters. Please enter a valid username.' ) );
$sanitized_user_login = '';
} elseif ( username_exists( $sanitized_user_login ) ) {
$errors->add( 'username_exists', __( '<strong>ERROR</strong>: This username is already registered. Please choose another one.' ) );
}
// Check the e-mail address
if ( $user_email == '' ) {
$errors->add( 'empty_email', __( '<strong>ERROR</strong>: Please type your e-mail address.' ) );
} elseif ( ! is_email( $user_email ) ) {
$errors->add( 'invalid_email', __( '<strong>ERROR</strong>: The email address isn’t correct.' ) );
$user_email = '';
} elseif ( email_exists( $user_email ) ) {
$errors->add( 'email_exists', __( '<strong>ERROR</strong>: This email is already registered, please choose another one.' ) );
}
do_action( 'register_post', $sanitized_user_login, $user_email, $errors );
$errors = apply_filters( 'registration_errors', $errors, $sanitized_user_login, $user_email );
if ( $errors->get_error_code() )
return $errors;
$user_pass = wp_generate_password( 12, false);
$user_id = wp_create_user( $sanitized_user_login, $user_pass, $user_email );
if ( ! $user_id ) {
$errors->add( 'registerfail', sprintf( __( '<strong>ERROR</strong>: Couldn’t register you… please contact the <a href="mailto:%s">webmaster</a> !' ), get_option( 'admin_email' ) ) );
return $errors;
}
update_user_option( $user_id, 'default_password_nag', true, true ); //Set up the Password change nag.
wp_new_user_notification( $user_id, $user_pass );
return $user_id;
}
я так понимаю нужно строку
if(!preg_match('/^[a-z0-9_-]{4,15}$/i', $key)) exit('Неверно заполнено поле «Логин»');
применить не к $key а к $sanitized_user_login ?
Последний раз редактировалось liringea, 11.08.2013 в 19:08.
|
|
11.08.2013, 19:21
|
|
Профессор
|
|
Регистрация: 30.04.2012
Сообщений: 3,018
|
|
liringea, да.
|
|
|
|