2014-02-15 2 views
2

У меня есть SOAP-сервер для обработки соединений из веб-коннектора QuickBooks. Первый метод вызывается в «подлинности», который правильно возвращает данные, которые он ожидает, однако это дает мне ошибкуПроблема аутентификации с использованием веб-коннектора QuickBooks: ссылка на объект не установлена ​​в экземпляр объекта

QBWC1012: Authentication failed due to following error message. 
Object reference not set to an instance of an object. 

Я в недоумении на этом, и не кажется, что будет решение по паутина. Сообщение об ошибке на самом деле не дает мне ничего для продолжения.

Если у кого есть идеи, где я могу найти дополнительную информацию об этом, я был бы вам признателен.

Вот журнал ошибок WC для выпуска:

20140215.17:15:32 UTC : QBWebConnector.RegistryManager.setUpdateLock() : HKEY_CURRENT_USER\Software\Intuit\QBWebConnector\UpdateLock has been set to False 
20140215.17:15:32 UTC : QBWebConnector.RegistryManager.setUpdateLock() : ********************* Update session unlocked ********************* 
20140215.17:15:32 UTC : QBWebConnector.WebServiceManager.DoUpdate() : Update completed with errors. See log (QWClog.txt) for details. 
20140215.17:15:32 UTC : UpdateThisScheduledApp() : QBWC1031: Update completed with some error. Application has been notified of the error accordingly. See QWCLog for further information. 
20140215.17:16:30 UTC : UpdateThisScheduledApp() : Password management - Started 
20140215.17:16:30 UTC : UpdateThisScheduledApp() : Password management - Ended 
20140215.17:16:30 UTC : UpdateThisScheduledApp() : Performing SCHEDULED UPDATE for application = PManager SOAP 
20140215.17:16:30 UTC : QBWebConnector.RegistryManager.getUpdateLock() : HKEY_CURRENT_USER\Software\Intuit\QBWebConnector\UpdateLock = FALSE 
20140215.17:16:30 UTC : QBWebConnector.RegistryManager.setUpdateLock() : HKEY_CURRENT_USER\Software\Intuit\QBWebConnector\UpdateLock has been set to True 
20140215.17:16:30 UTC : QBWebConnector.RegistryManager.setUpdateLock() : ********************* Update session locked ********************* 
20140215.17:16:30 UTC : QBWebConnector.SOAPWebService.instantiateWebService() : Initiated connection to the following application. 
20140215.17:16:30 UTC : QBWebConnector.SOAPWebService.instantiateWebService() : AppName: PManager SOAP 
20140215.17:16:30 UTC : QBWebConnector.SOAPWebService.instantiateWebService() : AppUniqueName (if available): PManager SOAP 
20140215.17:16:30 UTC : QBWebConnector.SOAPWebService.instantiateWebService() : AppURL: https://[SNIP]/pmanager/soapserver.php 
20140215.17:16:30 UTC : QBWebConnector.SOAPWebService.do_serverVersion() : *** Calling serverVersion(). 
20140215.17:16:31 UTC : QBWebConnector.SOAPWebService.do_serverVersion() : Received from serverVersion() following parameter:<serverVersionRet=""> 
20140215.17:16:31 UTC : QBWebConnector.SOAPWebService.do_serverVersion() : This application sent a null for server version. Allowing update operation. 
20140215.17:16:31 UTC : QBWebConnector.SOAPWebService.do_clientVersion() : *** Calling clientVersion() with following parameter:<productVersion="2.1.0.30"> 
20140215.17:16:32 UTC : QBWebConnector.SOAPWebService.do_clientVersion() : Received from clientVersion() following parameter:<clientVersionRet=""> 
20140215.17:16:32 UTC : QBWebConnector.SOAPWebService.do_clientVersion() : This application agrees with the current version of QBWebConnector. Allowing update operation. 
20140215.17:16:32 UTC : QBWebConnector.SOAPWebService.do_authenticate() : Authenticating to application 'PManager SOAP', username = '[SNIP]' 
20140215.17:16:32 UTC : QBWebConnector.SOAPWebService.do_authenticate() : *** Calling authenticate() with following parameters:<userName="[SNIP]"><password=<MaskedForSecurity> 
20140215.17:16:33 UTC : QBWebConnector.SOAPWebService.do_authenticate() : QBWC1012: Authentication failed due to following error message. 
Object reference not set to an instance of an object. 
More info: 
StackTrace = at QBWebConnector.WebService.do_authenticate(String& ticket, String& companyFileName) 
Source = QBWebConnector 
20140215.17:16:33 UTC : QBWebConnector.RegistryManager.setUpdateLock() : HKEY_CURRENT_USER\Software\Intuit\QBWebConnector\UpdateLock has been set to False 
20140215.17:16:33 UTC : QBWebConnector.RegistryManager.setUpdateLock() : ********************* Update session unlocked ********************* 
20140215.17:16:33 UTC : QBWebConnector.WebServiceManager.DoUpdate() : Update completed with errors. See log (QWClog.txt) for details. 
20140215.17:16:33 UTC : UpdateThisScheduledApp() : QBWC1031: Update completed with some error. Application has been notified of the error accordingly. See QWCLog for further information. 
ответ

SOAP отправляется в туалет:

<?xml version="1.0" encoding="ISO-8859-1"?> 
<SOAP-ENV:Envelope SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/"> 
<SOAP-ENV:Body> 
<ns1:authenticateResponse xmlns:ns1="http://developer.intuit.com/"> 
    <return xsi:type="SOAP-ENC:Array" SOAP-ENC:arrayType="xsd:string[2]"> 
     <item xsi:type="xsd:string">8d51474324d94e25aa1e6670da584204</item> 
     <item xsi:type="xsd:string">C:/Path/File.QBW</item> 
    </return> 
</ns1:authenticateResponse> 
</SOAP-ENV:Body> 
</SOAP-ENV:Envelope> 
+0

Можете ли вы разместить свой код? Или ответ SOAP, который вы возвращаете? –

+0

Добавлено в OP выше – Ian

ответ

0

Я должен был обновить это раньше ... Проблема оказалась номером версии, я пытался использовать более старую версию, которая не поддерживала некоторые функции. Изменение версии в вызове в WC решило ее.

+0

какой версия номер? Какой призыв к WC? –

0

Вероятно, немного поздно, но в случае, если это поможет кому-то, у меня было аналогичная проблема и изменение стиля от «RPC» до «DocWrapped» в файле QWC исправили проблему.

UPDATE 5/2017:

вопрос Ор был связан с несоответствием номер версии, но у меня были те же симптомы, где проблема была связана с несоответствием стиля в БОВ конфигурации. Согласно QBWC_proguide, правильная версия будет зависеть от настройки сервера, но действительные параметры включают в себя: «Документ» (который по умолчанию), «DocWrapped» и «RPC».

Для моей настройки Rails работал либо «Документ», либо «DocWrapped».

После изменения этой конфигурации удалите и повторно добавьте приложение веб-коннектора.

+2

Это больше похоже на комментарий, чем на ответ ... Можете ли вы расширить это немного? – apaul

Смежные вопросы