fix bug(fxxk microsoft)

This commit is contained in:
simplxs 2024-07-02 19:28:03 +08:00
parent d120834ac1
commit 52d2fa4851
No known key found for this signature in database
GPG Key ID: 1A3833A46D84A08C
5 changed files with 108 additions and 120 deletions

View File

@ -2,27 +2,28 @@
#include "../include/rapidjson/document.h" #include "../include/rapidjson/document.h"
#include <filesystem>
#include <fstream> #include <fstream>
#include <iostream> #include <iostream>
Server *server = nullptr;
void init() void init()
{ {
try
{
#if defined(_WIN_PLATFORM_) #if defined(_WIN_PLATFORM_)
std::string version = "9.9.12-25300"; std::string version = "9.9.12-25300";
try try
{ {
std::ifstream versionConfig("resources\\app\\versions\\config.json"); TCHAR pathm[MAX_PATH];
GetModuleFileName(NULL, pathm, MAX_PATH);
std::filesystem::path path = pathm;
path = path.parent_path().append("resources\\app\\versions\\config.json");
std::ifstream versionConfig(path.wstring());
if (versionConfig.is_open()) if (versionConfig.is_open())
{ {
std::string versionConfigStr; std::stringstream versionConfigStream;
versionConfig >> versionConfigStr; versionConfigStream << versionConfig.rdbuf();
versionConfig.close(); versionConfig.close();
rapidjson::Document doc; rapidjson::Document doc;
doc.Parse(versionConfigStr.c_str(), versionConfigStr.size()); doc.Parse(versionConfigStream.str().c_str(), versionConfigStream.str().size());
if (doc.HasMember("curVersion") && doc["curVersion"].IsString()) if (doc.HasMember("curVersion") && doc["curVersion"].IsString())
version = doc["curVersion"].GetString(); version = doc["curVersion"].GetString();
} }
@ -40,11 +41,11 @@ void init()
std::ifstream versionConfig("/opt/QQ/resources/app/package.json"); std::ifstream versionConfig("/opt/QQ/resources/app/package.json");
if (versionConfig.is_open()) if (versionConfig.is_open())
{ {
std::string versionConfigStr; std::stringstream versionConfigStrBuf;
versionConfig >> versionConfigStr; versionConfigStrBuf << versionConfig.rdbuf();
versionConfig.close(); versionConfig.close();
rapidjson::Document doc; rapidjson::Document doc;
doc.Parse(versionConfigStr.c_str(), versionConfigStr.size()); doc.Parse(versionConfigStrBuf.str().c_str(), versionConfigStrBuf.str().c_str());
if (doc.HasMember("version") && doc["version"].IsString()) if (doc.HasMember("version") && doc["version"].IsString())
version = doc["version"].GetString(); version = doc["version"].GetString();
} }
@ -70,12 +71,12 @@ void init()
} }
else else
{ {
std::string config; std::stringstream configStream;
configFile >> config; configStream << configFile.rdbuf();
configFile.close(); configFile.close();
try try
{ {
doc.Parse(config.c_str(), config.size()); doc.Parse(configStream.str().c_str(), configStream.str().size());
} }
catch (const std::exception &e) catch (const std::exception &e)
{ {
@ -91,21 +92,21 @@ void init()
if (doc.HasMember("version") && doc["version"].IsString()) if (doc.HasMember("version") && doc["version"].IsString())
version = doc["version"].GetString(); version = doc["version"].GetString();
printf("Start Init server\n"); std::thread sign_init([version, ip, port]
server = new Server(); {
server->Init();
printf("Start Init sign\n"); printf("Start Init sign\n");
std::thread([=] { // Cannot use '&' capture!!!!! will cause crash
for (int i = 0; i < 10; i++) for (int i = 0; i < 10; i++)
{ {
try try
{ {
if (Sign::Init(version)) if (Sign::Init(version))
{ {
if (!server->Run(ip, port)) printf("Start Init server\n");
Server server;
server.Init();
if (!server.Run(ip, port))
printf("Server run failed\n"); printf("Server run failed\n");
break; return;
} }
} }
catch (const std::exception &e) catch (const std::exception &e)
@ -113,23 +114,12 @@ void init()
printf("Init failed: %s\n", e.what()); printf("Init failed: %s\n", e.what());
} }
std::this_thread::sleep_for(std::chrono::seconds(1)); std::this_thread::sleep_for(std::chrono::seconds(1));
} } });
}) sign_init.detach();
.detach();
}
catch (const std::exception &e)
{
printf("Init failed: %s\n", e.what());
}
} }
void uninit() void uninit()
{ {
if (server != nullptr)
{
delete server;
server = nullptr;
}
} }
#if defined(_WIN_PLATFORM_) #if defined(_WIN_PLATFORM_)
@ -156,7 +146,7 @@ void __attribute__((constructor)) my_init(void)
init(); init();
} }
void __attribute__ ((destructor)) my_fini(void) void __attribute__((destructor)) my_fini(void)
{ {
uninit(); uninit();
} }

