Задать вопрос
  • Как получить ответ через POST с помощью CURL?

    @ScarIetSky Автор вопроса
    Vladislav: Переписал. Сначала делаю get чтобы получить куки, заголовки, затем post, меняя только $getUrl на $postUrl. Заголовки сохраняться с первого запроса или их надо записать в файл, а потом передавать в CURLOPT_HTTPHEADER?
    Результат пост запроса
    * Trying 185.94.84.100...
    * Connected to www.investing.com (185.94.84.100) port 443 (#0)
    * ALPN, offering http/1.1
    * Cipher selection: ALL:!EXPORT:!EXPORT40:!EXPORT56:!aNULL:!LOW:!RC4:@STRENGTH
    * successfully set certificate verify locations:
    * CAfile: c:/openserver/modules/php/PHP-7-x64/cacert.pem
    CApath: none
    * NPN, negotiated HTTP1.1
    * SSL connection using TLSv1.2 / ECDHE-RSA-AES256-GCM-SHA384
    * ALPN, server did not agree to a protocol
    * Server certificate:
    * subject: OU=Domain Control Validated; CN=*.investing.com
    * start date: Jan 18 09:48:38 2016 GMT
    * expire date: Jan 18 09:48:38 2019 GMT
    * subjectAltName: host "www.investing.com" matched cert's "*.investing.com"
    * issuer: C=US; ST=Arizona; L=Scottsdale; O=GoDaddy.com, Inc.; OU=certs.godaddy.com/repository/; CN=Go Daddy Secure Certificate Authority - G2
    * SSL certificate verify ok.
    > POST /holiday-calendar/Service/getCalendarFilteredData HTTP/1.1
    Host: www.investing.com
    User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36 OPR/42.0.2393.94
    Accept: */*
    Cookie: PHPSESSID=ec8j7t662mqidip4chg5fl9vq6; StickySession=id.18267366337.742www.investing.com; geoC=RU; gtmFired=OK; nyxDorf=YGcyYDVkYSNkNGFrM34wMzFlPmMxKDc3YmNuag%3D%3D; adBlockerNewUserDomains=1484480915
    Content-Length: 453
    Expect: 100-continue
    Content-Type: multipart/form-data; boundary=------------------------5773b84c8c410fd5

    < HTTP/1.1 100 Continue
    < HTTP/1.1 301 Moved Permanently
    < Server: nginx/1.10.2
    < Date: Sun, 15 Jan 2017 11:55:25 GMT
    < Content-Type: text/html; charset=utf-8
    < Content-Length: 0
    < Connection: keep-alive
    < X-Powered-By: PHP/5.4.43
    < Expires: Thu, 19 Nov 1981 08:52:00 GMT
    < Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
    < Pragma: no-cache
    * Added cookie ses_id="deleted" for domain www.investing.com, path /, expire 1
    < Set-Cookie: ses_id=deleted; expires=Thu, 01-Jan-1970 00:00:01 GMT; path=/; domain=www.investing.com
    < Location: https://www.investing.com/
    < Vary: User-Agent
    < Accept-Ranges: bytes
    < X-Varnish: 1244608783
    < Age: 0
    < Via: 1.1 varnish
    < Content-Security-Policy: upgrade-insecure-requests
    * HTTP error before end of send, stop sending
    <
    * Closing connection 0
    * Issue another request to this URL: 'https://www.investing.com/'
    * Switch from POST to GET
    * Hostname www.investing.com was found in DNS cache
    * Trying 185.94.84.100...
    * Connected to www.investing.com (185.94.84.100) port 443 (#1)
    * ALPN, offering http/1.1
    * Cipher selection: ALL:!EXPORT:!EXPORT40:!EXPORT56:!aNULL:!LOW:!RC4:@STRENGTH
    * successfully set certificate verify locations:
    * CAfile: c:/openserver/modules/php/PHP-7-x64/cacert.pem
    CApath: none
    * SSL re-using session ID
    * NPN, negotiated HTTP1.1
    * SSL connection using TLSv1.2 / ECDHE-RSA-AES256-GCM-SHA384
    * ALPN, server did not agree to a protocol
    * old SSL session ID is stale, removing
    * Server certificate:
    * subject: OU=Domain Control Validated; CN=*.investing.com
    * start date: Jan 18 09:48:38 2016 GMT
    * expire date: Jan 18 09:48:38 2019 GMT
    * subjectAltName: host "www.investing.com" matched cert's "*.investing.com"
    * issuer: C=US; ST=Arizona; L=Scottsdale; O=GoDaddy.com, Inc.; OU=certs.godaddy.com/repository/; CN=Go Daddy Secure Certificate Authority - G2
    * SSL certificate verify ok.
    > GET / HTTP/1.1
    Host: www.investing.com
    User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36 OPR/42.0.2393.94
    Accept: */*
    Cookie: PHPSESSID=ec8j7t662mqidip4chg5fl9vq6; StickySession=id.18267366337.742www.investing.com; geoC=RU; gtmFired=OK; nyxDorf=YGcyYDVkYSNkNGFrM34wMzFlPmMxKDc3YmNuag%3D%3D; adBlockerNewUserDomains=1484480915

    < HTTP/1.1 200 OK
    < Server: nginx/1.10.2
    < Date: Sun, 15 Jan 2017 11:55:26 GMT
    < Content-Type: text/html; charset=utf-8
    < Content-Length: 305967
    < Connection: keep-alive
    < X-Powered-By: PHP/5.4.43
    < Expires: Thu, 19 Nov 1981 08:52:00 GMT
    < Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
    < Pragma: no-cache
    * Added cookie ses_id="deleted" for domain www.investing.com, path /, expire 1
    < Set-Cookie: ses_id=deleted; expires=Thu, 01-Jan-1970 00:00:01 GMT; path=/; domain=www.investing.com
    * Replaced cookie nyxDorf="OT4xY2Y3NnQ0ZDw2NXg1Nj9rYj8wKTU1PD01MQ%3D%3D" for domain www.investing.com, path /, expire 1484484926
    < Set-Cookie: nyxDorf=OT4xY2Y3NnQ0ZDw2NXg1Nj9rYj8wKTU1PD01MQ%3D%3D; expires=Sun, 15-Jan-2017 12:55:26 GMT; path=/
    < Vary: Accept-Encoding,User-Agent
    < Accept-Ranges: bytes
    < X-Varnish: 1244608919
    < Age: 0
    < Via: 1.1 varnish
    < Content-Security-Policy: upgrade-insecure-requests
    <
    * Connection #1 to host www.investing.com left intact
  • Как получить ответ через POST с помощью CURL?

    @ScarIetSky Автор вопроса
    Это весь код. Ссылку на код класса я добавил в описание.
    Куки сохраняются при отправке get запроса. Заголовки отправляются тоже (я этом почти уверен).
  • Как получить ответ через POST с помощью CURL?

    @ScarIetSky Автор вопроса
    Сделал. Вижу, что post заменяется на get и нет переданных параметров. Чем это может мне помочь?
    * Trying 185.94.84.100...
    * Connected to www.investing.com (185.94.84.100) port 443 (#0)
    * ALPN, offering http/1.1
    * Cipher selection: ALL:!EXPORT:!EXPORT40:!EXPORT56:!aNULL:!LOW:!RC4:@STRENGTH
    * successfully set certificate verify locations:
    * CAfile: c:/openserver/modules/php/PHP-7-x64/cacert.pem
    CApath: none
    * NPN, negotiated HTTP1.1
    * SSL connection using TLSv1.2 / ECDHE-RSA-AES256-GCM-SHA384
    * ALPN, server did not agree to a protocol
    * Server certificate:
    * subject: OU=Domain Control Validated; CN=*.investing.com
    * start date: Jan 18 09:48:38 2016 GMT
    * expire date: Jan 18 09:48:38 2019 GMT
    * subjectAltName: host "www.investing.com" matched cert's "*.investing.com"
    * issuer: C=US; ST=Arizona; L=Scottsdale; O=GoDaddy.com, Inc.; OU=certs.godaddy.com/repository/; CN=Go Daddy Secure Certificate Authority - G2
    * SSL certificate verify ok.
    > POST /holiday-calendar/Service/getCalendarFilteredData HTTP/1.1
    Host: www.investing.com
    User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:50.0) Gecko/20100101 Firefox/50.0
    Accept: */*
    Cookie: PHPSESSID=0pt92nc13gsvi3el2jjhp5drd0; StickySession=id.70110165438.949www.investing.com; geoC=RU; gtmFired=OK; nyxDorf=NTJkNjFgMnAzYzkzZShkZzFlP2I3LmFhPTxkYA%3D%3D; adBlockerNewUserDomains=1484472717
    Content-Length: 58
    Content-Type: application/x-www-form-urlencoded

    * upload completely sent off: 58 out of 58 bytes
    < HTTP/1.1 301 Moved Permanently
    < Server: nginx/1.10.2
    < Date: Sun, 15 Jan 2017 11:06:31 GMT
    < Content-Type: text/html; charset=utf-8
    < Content-Length: 0
    < Connection: keep-alive
    < X-Powered-By: PHP/5.4.43
    < Expires: Thu, 19 Nov 1981 08:52:00 GMT
    < Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
    < Pragma: no-cache
    * Added cookie ses_id="deleted" for domain www.investing.com, path /, expire 1
    < Set-Cookie: ses_id=deleted; expires=Thu, 01-Jan-1970 00:00:01 GMT; path=/; domain=www.investing.com
    < Location: https://www.investing.com/
    < Vary: User-Agent
    < Accept-Ranges: bytes
    < X-Varnish: 1244086267
    < Age: 0
    < Via: 1.1 varnish
    < Content-Security-Policy: upgrade-insecure-requests
    <
    * Connection #0 to host www.investing.com left intact
    * Issue another request to this URL: 'https://www.investing.com/'
    * Switch from POST to GET
    * Found bundle for host www.investing.com: 0x2a596105e20 [can pipeline]
    * Re-using existing connection! (#0) with host www.investing.com
    * Connected to www.investing.com (185.94.84.100) port 443 (#0)
    > GET / HTTP/1.1
    Host: www.investing.com
    User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:50.0) Gecko/20100101 Firefox/50.0
    Accept: */*
    Cookie: PHPSESSID=0pt92nc13gsvi3el2jjhp5drd0; StickySession=id.70110165438.949www.investing.com; geoC=RU; gtmFired=OK; nyxDorf=NTJkNjFgMnAzYzkzZShkZzFlP2I3LmFhPTxkYA%3D%3D; adBlockerNewUserDomains=1484472717

    < HTTP/1.1 200 OK
    < Server: nginx/1.10.2
    < Date: Sun, 15 Jan 2017 11:06:32 GMT
    < Content-Type: text/html; charset=utf-8
    < Content-Length: 306137
    < Connection: keep-alive
    < X-Powered-By: PHP/5.4.43
    < Expires: Thu, 19 Nov 1981 08:52:00 GMT
    < Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
    < Pragma: no-cache
    * Added cookie ses_id="deleted" for domain www.investing.com, path /, expire 1
    < Set-Cookie: ses_id=deleted; expires=Thu, 01-Jan-1970 00:00:01 GMT; path=/; domain=www.investing.com
    * Replaced cookie nyxDorf="NjEzYTNiNHZlNWpgZSgyMT5qZjtjemJiYGE0MA%3D%3D" for domain www.investing.com, path /, expire 1484481991
    < Set-Cookie: nyxDorf=NjEzYTNiNHZlNWpgZSgyMT5qZjtjemJiYGE0MA%3D%3D; expires=Sun, 15-Jan-2017 12:06:31 GMT; path=/
    < Vary: Accept-Encoding,User-Agent
    < Accept-Ranges: bytes
    < X-Varnish: 1244086284
    < Age: 0
    < Via: 1.1 varnish
    < Content-Security-Policy: upgrade-insecure-requests
    <
    * Connection #0 to host www.investing.com left intact