Холст base64 POST строка повреждена - PullRequest
0 голосов
/ 25 августа 2018

У меня проблема с отправкой изображения, содержащегося на холсте. Я использовал метод canvas.toDataURL () для создания строки base64, а затем разместил изображение с помощью ajax. Когда я печатаю полученную строку в консоли, у меня всегда есть проводная строка, которая всегда заканчивается одинаково (AKACgAoAKACgAoAKACgAoAKACgAoAKACgAoAKACgAoAK ..). Понятно, что позже, когда я пытаюсь декодировать строку, результатом всегда будет искаженное изображение JPEG.

Вот пример строки, которую я получаю с холста:

$ 

JS

const player = document.getElementById('player');
const canvas = document.getElementById('canvas');
const context = canvas.getContext('2d');
const captureButton = document.getElementById('capture');
const constraints = {video: true,};

captureButton.addEventListener('click', () => {
   context.drawImage(player, 0, 0, canvas.width,canvas.height);

// Stop all video streams.
player.srcObject.getVideoTracks().forEach(track =>      track.stop());
  document.getElementById('picture').style.display='block';});

navigator.mediaDevices.getUserMedia(constraints).then((stream) => {
// Attach the video stream to the video element and autoplay.
              player.srcObject = stream;
            });
var dataURL = canvas.toDataURL("image/jpeg",1 );

function sendPhoto()
            {
               $.ajax({
                      type: "POST",
                      url: "{{ url_for('photobooth.album') }}",
                      data:{
                        imageBase64: dataURL
                      }
                    }).done(function() {
                    console.log('sent');
                });

            }

Python

image_b64 = request.values['imageBase64']
imgdata = base64.b64decode(image_b64[image_b64.find(','):])

filename = fileName()+'.jpg'
with open(os.path.join(app.root_path, app.config['UPLOAD_FOLDER'], filename), 'wb') as f:
            f.write(imgdata)

Что я делаю не так?

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