Загрузить изображение в Drupal 7 / Services 3 от Titanium?
Это должно быть близко, но я не могу понять, что является причиной ошибки.
В моем приложении Titanium у меня есть Webview с элементом canvas и этот код:
function getImageData() {
return canvas.toDataURL('image/png');
}
Я перемещаю эти данные в приложение Titanium следующим образом:
var imageBase64data = webview.evalJS('getImageData()')
Данные выглядят хорошо, начиная с "data:image/png;base64,"...
Затем в Titanium у меня есть сеанс drupal, в который я вошел, и я вызываю эту функцию:
function uploadImage(imageBase64data, callback) {
var url = REST_PATH + "file.json";
var file = {
filename: utils.createRandomString() + ".png",
file: imageBase64data
// uid: Titanium.App.Properties.getString("userUid"),
// filesize: ""+Titanium.Utils.base64decode(imageBase64data).length,
};
var xhr = Titanium.Network.createHTTPClient({timeout: 30000});
xhr.setRequestHeader("Content-Type", "application/json; charset=utf-8");
var authString = Titanium.App.Properties.getString("userSessionName")+'='+Titanium.App.Properties.getString("userSessionId");
xhr.setRequestHeader("Cookie", authString);
xhr.onload = function() {
if(xhr.status == 200) {
var response = xhr.responseText;
callback(response);
}
};
xhr.onerror = function(e) {
alert("There was an error: " + e.error);
Ti.API.info(JSON.stringify(this));
};
xhr.open("POST", url);
xhr.send(file);
}
Вызывается xhr.onerror с помощью e.error = "undefined"
След выглядит так:
{
"responseData":{},
"readyState":4,
"connected":true,"UNSENT":0,"DONE":4,"HEADERS_RECEIVED":2,"OPENED":1,"LOADING":3,
"responseText":null,"status":406
}
Я думаю, что аутентификация работает, потому что раньше я получал ошибку "нужна аутентификация", пока не добавил заголовок Cookie.
1 ответ
Решение
Это было с установкой, предоставленной Drupanium. Я только что сделал новую установку Drupal и свежие Services 3, и мой файл загружается хорошо.