/**
* curl
*/
public function curl($url,$data,$header){//$url地址 $data数据
$curl = curl_init();
curl_setopt($curl,CURLOPT_URL,$url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
//启用时会发送一个常规的POST请求,为1或者为true
if(!empty($data)){
$data = is_array($data)?json_encode($data):$data;
curl_setopt($curl,CURLOPT_POST,1);
curl_setopt($curl,CURLOPT_POSTFIELDS,$data);//需要要传送的内容
}
$header1 = array(
'Content-Type: application/json; charset=utf-8',
'Content-Length:' . strlen($data),
'Cache-Control: no-cache',
'Pragma: no-cache'
);
$header = array_merge($header1,$header);
curl_setopt($curl, CURLOPT_HTTPHEADER,$header);
curl_setopt($curl,CURLOPT_RETURNTRANSFER,1);
$return_str = curl_exec($curl);
curl_close($curl);
return $return_str;
}
//multipart/form-data格式
public function form_post($url,$param,$header){
$delimiter = uniqid();
$post_data = $this->buildData($param,$delimiter);
$a = [
'Content-Length:' . strlen($post_data),
'Content-Type:multipart/form-data;boundary=----'.$delimiter,
"accept-encoding: gzip, deflate",
];
$header = array_merge($a,$header);
$curl = curl_init($url);
curl_setopt($curl,CURLOPT_RETURNTRANSFER,1);
curl_setopt($curl,CURLOPT_POST,true);
curl_setopt($curl,CURLOPT_POSTFIELDS,$post_data);
curl_setopt($curl,CURLOPT_HTTPHEADER,$header);
curl_setopt($curl, CURLINFO_HEADER_OUT, true); //是否返回输出header信息
$response = curl_exec($curl);
$error = curl_error($curl);
$header1 = curl_getinfo($curl, CURLINFO_HEADER_OUT);//获取返回的header信息
curl_close($curl);
return $response;
}
public function buildData($param,$delimiter){
$data = '';
$eol = "\r\n";
$upload = $param['faceImage'];
unset($param['faceImage']);
$json_str = json_encode($param);
$data .= "------" . $delimiter . "\r\n". 'Content-Disposition: form-data; name="json"'. "\r\n". 'Content-Type:application/json;charset=UTF-8'."\r\n\r\n" . $json_str ."\r\n";
$fp = fopen($upload,'rb'); //以二进制模式打开
$PSize = $this->getImageSize($upload, 'curl',true);//图片大小
$picturedata = fread($fp,$PSize['size']); //读取图片 二进制内容
// 拼接文件流
$data .= "------" . $delimiter . $eol
. 'Content-Disposition:form-data;name="faceImage";filename="' . $upload . '"' . "\r\n"
. 'Content-Type:'.$PSize['mime']."\r\n\r\n";
$data .= $picturedata . "\r\n";
$data .= "------" . $delimiter . "------"."\r\n";
return $data;
}
/**
* 获取远程图片的宽高和体积大小
*
* @param string $url 远程图片的链接
* @param string $type 获取远程图片资源的方式, 默认为 curl 可选 fread
* @param boolean $isGetFilesize 是否获取远程图片的体积大小, 默认false不获取, 设置为 true 时 $type 将强制为 fread
* @return false|array
*/
function getImageSize($url, $type = 'curl', $isGetFilesize = false)
{
// 若需要获取图片体积大小则默认使用 fread 方式
$type = $isGetFilesize ? 'fread' : $type;
if ($type == 'fread') {
// 或者使用 socket 二进制方式读取, 需要获取图片体积大小最好使用此方法
$handle = fopen($url, 'rb');
if (! $handle) return false;
// 只取头部固定长度168字节数据(有一些图片我们是获取不到信息的这个时候我们可以选择使用curl方式的)
$dataBlock = fread($handle, 255);
}else{
$ch = curl_init($url);
// 超时设置
curl_setopt($ch, CURLOPT_TIMEOUT, 5);
// 取前面 168 个字符 通过四张测试图读取宽高结果都没有问题,若获取不到数据可适当加大数值
curl_setopt($ch, CURLOPT_RANGE, '0-254');
// 跟踪301跳转
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
// 返回结果
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
//针对https忽略证书检测
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$dataBlock = curl_exec($ch);
curl_close($ch);
if (! $dataBlock) return false;
}
// 将读取的图片信息转化为图片路径并获取图片信息,经测试,这里的转化设置 jpeg 对获取png,gif的信息没有影响,无须分别设置
// 有些图片虽然可以在浏览器查看但实际已被损坏可能无法解析信息
// $size = getimagesize('data://image/jpeg;base64,'. base64_encode($dataBlock));
$size = getimagesize($url);
if (empty($size)) {
return false;
}
$result['width'] = $size[0];
$result['height'] = $size[1];
$result['mime'] = $size['mime'];
// 是否获取图片体积大小
if ($isGetFilesize) {
// 获取文件数据流信息
$meta = stream_get_meta_data($handle);
// nginx 的信息保存在 headers 里,apache 则直接在 wrapper_data
$dataInfo = isset($meta['wrapper_data']['headers']) ? $meta['wrapper_data']['headers'] : $meta['wrapper_data'];
foreach ($dataInfo as $va) {
if ( preg_match('/length/iU', $va)) {
$ts = explode(':', $va);
$result['size'] = trim(array_pop($ts));
break;
}
}
}
if ($type == 'fread') fclose($handle);
return $result;
}
curl[post]
于 2022-03-26 11:49:24 首次发布