У меня есть приложение Rails, которое использует Devise для аутентификации пользователя.Я разрабатываю надстройку и с помощью ajax отправляю сообщение в свой маршрут входа, отправляя параметры имени пользователя и пароля (user [email] и user [password]).
Я пытаюсь отправить сообщение на маршрут xml (users / sign_in.xml), чтобы получить ответ XML.Сервер Rails работает нормально и создает сеанс.
Я выполняю это из ajax, и он возвращает успех.После этого, если я пытаюсь выполнить другой сервис, требующий аутентификации, он возвращает ошибку, которая говорит о том, что я не вошел в систему. Возможно, мне придется сохранить куки или отправить куки в следующих вызовах на сервер Rails.* Из скрипта контента я звоню:
function signInSubmit(){
var email = $('#sign_in_email').val();
var password = $('#sign_in_password').val();
signIn(email, password);
}
function signIn(email, password){
var sign_in_data = {
'user[email]' : email,
"user[password]" : password
}
var params = EncodeQueryData(sign_in_data);
invoke("/users/sign_in", params, signInCallBack);
}
function invoke(url_method, parameters, callback){
var url = url_api + url_method + ".xml?" + parameters;
var req = new XMLHttpRequest();
type = 'POST';
req.open("POST", url, true);
req.overrideMimeType('text/xml');
req.onreadystatechange = function () {
if (req.readyState == 4) {
if (req.status == 200) {
callback(req.responseXML);
}else if(req.status == 201){
callback(req.responseXML);
}
}
};
req.send();
}
function signInCallBack(doc){
//This returns an XML saying that authentication was successfull.
// Session was created in the server
login_session_key = doc.getElementsByTagName("email")[0].childNodes[0].nodeValue
callMethodThatNeedsAuthentication();
}
function callMethodThatNeedsAuthentication(){
// This method call returns a not authenticated error.
invoke("/api/methodthatneedsauthentication", "", NeedsAuthenticationCallBack);
}
Как вы думаете?