PHP常用函数大全

PHP常用函数大全
                     第一张

PHP随机图片API本地图片版,页面直接输出图片

<?php
$img_array = glob('images/*.{gif,jpg,png,jpeg,webp,bmp}', GLOB_BRACE);
if(count($img_array) == 0) die('没找到图片文件。请先上传一些图片到 '.dirname(__FILE__).'/images/ 文件夹');
header('Content-Type: image/png');
echo(file_get_contents($img_array[array_rand($img_array)]));
?>

将图片保存到images目录下,自动读取images图片并输出。

PHP随机图片API远程图片版,页面直接输出图片

<?php
$imgku=file('pic.txt');
showImg($imgku[array_rand($imgku)]);
/*
* php 页面直接输出图片
*/
function showImg($img){
$img = trim($img);
$info = getimagesize($img);
$imgExt = image_type_to_extension($info[2], false); //获取文件后缀
$fun = "imagecreatefrom{$imgExt}";
$imgInfo = $fun($img);         //1.由文件或 URL 创建一个新图象。如:imagecreatefrompng ( string $filename )
//$mime = $info['mime'];
$mime = image_type_to_mime_type(exif_imagetype($img)); //获取图片的 MIME 类型
header('Content-Type:'.$mime);
$quality = 100;
if($imgExt == 'png') $quality = 9;   //输出质量,JPEG格式(0-100),PNG格式(0-9)
$getImgInfo = "image{$imgExt}";
$getImgInfo($imgInfo, null, $quality); //2.将图像输出到浏览器或文件。如: imagepng ( resource $image )
imagedestroy($imgInfo);
}
?>

需安装GD库及exif扩展,php.ini中开启allow_url_fopen函数,读取同目录下pic.txt文件中的图片网址,每行一个图片地址。

Cookie限制时间再次提交

if(isset($_COOKIE['submission_time'])) {
$submissionTime =   $_COOKIE['submission_time'];
$currentTime    =   time();
$timePassed     =   ($currentTime - $submissionTime ) / 60 * 60;
if($timePassed < 24 ) {
echo "<div class='alert alert-warning'>You can record the sales after 24 hours! Please wait..</div>";
die();
}
}else {
$cookieName     =   'submission_time';
$cokkieValue    =   time(); 
setcookie($cookieName, $cokkieValue, time() + (+60*60*24*30 ), "/");
}

判断字符串是否含有某分割符,若包含分割符,分割后输出全部分割后的值

if(strpos($qcont,',') === false){
echo "不包含,分割字段";
}else{
echo "包含,分割字段,下面进行切割并输出";
$qcontArr = explode(",", $qcont);
$qcontcount = count($qcontArr);
for ($i = 0; $i < $qcontcount; $i++) {
if ($qcontArr[$i] == "") {
continue;  
}
echo $qcontArr[$i];
}
}

对错误的详情进行格式化输出,记入log文件。

function slog($logs){
$toppath="log.htm";
$Ts=fopen($toppath,"a+");
fputs($Ts,$logs."rn");
fclose($Ts);
}

使用file_get_contents() 发送GET、post请求

1、【GET请求】

$data = array( 'name'=>'zhezhao','age'=>'23');
$query = http_build_query($data); 
$url = 'http://localhost/get.php';//这里一定要写完整的服务页面地址,否则php程序不会运行 
$result = file_get_contents($url.'?'.$query);

2、【POST请求】

$data = array('user'=>'jiaxiaozi','passwd'=>'123456');
$requestBody = http_build_query($data);
$context = stream_context_create(['http' => ['method' => 'POST', 'header' => "Content-Type: application/x-www-form-urlencodedrn"."Content-Length: " . mb_strlen($requestBody), 'content' => $requestBody]]);
$response = file_get_contents('http://server.test.net/login', false, $context);

php获取当天是几号、周几

echo date('y').'</br>';    //当前年份
echo date('m').'</br>';    //当前月份
echo date('d').'</br>';    //当前日
echo date('s').'</br>';    //当前秒
echo date('w').'</br>';    //当前周几

