去年在网上 找了一个封装好的get post请求的方法 ,很方便 所以一直在用.直到遇到了 ...出现
a.
现象: 获取的数据直接被打印出来,变量接受不到数据。
汗,我的页面上莫名的出现了很数据 ...
b.
解决:
在我本地的虚拟机的是没有什么问题的,但是放到服务器上就出现了,直觉php 版本或者设定的问题(5.6)在stackOverflow 上看了大神们的解释 , 很懵;
本人是小白所以之后转到了php.net 了解了用途之后试着 将 CURLOPT_FOLLOWLOCATION 配置项改成了false然后ok,请求也是顺利
c.
总计:
找时间学一下 curl ,不然好被动(CURLOPT_FOLLOWLOCATION 关掉之后不知道有啥影响 尴尬...)
function GoCurl($url, $type, $data = false, &$err_msg = null, $timeout = 20, $cert_info = array()) { $type = strtoupper($type); if ($type == 'GET' && is_array($data)) { $data = http_build_query($data); } $option = array(); if ($type == 'POST') { $option[CURLOPT_POST] = 1; } if ($data) { if ($type == 'POST') { $option[CURLOPT_POSTFIELDS] = $data; } elseif ($type == 'GET') { $url = strpos($url, '?') !== false ? $url . '&' . $data : $url . '?' . $data; } } $option[CURLOPT_URL] = $url; $option[CURLOPT_FOLLOWLOCATION] = true; $option[CURLOPT_MAXREDIRS] = 4; $option[CURLOPT_RETURNTRANSFER] = true; $option[CURLOPT_TIMEOUT] = $timeout; //设置证书信息 if (!empty($cert_info) && !empty($cert_info['cert_file'])) { $option[CURLOPT_SSLCERT] = $cert_info['cert_file']; $option[CURLOPT_SSLCERTPASSWD] = $cert_info['cert_pass']; $option[CURLOPT_SSLCERTTYPE] = $cert_info['cert_type']; } //设置 CA if (!empty($cert_info['ca_file'])) { // 对认证证书来源的检查,0 表示阻止对证书的合法性的检查。 1 需要设置 CURLOPT_CAINFO $option[CURLOPT_SSL_VERIFYPEER] = 1; $option[CURLOPT_CAINFO] = $cert_info['ca_file']; } else { // 对认证证书来源的检查,0 表示阻止对证书的合法性的检查。 1 需要设置CURLOPT_CAINFO $option[CURLOPT_SSL_VERIFYPEER] = 0; } $ch = curl_init(); curl_setopt_array($ch, $option); $response = curl_exec($ch); $curl_no = curl_errno($ch); $curl_err = curl_error($ch); curl_close($ch); // error_log if ($curl_no > 0) { if ($err_msg !== null) { $err_msg = '(' . $curl_no . ')' . $curl_err; } } return $response; }