php函数接口什么意思_PHP封装curl的调用接口及常用函数详解

/**

* @desc 封装curl的调用接口,post的请求方式

*/

function doCurlPostRequest($url, $requestString, $timeout = 5) {

if($url == "" || $requestString == "" || $timeout <= 0){

return false;

}

$con = curl_init((string)$url);

curl_setopt($con, CURLOPT_HEADER, false);

curl_setopt($con, CURLOPT_POSTFIELDS, $requestString);

curl_setopt($con, CURLOPT_POST, true);

curl_setopt($con, CURLOPT_RETURNTRANSFER,true);

curl_setopt($con, CURLOPT_TIMEOUT, (int)$timeout);

curl_setopt($con, CURLOPT_SSL_VERIFYPEER, false);

curl_setopt($con, CURLOPT_SSL_VERIFYHOST, false);

return curl_exec($con);

}

/**

* @desc 封装curl的调用接口,post的请求方式

*/

function doCurlPostsslRequest($url, $requestString,$pemfile, $timeout = 5) {

if($url == "" || $requestString == "" || $timeout <= 0){

return false;

}

echo $pemfile;

$con = curl_init((string)$url);

curl_setopt($con, CURLOPT_HEADER, false);

curl_setopt($con, CURLOPT_POSTFIELDS, $requestString);

curl_setopt($con, CURLOPT_POST, true);

curl_setopt($con, CURLOPT_RETURNTRANSFER,true);

curl_setopt($con, CURLOPT_TIMEOUT, (int)$timeout);

curl_setopt($con, CURLOPT_SSL_VERIFYPEER, 1);

curl_setopt($con, CURLOPT_SSL_VERIFYHOST, 2);

//curl_setopt($ch, CURLOPT_SSLCERT, $pemfile);

//curl_setopt($ch, CURLOPT_SSLCERTTYPE, 'PEM');

curl_setopt($con, CURLOPT_CAINFO, $pemfile);

return curl_exec($con);

}

/**

* @desc 封装curl的调用接口,post Json数据的请求方式

*/

function doCurlPostJsonReq($url, $requestString, $timeout = 25){

if($url == "" || $requestString == "" || $timeout <= 0){

return false;

}

$con = curl_init((string)$url);

curl_setopt($con, CURLOPT_HEADER, false);

curl_setopt($con, CURLOPT_POSTFIELDS, $requestString);

curl_setopt($con, CURLOPT_POST, true);

curl_setopt($con, CURLOPT_RETURNTRANSFER,true);

curl_setopt($con, CURLOPT_TIMEOUT, (int)$timeout);

curl_setopt($con, CURLOPT_HTTPHEADER, array(

'Content-Type: application/json',

'Content-Length: ' . strlen($data_string))

);

return curl_exec($con);

}

/**

* @desc 封装curl的调用接口,post form数据的请求方式

*/

function doCurlPostFormReq($url, $requestString, $timeout = 25){

if($url == "" || $requestString == "" || $timeout <= 0){

return false;

}

$con = curl_init((string)$url);

curl_setopt($con, CURLOPT_HEADER, false);

curl_setopt($con, CURLOPT_POSTFIELDS, $requestString);

curl_setopt($con, CURLOPT_POST, true);

curl_setopt($con, CURLOPT_RETURNTRANSFER,true);

curl_setopt($con, CURLOPT_TIMEOUT, (int)$timeout);

curl_setopt($con, CURLOPT_HTTPHEADER, array(

'Content-Type: application/x-www-form-urlencoded')

);

return curl_exec($con);

}

/**

* @desc 封装curl的调用接口,get的请求方式

*/

function doCurlGetRequest($url, $data = array(), $timeout = 10) {

if($url == "" || $timeout <= 0){

return false;

}

if($data != array()) {

$url = $url . '?' . http_build_query($data);

}

Log::write("发送URL[".$url."]");

$con = curl_init((string)$url);

curl_setopt($con, CURLOPT_HEADER, false);

curl_setopt($con, CURLOPT_RETURNTRANSFER,true);

curl_setopt($con, CURLOPT_TIMEOUT, (int)$timeout);

curl_setopt($con, CURLOPT_SSL_VERIFYPEER, false);

curl_setopt($con, CURLOPT_SSL_VERIFYHOST, false);

return curl_exec($con);

}

/**

*截取字符串,中文无乱码

*/

