From 8abf0f2409a17db90edf05ef1889fab898035543 Mon Sep 17 00:00:00 2001 From: wincsb Date: Mon, 7 Nov 2022 14:19:34 +0800 Subject: [PATCH] Fixed the HTTP client crash when compiling with SSL and the unusable HTTP client when compiling without SSL --- util/src/tc_http.cpp | 39 ++++++++++++++++++++++----------------- 1 file changed, 22 insertions(+), 17 deletions(-) diff --git a/util/src/tc_http.cpp b/util/src/tc_http.cpp index 55418739..28a7b959 100755 --- a/util/src/tc_http.cpp +++ b/util/src/tc_http.cpp @@ -1,4 +1,4 @@ -#include "util/tc_http.h" +#include "util/tc_http.h" #include "util/tc_port.h" #include "util/tc_common.h" #include "util/tc_clientsocket.h" @@ -2258,36 +2258,41 @@ int TC_HttpRequest::doRequest(const string &sSendBuffer, TC_TCPClient &tcpClient iRet = tcpClient.recv(recvBuffer->free(), iRecvLen); - if (iRet != TC_ClientSocket::EM_SUCCESS) - { - return iRet; - } -#if TARS_SSL - iRet = ssl->read(recvBuffer->free(), iRecvLen, in); - if (iRet != 0) + if (iRet == TC_ClientSocket::EM_SUCCESS) { - return iRet; - } + if(this->_httpURL._iURLType == TC_URL::HTTPS) + { +#if TARS_SSL + iRet = ssl->read(recvBuffer->free(), iRecvLen, in); + if (iRet != 0) + { + return iRet; + } - rbuf = ssl->recvBuffer(); + rbuf = ssl->recvBuffer(); #else - if (iRet == TC_ClientSocket::EM_SUCCESS) - { - recvBuffer->addWriteIdx(iRecvLen); - } + return TC_ClientSocket::EM_HTTPS; #endif + } + else + { + recvBuffer->addWriteIdx(iRecvLen); + + } + } + switch (iRet) { case TC_ClientSocket::EM_SUCCESS: - if (stHttpRsp.incrementDecode(*rbuf)) + if (stHttpRsp.incrementDecode(*rbuf->getBuffer())) { return TC_ClientSocket::EM_SUCCESS; } continue; case TC_ClientSocket::EM_CLOSE: - stHttpRsp.incrementDecode(*rbuf); + stHttpRsp.incrementDecode(*rbuf->getBuffer()); return TC_ClientSocket::EM_SUCCESS; default: return iRet;