Chciałbym wyświetlić obraz jpeg w interfejsie użytkownika. W tym celu proszę o moją usługę (metoda GET), a potem przekształca się oprzeć 64:Angular JS - żądanie w celu uzyskania obrazu
$http({
url: "...",
method: "GET",
headers: {'Content-Type': 'image/jpeg'}
}).then(function(dataImage){
var binary = '';
var responseText = dataImage.data;
var responseTextLen = dataImage.data.length;
for (var j = 0; j < responseTextLen; j+=1) {
binary += String.fromCharCode(responseText.charCodeAt(j) & 0xff)
}
base64Image = 'data:image/jpeg;base64,' + window.btoa(binary);
});
W końcu moja przeglądarka informuje mnie, że obraz jest uszkodzony lub obcinane. Spróbowałem więc stworzenie XMLHttpRequest używając overrideMimeType ('text/plain; charset = x-user-defined') i to działa:
var xhr_object = new XMLHttpRequest();
xhr_object.overrideMimeType('text/plain; charset=x-user-defined');
xhr_object.open('GET', '...', false);
xhr_object.send(null);
if(xhr_object.status == 200){
var responseText = xhr_object.responseText;
var responseTextLen = responseText.length;
var binary = ''
for (var j = 0; j < responseTextLen; j+=1) {
binary += String.fromCharCode(responseText.charCodeAt(j) & 0xff)
}
base64Image = 'data:image/jpeg;base64,' + window.btoa(binary);
}
jaka jest różnica?
Nadal dostaję błąd "dane nie implementuje interfejs Blob", nawet z '{responseType:" blob "}'. – Yasammez
Co mówi inspektor przeglądarki? Czy są jakieś żądania sieciowe zablokowane przez klienta? – Daan
Ten w końcu rozwiązał mój problem. Nie musisz zajmować się zwykłymi starymi XHR i btoa() konwersją rzeczy. – Xinan