HTTPSClientSession.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. //
  2. // HTTPSClientSession.h
  3. //
  4. // $Id: //poco/Main/NetSSL_OpenSSL/include/Poco/Net/HTTPSClientSession.h#9 $
  5. //
  6. // Library: NetSSL_OpenSSL
  7. // Package: HTTPSClient
  8. // Module: HTTPSClientSession
  9. //
  10. // Definition of the HTTPSClientSession class.
  11. //
  12. // Copyright (c) 2006-2009, Applied Informatics Software Engineering GmbH.
  13. // and Contributors.
  14. //
  15. // Permission is hereby granted, free of charge, to any person or organization
  16. // obtaining a copy of the software and accompanying documentation covered by
  17. // this license (the "Software") to use, reproduce, display, distribute,
  18. // execute, and transmit the Software, and to prepare derivative works of the
  19. // Software, and to permit third-parties to whom the Software is furnished to
  20. // do so, all subject to the following:
  21. //
  22. // The copyright notices in the Software and this entire statement, including
  23. // the above license grant, this restriction and the following disclaimer,
  24. // must be included in all copies of the Software, in whole or in part, and
  25. // all derivative works of the Software, unless such copies or derivative
  26. // works are solely in the form of machine-executable object code generated by
  27. // a source language processor.
  28. //
  29. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  30. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  31. // FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
  32. // SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
  33. // FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
  34. // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  35. // DEALINGS IN THE SOFTWARE.
  36. //
  37. #ifndef NetSSL_HTTPSClientSession_INCLUDED
  38. #define NetSSL_HTTPSClientSession_INCLUDED
  39. #include "Poco/Net/NetSSL.h"
  40. #include "Poco/Net/Utility.h"
  41. #include "Poco/Net/HTTPClientSession.h"
  42. #include "Poco/Net/Context.h"
  43. #include "Poco/Net/X509Certificate.h"
  44. namespace Poco {
  45. namespace Net {
  46. class SecureStreamSocket;
  47. class HTTPRequest;
  48. class HTTPResponse;
  49. class NetSSL_API HTTPSClientSession: public HTTPClientSession
  50. /// This class implements the client-side of
  51. /// a HTTPS session.
  52. ///
  53. /// To send a HTTPS request to a HTTPS server, first
  54. /// instantiate a HTTPSClientSession object and
  55. /// specify the server's host name and port number.
  56. ///
  57. /// Then create a HTTPRequest object, fill it accordingly,
  58. /// and pass it as argument to the sendRequst() method.
  59. ///
  60. /// sendRequest() will return an output stream that can
  61. /// be used to send the request body, if there is any.
  62. ///
  63. /// After you are done sending the request body, create
  64. /// a HTTPResponse object and pass it to receiveResponse().
  65. ///
  66. /// This will return an input stream that can be used to
  67. /// read the response body.
  68. ///
  69. /// See RFC 2616 <http://www.faqs.org/rfcs/rfc2616.html> for more
  70. /// information about the HTTP protocol.
  71. ///
  72. /// Note that sending requests that neither contain a content length
  73. /// field in the header nor are using chunked transfer encoding will
  74. /// result in a SSL protocol violation, as the framework shuts down
  75. /// the socket after sending the message body. No orderly SSL shutdown
  76. /// will be performed in this case.
  77. {
  78. public:
  79. enum
  80. {
  81. HTTPS_PORT = 443
  82. };
  83. HTTPSClientSession();
  84. /// Creates an unconnected HTTPSClientSession.
  85. explicit HTTPSClientSession(const SecureStreamSocket& socket);
  86. /// Creates a HTTPSClientSession using the given socket.
  87. /// The socket must not be connected. The session
  88. /// takes ownership of the socket.
  89. HTTPSClientSession(const std::string& host, Poco::UInt16 port = HTTPS_PORT);
  90. /// Creates a HTTPSClientSession using the given host and port.
  91. explicit HTTPSClientSession(Context::Ptr pContext);
  92. /// Creates an unconnected HTTPSClientSession, using the
  93. /// give SSL context.
  94. HTTPSClientSession(const std::string& host, Poco::UInt16 port, Context::Ptr pContext);
  95. /// Creates a HTTPSClientSession using the given host and port,
  96. /// using the given SSL context.
  97. ~HTTPSClientSession();
  98. /// Destroys the HTTPSClientSession and closes
  99. /// the underlying socket.
  100. X509Certificate serverCertificate();
  101. /// Returns the server's certificate.
  102. ///
  103. /// The certificate is available after the first request has been sent.
  104. protected:
  105. void connect(const SocketAddress& address);
  106. std::string proxyRequestPrefix() const;
  107. private:
  108. HTTPSClientSession(const HTTPSClientSession&);
  109. HTTPSClientSession& operator = (const HTTPSClientSession&);
  110. Context::Ptr _pContext;
  111. };
  112. } } // namespace Poco::Net
  113. #endif // Net_HTTPSClientSession_INCLUDED