Próbuję napisać aplikację klienta w C++ przy użyciu bibliotek Poco (wersja poco-1.4.6p1-all) i kompilować w Visual Studio 2010, która wysyła żądanie HTTPS do serwera, który ma własny certyfikat. Mam błąd, ponieważ certyfikat nie jest rozpoznawane:Żądanie HTTPS w języku C++ przy użyciu Poco
First-chance exception at 0x76e8c41f in httprequest.exe: Microsoft C++ exception: Poco::Net::SSLException at memory location 0x0044ed38..
Próbowałem zmieniając zweryfikować funkcje napisane w bibliotece (w X509Certificate.h) tak, że zawsze zwraca wartość true i przebudował bibliotekę. Ten sam błąd.
Oto kod:
try{
const Poco::URI uri("https://www.theServer.com");
Poco::Net::Context::Ptr context =
new Poco::Net::Context(Poco::Net::Context::CLIENT_USE, "",
"","",Poco::Net::Context::VERIFY_RELAXED,
9, true, "ALL:!ADH:!LOW:!EXP:!MD5:@STRENGTH");
Poco::SharedPtr<Poco::Net::InvalidCertificateHandler> pAcceptCertHandler = new Poco::Net::AcceptCertificateHandler(true);
Poco::Net::SSLManager::instance().initializeClient(NULL, pAcceptCertHandler, context);
Poco::Net::HTTPSClientSession session(uri.getHost(), uri.getPort(), context);
Poco::Net::HTTPRequest req(Poco::Net::HTTPRequest::HTTP_GET, "");
req.setContentType("application/x-javascript; charset=utf-8\r\n");
req.setKeepAlive(true);
Poco::Net::HTTPBasicCredentials cred("[email protected]", "lala");
cred.authenticate(req);
session.sendRequest(req);
Poco::Net::HTTPResponse res;
std::istream& rs = session.receiveResponse(res);
std::string resp;
std::vector<Poco::Net::HTTPCookie> cookies;
res.getCookies(cookies);
res.write(std::cout);
}
catch(const Poco::Net::SSLException& e)
{
std::cerr << e.what() << ": " << e.message() << std::endl;
}
catch(const std::exception& e)
{
std::cerr << e.what() << std::endl;;
}
Dziękujemy!
Zdałem sobie sprawę, że ten wyjątek jest generowany niezależnie od serwera, z którym próbuję się połączyć. Czy może to wynikać z nieprawidłowej instalacji OpenSSL? – CJJ
Znalazłem odpowiedź. Problem polegał na tym, że nie dostałem certyfikatu. Działa to tak: – CJJ