解决file_get_contents无法请求https连接的方法
解决方案有3:
1.windows下的PHP,只需要到php.ini中把extension=php_openssl.dll前面的;删掉,重启服务就可以了。
2.linux下的PHP,就必须安装openssl模块,安装好了以后就可以访问了。
3.如果服务器你不能修改配置的话,那么就使用curl函数来替代file_get_contents函数,当然不是简单的替换啊。还有相应的参数配置才能正常使用curl函数。
对curl函数封装如下:
复制代码 代码如下:
function http_request($url,$timeout=30,$header=array()){
if (!function_exists('curl_init')) {
throw new Exception('server not install curl');
}
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, true);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);
if (!emptyempty($header)) {
curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
}
$data = curl_exec($ch);
list($header, $data) = explode("\r\n\r\n", $data);
$http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
if ($http_code == 301 || $http_code == 302) {
$matches = array();
preg_match('/Location:(.*?)\n/', $header, $matches);
$url = trim(array_pop($matches));
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HEADER, false);
$data = curl_exec($ch);
}
if ($data == false) {
curl_close($ch);
}
@curl_close($ch);
return $data;
}
上一篇: Transact_SQL 小手册
推荐阅读
-
ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务解决
-
mysql无法远程连接的解决方法
-
CI框架出现mysql数据库连接资源无法释放的解决方法,cimysql_PHP教程
-
解决file_get_contents无法请求https连接的方法_PHP教程
-
node.js请求HTTPS报错:UNABLE_TO_VERIFY_LEAF_SIGNATURE\的解决方法
-
php后台经常提示无法连接mysql 刷新后又可以访问的解决方法_MySQL
-
Win10系统电脑无法登录LOL提示服务器连接异常的原因及解决方法
-
解决Charles抓包https时,无法查看CONNECT请求的问题
-
MYSQL无法连接 提示10055错误的解决方法
-
解决Charles抓包https时,无法查看CONNECT请求的问题