OCT 1. 修复httplib连接异常获取数据导致程序退出问题

This commit is contained in:
黄昕 2023-08-24 09:47:01 +08:00
parent c2153fd024
commit 5f3f55fad4
3 changed files with 20 additions and 13 deletions

View File

@ -377,15 +377,18 @@ template<class T1, class T2> int PlatformProtolPostMessage(const TCHAR *pUrlPath
res = g_httpCtx->Post(pUrlPath, pJson, HTTP_JSON_CONTENT); res = g_httpCtx->Post(pUrlPath, pJson, HTTP_JSON_CONTENT);
} }
} }
SPDLOG_DEBUG(TEXT("+++++ Http Request {0}\n---- Http Response {1}"), pJson, res->body.c_str());
if (res.error() != httplib::Error::Success) { if (res.error() != httplib::Error::Success) {
SPDLOG_ERROR(TEXT("[{0}]:Post Data {1} error: {2}"), pUrlPath, pJson, httplib::to_string(res.error())); SPDLOG_ERROR(TEXT("[{0}]:Post Data {1} error: {2}"), pUrlPath, pJson, httplib::to_string(res.error()));
if(res.error() != httplib::Error::Connection) {
SPDLOG_DEBUG(TEXT("+++++ Http Request {0}\n---- Http Response {1}"), pJson, res->body.c_str());
}
free(pJson); free(pJson);
return -ERR_HTTP_POST_DATA; return -ERR_HTTP_POST_DATA;
} }
SPDLOG_DEBUG(TEXT("+++++ Http Request {0}\n---- Http Response {1}"), pJson, res->body.c_str());
if (res->status != 200) { if (res->status != 200) {
SPDLOG_ERROR(TEXT("[{0}]:Post Data {1} server return HTTP error: {2}"), pUrlPath, pJson, res->status); SPDLOG_ERROR(TEXT("[{0}]:Post Data {1} server return HTTP error: {2}"), pUrlPath, pJson, res->status);
free(pJson); free(pJson);

View File

@ -50,17 +50,22 @@ static spdlog::level::level_enum logLevelToSpdlogLevel(LOG_LEVEL level) {
static void InitTunnelSDKLog(const TCHAR *pLogFile, LOG_LEVEL level) { static void InitTunnelSDKLog(const TCHAR *pLogFile, LOG_LEVEL level) {
TCHAR buf[MAX_PATH] = {0}; TCHAR buf[MAX_PATH] = {0};
TCHAR tmpPath[MAX_PATH];
if (pLogFile && strlen(pLogFile) > 0 && !PathIsRelative(pLogFile)) { if (pLogFile && strlen(pLogFile) > 0) {
TCHAR tmpPath[MAX_PATH]; if (PathIsRelative(buf)) {
StringCbCopy(tmpPath, MAX_PATH, pLogFile); StringCbPrintf(buf, MAX_PATH, TEXT("%s\\%s"), g_globalConfig.workDirectory, pLogFile);
PathRemoveFileSpec(tmpPath); } else {
MakeSureDirectoryPathExists(tmpPath); StringCbCopy(buf, MAX_PATH, pLogFile);
StringCbCopy(buf, MAX_PATH, pLogFile); }
} else { } else {
StringCbPrintf(buf, MAX_PATH, TEXT("%s\\tunnelsdklog.log"), g_globalConfig.workDirectory); StringCbPrintf(buf, MAX_PATH, TEXT("%s\\tunnelsdklog.log"), g_globalConfig.workDirectory);
} }
StringCbCopy(tmpPath, MAX_PATH, buf);
PathRemoveFileSpec(tmpPath);
MakeSureDirectoryPathExists(tmpPath);
g_globalConfig.enableLog = TRUE; g_globalConfig.enableLog = TRUE;
g_globalConfig.logLevel = logLevelToSpdlogLevel(level); g_globalConfig.logLevel = logLevelToSpdlogLevel(level);
@ -144,7 +149,7 @@ int TunnelSDKInitEnv(const TCHAR *pWorkDir,
StringCbCat(g_globalConfig.configDirectory, MAX_PATH, "\\NetTunnel"); StringCbCat(g_globalConfig.configDirectory, MAX_PATH, "\\NetTunnel");
SPDLOG_DEBUG(TEXT("Configure directory: {0}."), g_globalConfig.configDirectory); SPDLOG_DEBUG(TEXT("Configure directory: {0}."), g_globalConfig.configDirectory);
SPDLOG_DEBUG(TEXT("Platform Server: {}, Work Module: {}"), pSvrUrl, isWorkServer? TEXT("SERVER") : TEXT("Client")); SPDLOG_DEBUG(TEXT("Platform Server: {}, Work Module: {}"), pSvrUrl, isWorkServer ? TEXT("SERVER") : TEXT("Client"));
// 如果配置目录不存在则自动创建 // 如果配置目录不存在则自动创建
if (!PathFileExists(g_globalConfig.configDirectory)) { if (!PathFileExists(g_globalConfig.configDirectory)) {
@ -173,7 +178,7 @@ int TunnelSDKInitEnv(const TCHAR *pWorkDir,
return -ERR_ITEM_UNEXISTS; return -ERR_ITEM_UNEXISTS;
} }
#endif #endif
return ERR_SUCCESS; return ERR_SUCCESS;
} }

View File

@ -19,8 +19,7 @@ TEST_MODULE_INITIALIZE(ModuleInitialize) {
Assert::AreEqual(0, Assert::AreEqual(0,
TunnelSDKInitEnv(path, TunnelSDKInitEnv(path,
"http://172.21.40.194:32549", "http://172.21.40.194:32549",
TEXT("C:\\Users\\HuangXin\\Documents\\development\\visual_studio\\tunnel_" TEXT("./test/utest.log"),
"windows\\NetTunnelApp\\bin\\Debug\\utest.log"),
LOG_TRACE, LOG_TRACE,
false)); false));
//Assert::AreEqual(0, EnableVerifySignature(TEXT("123"), TEXT("123456"))); //Assert::AreEqual(0, EnableVerifySignature(TEXT("123"), TEXT("123456")));