NetSuite API - 如何将追踪号码发回发票或销售订单?

时间:2013-08-15 15:58:46

标签: api updates shipping netsuite

我正在通过SOAP API将运输解决方案与NetSuite集成。我可以通过searchRecord调用检索shipAddress。现在我需要将跟踪号码,使用的服务和成本发回NetSuite。希望有人可以指出我正确的方向,因为搜索没有给我任何答案。一个示例XML会很棒。

2 个答案:

答案 0 :(得分:0)

我几乎粘贴了外部开发人员试图实现的响应,但我不知道如何设置信封以在记录中的NS内接收它...我认为这是什么处理更新帖子到Field:

'
             var a = new Array();
                                 a['Content-Type'] = 'text/xml; charset=utf-8';
                                 a['POST'] = '/FedexNSService/Service1.asmx HTTP/1.1';
                                 a['Content-Length'] = data.length;           
                                 a['SOAPAction'] = 'https://wsbeta.fedex.com:443/web-services/ship/ReturnFedexLable';
                                nlapiLogExecution('DEBUG', 'Results', 'data : ' + data);



            var response = nlapiRequestURL('http://sonatauat.adaaitsolutions.com/FedexNSService/Service1.asmx?op=ReturnFedexLable', data, a, null,null);
nlapiLogExecution('DEBUG', 'response', response);                
            var responseXML = nlapiStringToXML(response.getBody());
nlapiLogExecution('DEBUG', 'responseXML', responseXML);
                                 var responseCode = response.getCode();
nlapiLogExecution('DEBUG', 'responseCode', responseCode);
                                 var body = response.getBody();
nlapiLogExecution('DEBUG', 'body', body);                                
                                 nlapiLogExecution('DEBUG', 'responseXML '+responseXML, 'responseCode : ' + responseCode);
                                 nlapiLogExecution('DEBUG', 'body ', 'body : ' +body);
                        var imageurl ='';        
                    if(responseXML != null)
                    {

                            var rawfeeds = nlapiSelectNodes(responseXML, "//Tracking"); 
                            var FileInternalId = nlapiSelectValue(rawfeeds[0], "FileInternalId");
                            var TrackingIds = nlapiSelectValue(rawfeeds[1], "TrackingIds");
                            nlapiLogExecution('DEBUG', 'FileInternalId '+FileInternalId, 'TrackingIds : '+TrackingIds );    
                            if(FileInternalId)
                            {
                                var image=nlapiLoadFile(5985);
                                imageurl=image.getURL();
                                imageurl = ("https://system.netsuite.com"+imageurl);       
                                nlapiLogExecution('DEBUG','image',imageurl);
                            }

                    }
            return imageurl;
'

答案 1 :(得分:0)

要通过SOAP更新包含信息的销售订单,您需要创建销售订单对象,设置值并调用updateupsert方法:

[JAVA]

SalesOrder so = new SalesOrder();
so.setExternalId("externalID"); //This should correspond to the previous external ID for updates. 
...set_other_fields_as_required...
WriteResponse wr = ns.getPort().update(so);    //ns = _port if you're using the samples                 

[C#]

var so = new SalesOrder();
so.externalId = "externalID";
...set_other_fields_as_required...
var wr = Service.upsert(so); 

PHP应该是类似的,但我没有使用PHP工具包,所以我不能肯定地说。

这应该有助于您入门。