Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/amazon-s3/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
在具有SuiteScript 2.0的NetSuite中,无法发送包含内容类型为multipart/form data的HTTP POST请求的文件_Post_Https_Multipartform Data_Netsuite_Suitescript2.0 - Fatal编程技术网

在具有SuiteScript 2.0的NetSuite中,无法发送包含内容类型为multipart/form data的HTTP POST请求的文件

在具有SuiteScript 2.0的NetSuite中,无法发送包含内容类型为multipart/form data的HTTP POST请求的文件,post,https,multipartform-data,netsuite,suitescript2.0,Post,Https,Multipartform Data,Netsuite,Suitescript2.0,我无法将我的“多部分/表单数据”文件发送到此API。如果我使用POSTMAN,它可以工作,但使用https post方法,netsuite似乎无法识别“表单数据”内容类型。有人知道如何使用SuiteScript 2发送表单数据?以下是我代码的一部分: var fileObj = file.create({ name: invoiceNumber + '_ubl.xml', fileType: file.Type.XMLDOC,

我无法将我的“多部分/表单数据”文件发送到此API。如果我使用POSTMAN,它可以工作,但使用https post方法,netsuite似乎无法识别“表单数据”内容类型。有人知道如何使用SuiteScript 2发送表单数据?以下是我代码的一部分:

var fileObj = file.create({
                name: invoiceNumber + '_ubl.xml',
                fileType: file.Type.XMLDOC,
                contents: einvoicecontentwithpdf,
                folder : 120,
                isOnline : false
            });

var headers = {
                    'Authorization': 'Basic xxxxxxxxxxxxxxxxxxxxx',
                    'Content-Type':  'multipart/form-data'
            };

            var response = https.post({
                url: 'https://community-api-uat-1-2.nxt.uat.unifiedpost.com/api/universal_connector/v1/uc/ar',
                body: {
                    'file': fileObj                    
                },
                headers: headers 
            }); 

你必须自己塑造整个身体

这和我到目前为止测试的一样有效。代码可能看起来有点非idomatic,因为它是从Typescript编译的

请注意,要包含非文本文件,必须对其进行调整,以对文件体进行base64编码

/**
 * multiPartUpload.js
 * @NApiVersion 2.x
 */
define(["require", "exports", "N/https", "N/file", "N/log"], function (require, exports, http, file, log) {
    Object.defineProperty(exports, "__esModule", { value: true });
    var types = {};
    types[file.Type.AUTOCAD] = 'application/x-autocad';
    types[file.Type.BMPIMAGE] = 'image/x-xbitmap';
    types[file.Type.CSV] = 'text/csv';
    types[file.Type.EXCEL] = 'application/vnd.ms-excel';
    types[file.Type.FLASH] = 'application/x-shockwave-flash';
    types[file.Type.GIFIMAGE] = 'image/gif';
    types[file.Type.GZIP] = 'application/?x-?gzip-?compressed';
    types[file.Type.HTMLDOC] = 'text/html';
    types[file.Type.ICON] = 'image/ico';
    types[file.Type.JAVASCRIPT] = 'text/javascript';
    types[file.Type.JPGIMAGE] = 'image/jpeg';
    types[file.Type.JSON] = 'application/json';
    types[file.Type.MESSAGERFC] = 'message/rfc822';
    types[file.Type.MP3] = 'audio/mpeg';
    types[file.Type.MPEGMOVIE] = 'video/mpeg';
    types[file.Type.MSPROJECT] = 'application/vnd.ms-project';
    types[file.Type.PDF] = 'application/pdf';
    types[file.Type.PJPGIMAGE] = 'image/pjpeg';
    types[file.Type.PLAINTEXT] = 'text/plain';
    types[file.Type.PNGIMAGE] = 'image/x-png';
    types[file.Type.POSTSCRIPT] = 'application/postscript';
    types[file.Type.POWERPOINT] = 'application/?vnd.?ms-?powerpoint';
    types[file.Type.QUICKTIME] = 'video/quicktime';
    types[file.Type.RTF] = 'application/rtf';
    types[file.Type.SMS] = 'application/sms';
    types[file.Type.STYLESHEET] = 'text/css';
    types[file.Type.TIFFIMAGE] = 'image/tiff';
    types[file.Type.VISIO] = 'application/vnd.visio';
    types[file.Type.WORD] = 'application/msword';
    types[file.Type.XMLDOC] = 'text/xml';
    types[file.Type.ZIP] = 'application/zip';
    function getContentType(f) {
        var mime = types[f.fileType];
        var charset = f.encoding;
        var ct = 'Content-Type: ' + mime + (charset ? ';charset=' + charset : '');
        log.debug({ title: 'content for ' + f.name, details: ct });
        return ct;
    }
    function isFile(o) {
        return (typeof o == 'object' && typeof o.fileType != 'undefined');
    }
    /**
     * Creates a multipart upload
     * @param {string} url     to post to
     * @param {object} headers key/value of headers; include Auth headers if needed
     * @param {array} parts   array of {name:string, value:file|string}
     */
    function uploadParts(url, headers, parts) {
        var boundary = 'someuniqueboundaryasciistring';
        headers['content-type'] = 'multipart/form-data; boundary=' + boundary;
        // Body
        var body = [];
        parts.forEach(function (p, idx) {
            var partIsFile = isFile(p.value);
            body.push('--' + boundary);
            body.push('Content-Disposition: form-data; name="' + p.name + '"' + (partIsFile ? ('; filename="' + p.value.name + '"') : ''));
            if (partIsFile) { 
                var ct = getContentType(p.value);
                body.push(getContentType(p.value));
                if(partIsBinary(ct)){
                    body.push('Content-Transfer-Encoding: base64');
                }
            }
            body.push('');
            body.push(partIsFile ? p.value.getContents() : p.value);
            if (idx == parts.length - 1) {
                body.push('--' + boundary + '--');
                body.push('');
            }
        });
        // Submit Request
        try {
            var response = http.post({
                url: url,
                headers: headers,
                body: body.join('\r\n')
            });
            return response;
        }
        catch (e) {
            log.error({ title: 'Failed to submit file', details: (e.message || e.toString()) + (e.getStackTrace ? (' \n \n' + e.getStackTrace().join(' \n')) : '') });
        }
    }
    exports.uploadParts = uploadParts;
    ;
});
一个简单的测试:

/**
 *@NApiVersion 2.x
 *@NScriptType Suitelet
 */
define(["require", "exports", "N/file", "./multiPartUpload"], function (require, exports, file, multiPartUpload_1) {
    Object.defineProperty(exports, "__esModule", { value: true });
    function onRequest(context) {
        var files = [
            { name: 'f1', value: file.load({ id: 1056 }) }, // file cabinet ids; you can use dynamic files
            { name:'t1', value:'test'},
            { name: 'f2', value: file.load({ id: 7479 }) }
        ];
        var resp = multiPartUpload_1.uploadParts('https://your-test-server/', {}, files);
        context.response.write({ output: resp.body });
    }
    exports.onRequest = onRequest;
});

很好。它正在工作,你很了不起:)但是NetSuite不允许我们这样做真是太疯狂了:-)但是是的,这些出站http限制已经让人恼火了好几年了。嗨@bknights,你为什么使用:Object.defineProperty(导出,“\u esModule”{value:true});@user4076248它是从Typescript编译而来的。Typescript在tsconfig.json声明AMD modules时会这样做。AMD是Netsuite支持的约定,没有填充。它似乎是良性的。I@user4076248如果您使用的是ecmascript,只需使用SS2.0脚本示例即可