发布作者: 笒鬼鬼
百度收录: 正在检测是否收录...
作品采用: 《 署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0) 》许可协议授权
前言
我用Curl比较多 ,就渐渐的改出了一套非常好用的Curl封装的方法,今天分享出来!
代码
<?php
/**
* @msg PHPCurl封装的方法
*/
function teacher_curl($url, $paras = [])
{
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
if (isset($paras['Header'])) {
$Header = $paras['Header'];
} else {
$Header[] = "Accept:*/*";
$Header[] = "Accept-Encoding:gzip,deflate,sdch";
$Header[] = "Accept-Language:zh-CN,zh;q=0.8";
$Header[] = "Connection:close";
}
curl_setopt($ch, CURLOPT_HTTPHEADER, $Header);
if (isset($paras['ctime'])) { // 连接超时
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $paras['ctime']);
} else {
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);
}
if (isset($paras['rtime'])) { // 读取超时
curl_setopt($ch, CURLOPT_TIMEOUT, $paras['rtime']);
}
if (isset($paras['post'])) {
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $paras['post']);
}
if (isset($paras['header'])) {
curl_setopt($ch, CURLOPT_HEADER, true);
}
if (isset($paras['cookie'])) {
curl_setopt($ch, CURLOPT_COOKIE, $paras['cookie']);
}
if (isset($paras['refer'])) {
if ($paras['refer'] == 1) {
curl_setopt($ch, CURLOPT_REFERER, 'http://m.qzone.com/infocenter?g_f=');
} else {
curl_setopt($ch, CURLOPT_REFERER, $paras['refer']);
}
}
if (isset($paras['ua'])) {
curl_setopt($ch, CURLOPT_USERAGENT, $paras['ua']);
} else {
curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36");
}
if (isset($paras['nobody'])) {
curl_setopt($ch, CURLOPT_NOBODY, 1);
}
curl_setopt($ch, CURLOPT_ENCODING, "gzip");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
if (isset($paras['GetCookie'])) {
curl_setopt($ch, CURLOPT_HEADER, 1);
$result = curl_exec($ch);
preg_match_all("/Set-Cookie: (.*?);/m", $result, $matches);
$headerSize = curl_getinfo($ch, CURLINFO_HEADER_SIZE);
$header = substr($result, 0, $headerSize); //状态码
$body = substr($result, $headerSize);
$ret = [
"Cookie" => $matches, "body" => $body, "header" => $header, 'code' => curl_getinfo($ch, CURLINFO_HTTP_CODE),
];
curl_close($ch);
return $ret;
}
$ret = curl_exec($ch);
if (isset($paras['loadurl'])) {
$Headers = curl_getinfo($ch);
if (isset($Headers['redirect_url'])) {
$ret = $Headers['redirect_url'];
} else {
$ret = false;
}
}
curl_close($ch);
return $ret;
}
使用方法
文档
GET访问
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu");
POST访问
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php",[
'post'=>[
'url'=>'qq.com'
]
]);
或
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'post'=>'url=qq.com'
]);
携带Cookie访问
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'cookie'=>'cookie内容'
]);
模拟访问来源Refer
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'refer'=>'https://api.oioweb.cn'
]);
模拟UseaAgent
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'ua'=>'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36'
]);
文件上传
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'post'=>[
'file'=>new CURLFile(realpath("Curl.jpg"))
]
]);
或
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'post'=>new CURLFile(realpath("Curl.jpg"))
]);
获取301跳转地址
echo teacher_curl("https://mmbizurl.cn/s/RNHSo6Dek",[
'loadurl'=>1
]);
查看返回Header信息
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'header'=>1
]);
设置请求头信息
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'Header'=>[
'accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3
accept-encoding: gzip, deflate, br
accept-language: zh-CN,zh;q=0.9
cache-control: max-age=0'
]
]);
获取请求的全部信息
echo teacher_curl("https://api.cenguigui.cn/api/juhe/hotlist.php?type=zhihu",[
'post'=>[
'user'=>123456,
'pwd'=>123
],
'GetCookie'=>1
]);
最后
还有其他的功能,自己研究吧!还是很强大的!
—— 评论区 ——