Загрузите файл в Autodesk Forge с помощью .NET - PullRequest
0 голосов
/ 22 ноября 2018

Я не уверен, как загружать объекты внутри корзины.Файл, который я в настоящее время могу загрузить, имеет значительно меньший размер по сравнению с файлом, загруженным в корзину.Кроме того, я не могу открыть файл после его загрузки.Чего-то не хватает в моем коде?Следующий код - это то, что я использовал для загрузки файлов.

var element = document.createElement('a');

element.setAttribute('href', '#');
element.setAttribute('download', node.text);
element.style.display = 'none';

document.body.appendChild(element);
element.click();
document.body.removeChild(element);

1 Ответ

0 голосов
/ 23 ноября 2018

Вы ссылаетесь на мой ответ здесь ( Загрузите файл документов BIM360 с использованием Javascript ) для загрузки файлов из корзины Forge OSS.

В этом предложении я расширил функцию jQuery, чтобы создать новый XMLHttpRequest ипередает все полученные данные обратно в jQuery.

/**
 *
 * jquery.binarytransport.js
 *
 * @description. jQuery ajax transport for making binary data type requests.
 * @version 1.0 
 * @author Henry Algus <henryalgus@gmail.com>
 *
 */
// use this transport for "binary" data type
$.ajaxTransport("+binary", function(options, originalOptions, jqXHR) {
    // check for conditions and support for blob / arraybuffer response type
    if (window.FormData && ((options.dataType && (options.dataType == 'binary')) || (options.data && ((window.ArrayBuffer && options.data instanceof ArrayBuffer) || (window.Blob && options.data instanceof Blob))))) {
        return {
            // create new XMLHttpRequest
            send: function(headers, callback) {
                // setup all variables
                var xhr = new XMLHttpRequest(),
                    url = options.url,
                    type = options.type,
                    async = options.async || true,
                    // blob or arraybuffer. Default is blob
                    dataType = options.responseType || "blob",
                    data = options.data || null,
                    username = options.username || null,
                    password = options.password || null;

                xhr.addEventListener('load', function() {
                    var data = {};
                    data[options.dataType] = xhr.response;
                    // make callback and send data
                    callback(xhr.status, xhr.statusText, data, xhr.getAllResponseHeaders());
                });

                xhr.open(type, url, async, username, password);

                // setup custom headers
                for (var i in headers) {
                    xhr.setRequestHeader(i, headers[i]);
                }

                xhr.responseType = dataType;
                xhr.send(data);
            },
            abort: function() {
                jqXHR.abort();
            }
        };
    }
}); 

После этого вы можете просто заменить значения filename, bucketKey и YOUR_ACCESS_TOKEN на свои, чтобы напрямую загружать файлы с веб-сайта. Однако, это может быть очень небезопасно, см. Комментарий здесь

$(function() {

  $('a#download').click(function(event) {
    event.preventDefault();

    const filename = 'hose.rvt';
    const bucketKey = 'adn-test';

    const settings = {
      crossDomain: true,
      url: 'https://developer.api.autodesk.com/oss/v2/buckets/' + bucketKey + ' /objects/' + filename,
      method: 'GET',
      dataType: 'binary',
      processData: false,
      headers: {
        Authorization: 'Bearer YOUR_ACCESS_TOKEN',
        Content-Type: 'application/octet-stream'
      }
    };

    $.ajax(settings).done(function (blob, textStatus, jqXHR) {
        console.log(blob );
        console.log(textStatus);

      if( navigator.msSaveBlob )
        return navigator.msSaveBlob(blob, filename);

      const url = URL.createObjectURL(blob);
      const a = document.createElement('a');
      a.style = 'display: none';
      document.body.appendChild(a);

      a.href = url;
      a.download = filename;
      a.click();
      URL.revokeObjectURL(url);
    });
  });
}) 
...