Consommation web service en visual C++ (2005)
Bonjour,
J'ai besoin d'un petit coup de pouce : j'ai importé une référence web de notre ERP (Sage X3) dans mon logiciel sous VS2005. Jusque là pas de problèmes : les tests ont été concluants mais en production j'ai un phénomène que je n'arrive pas à élucider (1 à 2% des cas)
J'ai une fonction save (générée en auto) qui crée un enregistrement dans une base :
Code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
| template <typename TClient>
inline HRESULT CCAdxWebServiceXmlCCServiceT<TClient>::save(
CAdxCallContext callContext,
BSTR publicName,
BSTR objectXml,
CAdxResultXml* saveReturn
)
{
if ( saveReturn == NULL )
return E_POINTER;
HRESULT __atlsoap_hr = InitializeSOAP(NULL);
if (FAILED(__atlsoap_hr))
{
SetClientError(SOAPCLIENT_INITIALIZE_ERROR);
return __atlsoap_hr;
}
CleanupClient();
CComPtr<IStream> __atlsoap_spReadStream;
__CCAdxWebServiceXmlCCService_save_struct __params;
memset(&__params, 0x00, sizeof(__params));
__params.callContext = callContext;
__params.publicName = publicName;
__params.objectXml = objectXml;
__atlsoap_hr = SetClientStruct(&__params, 10);
if (FAILED(__atlsoap_hr))
{
SetClientError(SOAPCLIENT_OUTOFMEMORY);
goto __skip_cleanup;
}
__atlsoap_hr = GenerateResponse(GetWriteStream());
if (FAILED(__atlsoap_hr))
{
SetClientError(SOAPCLIENT_GENERATE_ERROR);
goto __skip_cleanup;
}
__atlsoap_hr = SendRequest(_T("SOAPAction: \"\"\r\n"));
if (FAILED(__atlsoap_hr))
{
goto __skip_cleanup;
}
__atlsoap_hr = GetReadStream(&__atlsoap_spReadStream);
if (FAILED(__atlsoap_hr))
{
SetClientError(SOAPCLIENT_READ_ERROR);
goto __skip_cleanup;
}
// cleanup any in/out-params and out-headers from previous calls
Cleanup();
__atlsoap_hr = BeginParse(__atlsoap_spReadStream);
if (FAILED(__atlsoap_hr))
{
SetClientError(SOAPCLIENT_PARSE_ERROR);
goto __cleanup;
}
*saveReturn = __params.saveReturn;
goto __skip_cleanup;
__cleanup:
Cleanup();
__skip_cleanup:
ResetClientState(true);
memset(&__params, 0x00, sizeof(__params));
return __atlsoap_hr;
} |
qui me renvoie une erreur alors que la création s'est bien passée!
Code:
1 2 3 4 5 6
|
hr = service.save(Context, CComBSTR(L"ZPALETTE").Detach(), requete, &result2);
if (FAILED(hr))
{
_com_error err(hr);
LPCTSTR errMsg = err.ErrorMessage(); |
errMsg : Erreur non spécifiée (0x80004005)
un message d'erreur comme on les aime... J'ai horodaté 2 messages : 1 avant l'appel et l'autre immédiatement après pour mettre en évidence un timeout mais la fonction s'exécute dans la seconde!
Avez-vous une piste pour que je puisse avancer?