View File

@ -21,7 +21,6 @@ std::shared_ptr<void> (*nodeInitializeOncePerProcess)(
int __stdcall fakeWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd) int __stdcall fakeWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd)
{ {
MessageBoxA(NULL, "Init", "fakeWinMain", MB_OK);
checkRunAsNode(nullptr); checkRunAsNode(nullptr);
return oriWinMain(hInstance, hPrevInstance, lpCmdLine, nShowCmd); return oriWinMain(hInstance, hPrevInstance, lpCmdLine, nShowCmd);
} }
@ -43,11 +42,7 @@ bool RunAsNode::RunNode()
[](auto &a) [](auto &a)
{ return std::wstring_convert<std::codecvt_utf8<wchar_t>>().to_bytes(a); }); { return std::wstring_convert<std::codecvt_utf8<wchar_t>>().to_bytes(a); });
MessageBoxA(NULL, "pre nodeInitializeOncePerProcess", "fakeWinMain", MB_OK);
std::for_each(argv.begin(), argv.end(), [](const std::string &arg)
{ MessageBoxA(NULL, arg.c_str(), "fakeWinMain", MB_OK); });
nodeInitializeOncePerProcess(argv, (1 << 6) | (1 << 7)); nodeInitializeOncePerProcess(argv, (1 << 6) | (1 << 7));
MessageBoxA(NULL, "post nodeInitializeOncePerProcess", "fakeWinMain", MB_OK);
return true; return true;
} }

View File

@ -2,8 +2,6 @@
#include "../include/rapidjson/document.h" #include "../include/rapidjson/document.h"
#include "../include/rapidjson/writer.h" #include "../include/rapidjson/writer.h"
#include <thread>
std::string Server::GetSign(const std::string_view &cmd, const std::string_view &src, const int seq) std::string Server::GetSign(const std::string_view &cmd, const std::string_view &src, const int seq)
{ {
auto [signDataHex, extraDataHex, tokenDataHex] = Sign::Call(cmd, src, seq); auto [signDataHex, extraDataHex, tokenDataHex] = Sign::Call(cmd, src, seq);

View File

@ -1,4 +1,5 @@
#pragma once #pragma once
#define _DISABLE_CONSTEXPR_MUTEX_CONSTRUCTOR
#include "sign.h" #include "sign.h"
#include "../include/cpp-httplib/httplib.h" #include "../include/cpp-httplib/httplib.h"

View File

@ -5,6 +5,9 @@ for /f "tokens=2*" %%a in ('reg query "HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\M
set "RetString=%%b" set "RetString=%%b"
goto :boot goto :boot
) )
echo QQ installation not found
pause
exit
:boot :boot
for %%a in ("!RetString!") do ( for %%a in ("!RetString!") do (
@ -36,7 +39,8 @@ if errorlevel 1 (
goto launch goto launch
:restart :restart
powershell Start-Process -FilePath cmd.exe -ArgumentList """/c pushd %~dp0 && %~s0 %*""" -Verb RunAs powershell Start-Process -FilePath cmd.exe -ArgumentList """/c pushd %~dp0 && %~s0 %*""" -Verb RunAs
exit
:launch :launch
set "QQPath=!pathWithoutUninstall!QQ.exe" set "QQPath=!pathWithoutUninstall!QQ.exe"