запрос curl не способен конкатенировать строки [дублировать]

Просто используйте unsafe внутри вашего тега, чтобы предотвратить кодирование HTML.

body {
    unsafe {
       +"""<form class="formClass"/>"""
    }
}
49
задан StackOverflowNewbie 7 December 2010 в 02:51
поделиться

3 ответа

Быстрое исправление, добавьте это в свои параметры:

curl_setopt($ch,CURLOPT_SSL_VERIFYPEER, false)

или просто добавьте его в свою текущую функцию:

/**
 * Get a web file (HTML, XHTML, XML, image, etc.) from a URL.  Return an
 * array containing the HTTP server response header fields and content.
 */
function get_web_page( $url )
{
    $options = array(
        CURLOPT_RETURNTRANSFER => true,     // return web page
        CURLOPT_HEADER         => false,    // don't return headers
        CURLOPT_FOLLOWLOCATION => true,     // follow redirects
        CURLOPT_ENCODING       => "",       // handle all encodings
        CURLOPT_USERAGENT      => "spider", // who am i
        CURLOPT_AUTOREFERER    => true,     // set referer on redirect
        CURLOPT_CONNECTTIMEOUT => 120,      // timeout on connect
        CURLOPT_TIMEOUT        => 120,      // timeout on response
        CURLOPT_MAXREDIRS      => 10,       // stop after 10 redirects
        CURLOPT_SSL_VERIFYPEER => false     // Disabled SSL Cert checks
    );

    $ch      = curl_init( $url );
    curl_setopt_array( $ch, $options );
    $content = curl_exec( $ch );
    $err     = curl_errno( $ch );
    $errmsg  = curl_error( $ch );
    $header  = curl_getinfo( $ch );
    curl_close( $ch );

    $header['errno']   = $err;
    $header['errmsg']  = $errmsg;
    $header['content'] = $content;
    return $header;
}
74
ответ дан RageZ 18 August 2018 в 14:56
поделиться
  • 1
    Дополнительную информацию об этом можно найти здесь: unitstep.net/blog/2009/05/05/… – SystemX17 7 December 2010 в 02:56
  • 2
    извините за неправильное редактирование ;-) Я не понял, что вы имели в виду ... – RageZ 7 December 2010 в 03:02
  • 3
    это нормально - я только новичок здесь со вчерашнего дня. спасибо за то, что этот код лучше для человека, спрашивающего - ур потрясающий. – SystemX17 7 December 2010 в 03:04
  • 4
    Установка CURLOPT_SSL_VERIFYPEER в false позволяет использовать атаки типа «человек-в-середине». rmckay в webaware dot com dot au предупреждает об этом на nl3.php.net/manual/en/function.curl-setopt.php и дает альтернативное решение, которое работает: загрузка пакета корневого сертификата CA на сайт скручивания и сохранение его на вашем сервере. См. На данном сайте, прокрутите вниз до комментариев пользователя. – Paul Gobée 15 May 2014 в 23:52

другой вариант, такой как ответ Гавина Палмера, заключается в использовании файла .pem, но с опцией curl

1- загрузка последнего обновленного файла .pem из https: //curl.haxx .se / docs / caextract.html и сохраните его где-нибудь на вашем сервере (вне общей папки)

2- установите параметр в вашем коде вместо файла php.ini

curl_setopt($ch, CURLOPT_CAINFO, $_SERVER['DOCUMENT_ROOT'] .  "/../cacert-2017-09-20.pem");
1
ответ дан Accountant م 18 August 2018 в 14:56
поделиться

Я пытался использовать CURL для выполнения некоторых вызовов API https с php и столкнулся с этой проблемой. Я заметил рекомендацию на php-сайте, который запустил меня и запущен: http://php.net/manual/en/function.curl-setopt.php#110457

Пожалуйста, всем, прекратите настройку CURLOPT_SSL_VERIFYPEER на false или 0. Если ваша установка PHP не имеет обновленного набора корневых сертификатов CA, загрузите ее на сайт curl и сохраните на своем сервере:

http://curl.haxx.se/docs/caextract.html

Затем установите путь к нему в файле php.ini, например на Windows:

curl.cainfo = c: \ php \ cacert.pem

Отключение CURLOPT_SSL_VERIFYPEER позволяет людям посередине (MITM), которые вам не нужны!

25
ответ дан Gavin Palmer 18 August 2018 в 14:56
поделиться
  • 1
    Я сделал это, но теперь я получаю только 35 error:14077410:SSL routines:SSL23_GET_SERVER_HELLO:sslv3 alert handshake failure – OZZIE 1 February 2015 в 16:20
Другие вопросы по тегам:

Похожие вопросы: