使用.NET在Autodesk Forge上下载文件

时间:2018-11-22 15:44:50

标签: javascript .net autodesk-forge autodesk-viewer

我不确定如何在存储桶中下载对象。与存储桶中上传的文件相比,我当前能够下载的文件的大小要小得多。另外,下载后,我无法打开文件。我的代码中缺少什么吗?以下代码是我用来下载文件的代码。

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 :(得分:0)

您可以在此处参考我的答案(Download BIM360 Docs file using 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();
            }
        };
    }
}); 

之后,您只需将filenamebucketKeyYOUR_ACCESS_TOKEN的值替换为您的值,即可直接在网站上下载文件。 但是,这可能非常不安全,请参阅评论here

$(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);
    });
  });
})