Недавно я задал другой (связанный) вопрос, который приводит к следующему вопросу: отправка данных вместо файла для формы ввода
Читая документацию jQuery.ajax () ( http://api.jquery.com/jQuery.ajax/ ), кажется, что список принятых типов данных не включает изображения.
Я пытаюсь получить изображение с помощью jQuery.get (или jQuery.ajax, если нужно), сохранить это изображение в Blob и загрузить его на другой сервер в запросе POST. В настоящее время похоже, что из-за несоответствия в типах данных мои изображения оказываются поврежденными (несоответствие размера в байтах и т. Д.).
Код для этого выглядит следующим образом (он написан на coffeescript, но его несложно разобрать):
handler = (data,status) ->
fd = new FormData
fd.append("file", new Blob([data], { "type" : "image/png" }))
jQuery.ajax {
url: target_url,
data: fd,
processData: false,
contentType: "multipart/form-data",
type: "POST",
complete: (xhr,status) ->
console.log xhr.status
console.log xhr.statusCode
console.log xhr.responseText
}
jQuery.get(image_source_url, null, handler)
Как я могу вместо этого получить это изображение в виде капли?
javascript
jquery
Джабалсад
источник
источник
Ответы:
Вы не можете сделать это с помощью jQuery ajax, но с собственным XMLHttpRequest.
var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function(){ if (this.readyState == 4 && this.status == 200){ //this.response is what you're looking for handler(this.response); console.log(this.response, typeof this.response); var img = document.getElementById('img'); var url = window.URL || window.webkitURL; img.src = url.createObjectURL(this.response); } } xhr.open('GET', 'http://jsfiddle.net/img/logo.png'); xhr.responseType = 'blob'; xhr.send();
РЕДАКТИРОВАТЬ
Итак, возвращаясь к этой теме, кажется, что это действительно возможно сделать с помощью jQuery 3.
jQuery.ajax({ url:'https://images.unsplash.com/photo-1465101108990-e5eac17cf76d?ixlib=rb-0.3.5&q=85&fm=jpg&crop=entropy&cs=srgb&ixid=eyJhcHBfaWQiOjE0NTg5fQ%3D%3D&s=471ae675a6140db97fea32b55781479e', cache:false, xhr:function(){// Seems like the only way to get access to the xhr object var xhr = new XMLHttpRequest(); xhr.responseType= 'blob' return xhr; }, success: function(data){ var img = document.getElementById('img'); var url = window.URL || window.webkitURL; img.src = url.createObjectURL(data); }, error:function(){ } });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script> <img id="img" width=100%>
или же
используйте xhrFields, чтобы установить responseType
jQuery.ajax({ url:'https://images.unsplash.com/photo-1465101108990-e5eac17cf76d?ixlib=rb-0.3.5&q=85&fm=jpg&crop=entropy&cs=srgb&ixid=eyJhcHBfaWQiOjE0NTg5fQ%3D%3D&s=471ae675a6140db97fea32b55781479e', cache:false, xhrFields:{ responseType: 'blob' }, success: function(data){ var img = document.getElementById('img'); var url = window.URL || window.webkitURL; img.src = url.createObjectURL(data); }, error:function(){ } });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js"></script> <img id="img" width=100%>
источник
How can I retrieve this image as a blob instead?
, в любом случае, это просто демонстрация,handler
возьметthis.response
и добавит его в объект formdata и отправит через ajax.Если вам нужно обрабатывать сообщения об ошибках с помощью jQuery.AJAX, вам нужно будет изменить
xhr
функцию, чтобыresponseType
она не изменялась при возникновении ошибки.Таким образом, вам придется изменить значение
responseType
на " blob " только в том случае, если это успешный вызов:$.ajax({ ... xhr: function() { var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState == 2) { if (xhr.status == 200) { xhr.responseType = "blob"; } else { xhr.responseType = "text"; } } }; return xhr; }, ... error: function(xhr, textStatus, errorThrown) { // Here you are able now to access to the property "responseText" // as you have the type set to "text" instead of "blob". console.error(xhr.responseText); }, success: function(data) { console.log(data); // Here is "blob" type } });
Запись
Если вы отлаживаете и помещаете точку останова сразу после установки значения
xhr.responseType
« blob », вы можете заметить, что если вы попытаетесь получить значение для,responseText
вы получите следующее сообщение:источник
.done()
методе, и если что-то пошло не так, ответ в.fail()
методе должен обрабатываться как «текст», потому что в противном случае онresponseText
был пустым и т. Д. решение отлично сработало для меня!Большое спасибо @Musa, и вот отличная функция, которая преобразует данные в строку base64. Это может пригодиться вам при обработке файла двоичного файла (pdf, png, jpeg, docx, ...) в WebView, который получает двоичный файл, но вам необходимо безопасно передать данные файла в ваше приложение.
// runs a get/post on url with post variables, where: // url ... your url // post ... {'key1':'value1', 'key2':'value2', ...} // set to null if you need a GET instead of POST req // done ... function(t) called when request returns function getFile(url, post, done) { var postEnc, method; if (post == null) { postEnc = ''; method = 'GET'; } else { method = 'POST'; postEnc = new FormData(); for(var i in post) postEnc.append(i, post[i]); } var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { var res = this.response; var reader = new window.FileReader(); reader.readAsDataURL(res); reader.onloadend = function() { done(reader.result.split('base64,')[1]); } } } xhr.open(method, url); xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); xhr.send('fname=Henry&lname=Ford'); xhr.responseType = 'blob'; xhr.send(postEnc); }
источник