Функция обратного вызова (успех?) Для AJAX - PullRequest
1 голос
/ 06 декабря 2011

Когда пользователь вводит свои данные на страницу регистрации и нажимает кнопку «отправить», вызывается usernameCheck().Теоретически, он должен отправить запрос AJAX на сервер, который проверяет, введено ли имя пользователя.Если это так, то пользователь предупрежден, и больше ничего не происходит.В противном случае он проверяет, что пароль действителен.В предыдущем вопросе мне сказали, что мне нужна функция обратного вызова, чтобы остановить отправку формы перед асинхронным возвратом AJAX.Вместо этого я помещаю форму отправки в success: часть запроса AJAX, поэтому он должен вызываться только в том случае, если имя пользователя уникально и пароль действителен.

Однако, похоже, никогдаперейти к этапу проверки пароля или отобразить любое предупреждение ...

function usernameCheck(){ //returns true if username is free
    var ajaxHeaders = {}; //create header object
    ajaxHeaders["X-CSRFToken"] = getCookie('csrftoken'); //add csrftoken from cookies for authentication server-side
    $.ajax({
        type:'POST',
        url:"http://omnicloud.me/signup", 
      data:{username: $("#username").val()}, 
      success:function(response){
        if(response=="true"){
           $('#passAlert').innerHTML("Sorry, that username is already taken") 
           //passalert is where all of the errors (username taken, invalid password) show up
        } else {
            if (passwordCheck()){
                $('#signup_form').submit();
            }
        }
        },
    headers: ajaxHeaders //settings for ajax request
    });

    return !($('#passAlert').value == "Sorry, that username is already taken")
}

function passwordCheck(){
    var pattern =  /[a-z,A-Z,0-9,$,#,@,!,&,%,+,_,-,?]{10,}/  //regexp for valid charachers
    var text = document.getElementById('password').value;
    var msg = document.getElementById('passAlert');
    if(text.length < 10){
        msg.innerHTML = "Passwords need to be at least 10 characters long :(";
        return false;
    } else if (!text.match(pattern)){
        msg.innerHTML = "You have entered an invalid digit (sorry)";
        return false;
    } else if (unacceptable(text)){
        msg.innerHTML = "You can be more creative than that...";
        return false;
    } else if(text != document.getElementById('pass_repeat').value){
        msg.innerHTML = "Your passwords do not match.";
        return false;
    }
    return true;
}

function unacceptable(pwd){ //joins the array, if it matches any one of them 
                                                        //(g means at any point, i means case insensitive) password rejected
    var re = new RegExp(unforgivable.join("|"),"gi");
    return (pwd.toString().match(re) != null);
}

Просмотр регистрации Django:

def signup(request):
if request.method == 'GET':
    return render_to_response('signup.html', context_instance=RequestContext(request))
elif request.is_ajax(): 
#query db for user with username provided via ajax, return if it exists
    try:    
        user = User.objects.get(username=request.POST.get("username")) 
    except User.DoesNotExist:
        return HttpResponse("false",context_instance=RequestContext(request))
    else:
        return HttpResponse("true", context_instance=RequestContext(request))

1 Ответ

1 голос
/ 06 декабря 2011

Тот факт, что вы упоминаете полное доменное имя;

http://omnicloud.me/signup

предлагаю мне позвонить на сервер из домена, отличного от того, где вы загружаете страницу, и что вы сталкиваетесь с междоменными ограничениями браузера. Кросс-домен возможен, но требует дополнительной настройки - попробуйте сначала заставить его работать, используя тот же Domian, что и при загрузке страницы,

т.е. использовать

   /signup

на том же сервере, вместо использования http://omni.....

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...