Проблема в вопросе.Я провел тщательное расследование для решений в отношении этого, и я знаю, что есть темы для этого, и я тоже следовал им, и ничего не помогло.При этом я перечислю точно все, что я сделал до сих пор.Я использую PHP 5.2.14 с Zend Debugging на последней версии Eclipse на моем компьютере с Windows XP.У меня 1 ГБ оперативной памяти.У меня XAMPP работает с установленными Apache, MySQL и FileZilla.
На XAMPP я сделал следующее (Apache был выключен во время этих изменений): На панели управления XAMPP нажал Admin и перешел на https:// localhost/xampp/
.Оттуда я принял сертификаты из этой строки на странице приветствия:
Для поддержки OpenSSL используйте тестовый сертификат с https: // 127.0.0.1 или https: // localhost.
В том же разделе я проверил phpinfo()
.В разделе «Окружающая среда» SERVER["HTTPS"]
означает on
.В «среде Apache» HTTPS
означает On
.В разделе «Переменные PHP» _SERVER["HTTPS"]
означает On
.В разделе «Phar» OpenSSL support
означает disabled
(установите ext / openssl).Я не знаю, как включить Phar.
Теперь, что касается самих файлов в C: \ xampp, я перешел в папку PHP.В обоих файлах php.ini для производства и разработки (лучше, чем потом сожалеть) у меня есть allow_url_fopen=On
, allow_url_include=On
, и я удалил точку с запятой, чтобы extension=php_openssl.dll
больше не был закомментирован.Я даже подтвердил, что .dll находится в папке ext папки PHP.И libeay32.dll, и ssleay32.dll находятся в папках PHP и Apache.Папка Apache не содержит ни производительных, ни разрабатываемых файлов php.ini.
Я перешел на http://www.slproweb.com/products/Win32OpenSSL.html и установил Win32 OpenSSL v1.0.0d для обеспечения безопасности.
Теперь соответствующая строка кода в моем retrieve_website.php выглядит следующим образом:
$urlquery = "https://www.googleapis.com/customsearch/v1?key=".$appid."&cx=".$google_searchid."&q=".$query."&alt=atom&num=".$results;
$xmlresults = file_get_contents($urlquery);
У меня есть два других веб-сайта, которые я запрашиваю, но они обслуживаются по HTTP и работают нормально.У меня также есть строка кода, введенная ближе к концу скрипта:
echo 'openssl: ', extension_loaded ('openssl') ? 'yes':'no', "\n";
echo 'http wrapper: ', in_array('http', $w) ? 'yes':'no', "\n";
echo 'https wrapper: ', in_array('https', $w) ? 'yes':'no', "\n";
echo 'wrappers: ', var_dump($w);
Когда я запускаю его как PHP Script на Eclipse, все выводится отлично, как я хочу, вместе с этими результатами:
openssl: yes
http wrapper: yes
https wrapper: yes
wrappers: array(10) {
[0]=>
string(5) "https"
[1]=>
string(4) "ftps"
[2]=>
string(3) "php"
[3]=>
string(4) "file"
[4]=>
string(4) "data"
[5]=>
string(4) "http"
[6]=>
string(3) "ftp"
[7]=>
string(13) "compress.zlib"
[8]=>
string(14) "compress.bzip2"
[9]=>
string(3) "zip"
}
Несмотря на все эти изменения, которые я сделал (после запуска Apache), я все равно получаю те же ошибки при первом доступе к моему PHP-скрипту в Eclipse и Firefox через http://localhost/tutorial/retrieve_website.php:
Предупреждение: file_get_contents () [function.file-get-contents]: невозможно найти упаковщик «https» - вы забыли включить его при настройке PHP?в C: \ xampp \ htdocs \ tutorial \ retrieve_website.php в строке 29Предупреждение: file_get_contents (https: // www.googleapis.com/customsearch/v1?key=removed API ID & cx = удален поисковый идентификатор & q = + Devil + пошел + вниз +to + Georgia & alt = atom & num = 5) [function.file-get-contents]: не удалось открыть поток: нет такого файла или каталога в C: \ xampp \ htdocs \ tutorial \ retrieve_website.php в строке 29Предупреждение: DOMDocument :: loadXML () [domdocument.loadxml]: пустая строка, предоставляемая в качестве входных данных в C: \ xampp \ htdocs \ tutorial \ retrieve_website.php в строке 33openssl: нет http-оболочки: да https-оболочки: нет оболочек: array (10) {[0] => string (3) "php" [1] => string (4) "file" [2] => string (4)) "glob" [3] => string (4) "data" [4] => string (4) "http" [5] => string (3) "ftp" [6] => string (3) "zip "[7] => string (13)" compress.zlib "[8] => string (14)" compress.bzip2 "[9] => string (4)" phar "}
Что я упустил из виду или не смог сделать?Насколько я знаю, я сделал все, что я исследовал в отношении HTTPS и OpenSSL