打印结果显示为:

20
07
24
50
5

PHP给第三方接口POST或GET方式传输数据并得到返回值

function Post($url, $post = null)
{
$context = array();
if (is_array($post))
{
ksort($post);
$context['http'] = array
(   
'timeout'=>60,
'method' => 'POST',
'content' => http_build_query($post, '', '&'),
);
}
return file_get_contents($url, false, stream_context_create($context));
}
$data = array
(
'name' => 'test',
'email' => 'test@gmail.com',
'submit' => 'submit',
);
echo Post('http://www.baidu.com', $data);

同一页面24小时之内之只能执行一次

define('TIME_OUT', 86400); //定义重复操作最短的允许时间,单位秒
@session_start();
$time = time();
if( isset($_SESSION['time']) ){
if( $time - $_SESSION['time'] <= TIME_OUT ){
echo '<script type=text/javascript>alert("在24小时内只能执行一次!");</script>';
exit();
}
}
$_SESSION['time'] = $time;
echo "正常执行!";

PHP连接远程MSSQL函数:

已在如上环境安装后测试通过!

function mssql_user($username){
$host="远程服务器IP,MSSQL端口";
$dbname="数据库名称";
$user="数据库用户名";
$pass="数据库密码";
try {
$dbh = new PDO("sqlsrv:Server=$host;Database=$dbname", $user, $pass);
} catch(PDOException $e) {
echo $e->getMessage();
exit;
}
$stmt = $dbh->prepare("SELECT XXX FROM XXX WHERE XXX = ".$username);
$stmt->execute();
while ($row = $stmt->fetch()) {
echo $row[0];//多个查询结果输出
//return $row[0]; 单一的结果可以直接用return
}
unset($dbh); unset($stmt);
}

php时间戳和日期相互转换

获取当前日期时间的时间戳

echo time();

获取当前日期时间

echo date("Y/m/d H:i:s");

日期转换为时间戳

echo strtotime(date("Y/m/d"));

时间戳转换为日期

echo date('Y-m-d',time());

打印明天此时的时间戳

echo strtotime("+1 day");

当前时间:

echo date("Y-m-d H:i:s",time()) ;

指定时间:

echo date("Y-m-d H:i:s",strtotime("+1 day")) ;

下个星期此时的时间戳

echo strtotime("+1 week");

指定下星期几的PHP时间戳

echo strtotime("next Thursday");

指定下星期几的时间:

echo date("Y-m-d H:i:s",strtotime("next Thursday"));

指定上星期几的时间戳

echo strtotime("last Thursday");

指定本年的最后一个星期几的时间:

echo date("Y-m-d H:i:s",strtotime("last Thursday"));

截取指定两个字符之间的字符串

方法一

function cut($begin,$end,$str){
$b = mb_strpos($str,$begin) + mb_strlen($begin);
$e = mb_strpos($str,$end) - $b;
return mb_substr($str,$b,$e);
}

方法二

function get_between($input, $start, $end) {
$substr = substr($input, strlen($start)+strpos($input, $start),(strlen($input) - strpos($input, $end))*(-1));
return $substr;
}

方法一当截取的是值为串的时候,会出现截取不到的情况用方法二尝试。

方法三:preg_match_all函数

preg_match_all('/<Epoch>(.*)</Epoch>/', $result, $matches); 
//print_r($matches);
$resultapp = $matches[1][1];

方法一及方法二在截取长段字符串时,碰到过无法截取到的情况,用方法三解决。

调用SOHU API获取IP地址

//通过API获取IP地址
function getIP(){
$str = file_get_contents('https://pv.sohu.com/cityjson?ie=utf-8');
$ip = cut('cip": "','", "cid',$str);
if($ip){
return $ip;
}
}

注:需配合上面 截取指定两个字符之间的字符串 函数一起使用

获取访问客户端的IP地址

function get_client_ip(){
static $realip;
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;
}

本文结束

发表评论

登录... 评论区已永久关闭~