function msubstr($str, $start=0, $length=0,$suffix=false,$charset="utf-8"){

if(mb_strlen($str,"UTF8") >= $length){

$next_str = "…";

}else{

$next_str = "";

}

if(function_exists("mb_substr")){

if($suffix)

// return mb_substr($str, $start, $length, $charset)."…";

return mb_substr($str, $start, $length, $charset).$next_str;

else

return mb_substr($str, $start, $length, $charset);

}elseif(function_exists('iconv_substr')) {

if($suffix)

// return iconv_substr($str,$start,$length,$charset)."…";

return iconv_substr($str,$start,$length,$charset).$next_str;

else

return iconv_substr($str,$start,$length,$charset);

}

$re['utf-8'] = "/[x01-x7f]|[xc2-xdf][x80-xbf]|[xe0-xef][x80-xbf]{2}|[xf0-xff][x80-xbf]{3}/";

$re['gb2312'] = "/[x01-x7f]|[xb0-xf7][xa0-xfe]/";

$re['gbk'] = "/[x01-x7f]|[x81-xfe][x40-xfe]/";

$re['big5'] = "/[x01-x7f]|[x81-xfe]([x40-x7e]|xa1-xfe])/";

preg_match_all($re[$charset], $str, $match);

$slice = join("",array_slice($match[0], $start, $length));

if($suffix) return $slice."…";

if(!$suffix) return $slice;

return $slice;

}

/**

*用户名*隐藏

*$str = "如来神掌";

*echo cut_str($str, 1, 0).'**'.cut_str($str, 1, -1);

*输出:如**掌

*/

function cut_str($string, $sublen, $start = 0, $code = 'UTF-8')

{

if($code == 'UTF-8')

{

$pa = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/";

preg_match_all($pa, $string, $t_string);

if(count($t_string[0]) - $start > $sublen) return join('', array_slice($t_string[0], $start, $sublen));

return join('', array_slice($t_string[0], $start, $sublen));

}

else

{

$start = $start*2;

$sublen = $sublen*2;

$strlen = strlen($string);

$tmpstr = '';

for($i=0; $i< $strlen; $i++)

{

if($i>=$start && $i< ($start+$sublen))

{

if(ord(substr($string, $i, 1))>129)

{

$tmpstr.= substr($string, $i, 2);

}

else

{

$tmpstr.= substr($string, $i, 1);

}

}

if(ord(substr($string, $i, 1))>129) $i++;

}

//if(strlen($tmpstr)< $strlen ) $tmpstr.= "...";

return $tmpstr;

}

}

/*

*解决json_encode转换中文的问题,在php5.4下json_encode本身解决的这个问题

*/

function unescapedUnicode($match)

{

return mb_convert_encoding(pack('H*', $match[1]), 'UTF-8', 'UCS-2BE');

}

/**

*截取手机号

*demo:13112345678

*return:131****5678

*/

function hidtel($phone){

$IsWhat = preg_match('/(0[0-9]{2,3}[-]?[2-9][0-9]{6,7}[-]?[0-9]?)/i',$phone); //固定电话

if($IsWhat == 1){

return preg_replace('/(0[0-9]{2,3}[-]?[2-9])[0-9]{3,4}([0-9]{3}[-]?[0-9]?)/i','$1****$2',$phone);

}else{

return preg_replace('/(1[358]{1}[0-9])[0-9]{4}([0-9]{4})/i','$1****$2',$phone);

}

}

//获取IP

function getIp()

{

if (isset($_SERVER)){

if (isset($_SERVER["HTTP_X_FORWARDED_FOR"])){

$realip = $_SERVER["HTTP_X_FORWARDED_FOR"];

} else if (isset($_SERVER["HTTP_CLIENT_IP"])) {

$realip = $_SERVER["HTTP_CLIENT_IP"];

} else {

$realip = $_SERVER["REMOTE_ADDR"];

}

} else {

if (getenv("HTTP_X_FORWARDED_FOR")){

$realip = getenv("HTTP_X_FORWARDED_FOR");

} else if (getenv("HTTP_CLIENT_IP")) {

$realip = getenv("HTTP_CLIENT_IP");

} else {

$realip = getenv("REMOTE_ADDR");

}

}

return $realip;

}

//把汉字转换为数字

function getUnicodeFromOneUTF8($word)

{

//获取其字符的内部数组表示,所以本文件应用utf-8编码!

//$word = iconv("gb2312", "utf-8", $word);

if (is_array($word))

$arr = $word;

else

$arr = str_split($word);

//此时,$arr应类似array(228, 189, 160)

//定义一个空字符串存储

$bin_str = '';

//转成数字再转成二进制字符串,最后联合起来。

foreach ($arr as $value)

$bin_str .= decbin(ord($value));

//此时,$bin_str应类似111001001011110110100000

//正则截取

$bin_str = preg_replace('/^.{4}(.{4}).{2}(.{6}).{2}(.{6})$/','$1$2$3', $bin_str);

//此时, $bin_str应类似0100111101100000,如果是汉字"你"

return bindec($bin_str);

//返回类似20320, 汉字"你"

//return dechex(bindec($bin_str));

//如想返回十六进制4f60,用这句

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值