POCO C++ - NET SSL - 如何发布 HTTPS 请求
如何正确地对 HTTPS 服务器进行 POST 并正确嵌入登录数据.下面的代码不返回任何 cookie(在 Wininet 中是这样).我想知道 POCO HTTP 库如何处理 HTTP 重定向?
How to correctly do a POST to HTTPS server and embed the login data correctly. Below code does not return any cookies (in Wininet it does). I wonder how POCO HTTP library handles HTTP redirections?
MyApp()
{
try
{
const Poco::URI uri( "https://localhost.com" );
const Poco::Net::Context::Ptr context( new Poco::Net::Context( Poco::Net::Context::CLIENT_USE, "", "", "rootcert.pem" ) );
Poco::Net::HTTPSClientSession session(uri.getHost(), uri.getPort(), context );
Poco::Net::HTTPRequest req(Poco::Net::HTTPRequest::HTTP_POST, "/login.php" );
req.setContentType("Content-Type: application/x-www-form-urlencoded
");
req.setKeepAlive(true);
std::string reqBody("username=???&password=???&action_login=Log+In
");
req.setContentLength( reqBody.length() );
//Poco::Net::HTTPBasicCredentials cred("???", "???");
//cred.authenticate(req);
session.sendRequest(req) << reqBody;
Poco::Net::HTTPResponse res;
std::istream& rs = session.receiveResponse(res);
std::string resp;
std::vector<Poco::Net::HTTPCookie> cookies;
res.getCookies( cookies );
}
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;;
}
};
推荐答案
您正在像这样设置内容类型:
You are setting content type like this:
req.setContentType("Content-Type: application/x-www-form-urlencoded
");
应该是:
req.setContentType("application/x-www-form-urlencoded
");
相关文章