<html>
    <head>
      <base href="https://bugs.webkit.org/" />
    </head>
    <body><table border="1" cellspacing="0" cellpadding="8">
        <tr>
          <th>Bug ID</th>
          <td><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - Unable to post data in Safari 10 with a XHR POST request"
   href="https://bugs.webkit.org/show_bug.cgi?id=165081">165081</a>
          </td>
        </tr>

        <tr>
          <th>Summary</th>
          <td>Unable to post data in Safari 10 with a XHR POST request
          </td>
        </tr>

        <tr>
          <th>Classification</th>
          <td>Unclassified
          </td>
        </tr>

        <tr>
          <th>Product</th>
          <td>WebKit
          </td>
        </tr>

        <tr>
          <th>Version</th>
          <td>Safari 10
          </td>
        </tr>

        <tr>
          <th>Hardware</th>
          <td>iPhone / iPad
          </td>
        </tr>

        <tr>
          <th>OS</th>
          <td>iOS 10
          </td>
        </tr>

        <tr>
          <th>Status</th>
          <td>NEW
          </td>
        </tr>

        <tr>
          <th>Severity</th>
          <td>Normal
          </td>
        </tr>

        <tr>
          <th>Priority</th>
          <td>P2
          </td>
        </tr>

        <tr>
          <th>Component</th>
          <td>New Bugs
          </td>
        </tr>

        <tr>
          <th>Assignee</th>
          <td>webkit-unassigned&#64;lists.webkit.org
          </td>
        </tr>

        <tr>
          <th>Reporter</th>
          <td>bede.bignell&#64;fronde.com
          </td>
        </tr></table>
      <p>
        <div>
        <pre>Uploading an image (from a dataUrl format) using an XHR request appears to fail on iOS (10.0.2+), other browsers are working: the latest Chrome (54.0.2840.71), Firefox (50.0).

The request seems to be constructed correctly in JS, but there is no actual data attached to the request.

var dataUrl = &quot;

// create base64 encoded version of image
let parts = dataUrl.split(',');
let mime = parts[0].match(/:(.*?);/)[1];
let bstr = atob(parts[1]);
let n = bstr.length;
let u8arr = new Uint8Array(n);
  while (n--) {
  u8arr[n] = bstr.charCodeAt(n);
}
let blob = new window.Blob([u8arr], {type: mime});
file = new window.File([blob], file.name);

// create formdata for uploading
let data = new FormData();
data.append('file', file, file.name);


// send the post request
var xhr = new XMLHttpRequest;
xhr.onload = function (oEvent) {
  // Uploaded.
  if ( oEvent.target.status == '200') {
    console.log('upload with XHR success');
  } else {
    console.log('upload with XHR error');
  }
};
xhr.open(&quot;POST&quot;, '/upload-endpoint', false);
xhr.send(data);</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>