PHP常用函数记录
PHP Access-Control-Allow-Origin跨域设置多个域名$origin = isset($_SERVER['HTTP_ORIGIN'])? $_SERVER['HTTP_ORIGIN'] : '';
$allowOrigin = array(
'https://www.baidu.com/',
'https://www.google.com/'
);
if (in_array($origin, $allowOrigin)) {
header("Access-Control-Allow-Origin:".$origin);
}
Chevereto图床API调用的两种方法
测试可以用方法一,方法二才是最佳的选择,示例中的图床有效性自行测试。
#方法一:
<script async src="//at9.cc/sdk/pup.js" data-url="https://at9.cc/upload" data-auto-insert="markdown-embed-full" data-palette="clear"></script>
优点:引用JS后会自动在textarea标记显示上传按钮,简单直接,但是默认按钮排版不甚美观,可以使用以下自定义按钮解决。
缺点:点击按钮会跳出上传页面,多一个步骤且不是太美观。
优化:自定义按钮
<button class="btn btn-default pull-right" style="margin-right: 5px;outline:none;" data-chevereto-pup-trigger data-chevereto-pup-id ='#newpost' data-target="#newpost"><i class="fa fa-picture-o"></i>插入图片</button>
<style>
.btn-default {
color: #333;
background-color: #fff;
border-color: #ccc;
}
.btn-default:hover {
color: #333;
background-color: #d4d4d4;
border-color: #8c8c8c;
}
.btn {
display: inline-block;
padding: 6px 12px;
margin-bottom: 0;
font-size: 14px;
font-weight: 400;
line-height: 1.42857143;
text-align: center;
white-space: nowrap;
vertical-align: middle;
-ms-touch-action: manipulation;
touch-action: manipulation;
cursor: pointer;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
background-image: none;
border: 1px solid transparent;
border-radius: 4px;
}
.btn:active {
background-image: none;
outline: 0;
-webkit-box-shadow: inset 0 3px 5px rgba(0,0,0,.125);
box-shadow: inset 0 3px 5px rgba(0,0,0,.125);
}
</style>
#方法二(推荐):
<script src="https://cdn.staticfile.org/jquery/2.1.4/jquery.min.js"></script>
<input id="up_to_chevereto" type="file" accept="image/*" multiple="multiple"/>
<label for="up_to_chevereto" id="up_img_label"><i class="fa fa-picture-o" aria-hidden="true"></i>上传图片</label>
<p id="up_tips"></p>
<style type="text/css">
#up_to_chevereto {
display: none;
}
#up_img_label {
color: #fff;
background-color: #16a085;
border-radius: 5px;
display: inline-block;
padding: 5.2px;
}
</style>
<script type="text/javascript">
$('#up_to_chevereto').change(function() {
var result = '';
for (var i = 0; i < this.files.length; i++) {
var f=this.files;
var formData=new FormData();
formData.append('source',f);
$.ajax({
async:true,
crossDomain:true,
url:'https://at9.cc/api/1/upload/?key=19298e656196b40c8b6e87a3ac589f2c&format=json',
type : 'POST',
processData : false,
contentType : false,
data:formData,
beforeSend: function (xhr) {
$('#up_img_label').html('<i class="fa fa-spinner rotating" aria-hidden="true"></i> Uploading...');
},
success:function(res){
//console.log(res);
result = res;
console.log(result);
//alert(result);
$("#up_tips").html('<a href='+res.image.url+'><img src='+res.image.url+' alt='+res.image.title+'></img></a>');
$("#up_img_label").html('<i class="fa fa-check" aria-hidden="true"></i> 上传成功,继续上传');
},
error: function (){
$("#up_img_label").html('<i class="fa fa-times" aria-hidden="true"></i> 上传失败,重新上传');
}
});
}
});
</script>
PHP判断文件夹是否存在,不存在自动创建
在生成或保存文件时我们经常会遇到文件夹不存在时报错的情况,使用以下方法即可解决
#判断文件夹是否存在,没有则新建
//判断文件夹是否存在,没有则新建
function path_exists($path){
if (!function_exists($path)) {
mkdirs($path);
}
}
#创建文件夹
//创建文件夹
function mkdirs($dir, $mode = 0777)
{
if (is_dir($dir) || @mkdir($dir, $mode)) {
return true;
}
if (!mkdirs(dirname($dir), $mode)) {
return false;
}
return @mkdir($dir, $mode);
}
#使用方法:
path_exists("Upload/user/images/");
PHP 对接七牛的图片鉴黄、暴恐识别、政治敏感、广告图片识别API的简单例子
<?php
$ak = "这里填写你的 Access Key";
$sk = "这里填写你的 Secret Key";
function curl($url, $header = null, $data = null) {
if($header) {
$header = array_map(function ($k, $v) {
return "{$k}: {$v}";
}, array_keys($header), $header);
}
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_HEADER, 0);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
if($data) {
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, is_array($data) ? http_build_query($data) : $data);
}
$result = curl_exec($curl);
return $result;
}
function ScanImage($img) {
global $ak, $sk;
$request_data = json_encode(Array(
'data' => Array(
'uri' => $img
),
'params' => Array(
'scenes' => Array(
'pulp', // 图片鉴黄
'terror', // 暴恐识别
'politician',// 政治敏感
'ads' // 政治敏感
)
)
));
$sign_rawdata = "POST /v3/image/censor\nHost: ai.qiniuapi.com\nContent-Type: application/json\n\n{$request_data}";
$header = Array(
'Content-Type' => 'application/json',
'Authorization' => "Qiniu {$ak}:" . str_replace("+", "-", base64_encode(hash_hmac('sha1', $sign_rawdata, $sk, true)))
);
return curl("http://ai.qiniuapi.com/v3/image/censor", $header, $request_data);
}
$data = ScanImage("你想要识别的图片地址"); // 此处是图片地址
$data = json_decode($data, true);
print_r($data); // 输出返回的信息
用于识别广告图片,对于需要监控广告的场景很合适。七牛的价格也不贵,一百张图片 0.085 元。点此注册
PHP加入一言功能
function GetHitokoto(){
$url = 'https://v1.hitokoto.cn/?encode=json'; // 不限定内容类型
// $url = https://v1.hitokoto.cn/?encode=json&c=d'; // 限定内容类型
$ch = curl_init();
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 跳过证书检查
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); // 从证书中检查 SSL 加密算法是否存在
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'GET');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 6);
$response = curl_exec($ch);
if($error=curl_error($ch)){
return '欢迎来到轮回阁'; // 如果 6s 内,一言 API 调用失败则输出这个默认句子~
}
curl_close($ch);
$array_data = json_decode($response,true);
$Emu_content = $array_data['hitokoto'].'----《'.$array_data['from'].'》'; // 输出格式:经典语句----《语句出处》
return $Emu_content;
}
调用时使用:
<?php echo GetHitokoto(); ?>
非激活标签时JS动态修改网站图标以及标题
<!-- 图标标题变化 -->
<script>
const changeFavicon = link => {
let $favicon = document.querySelector('link');
if ($favicon !== null) {
$favicon.href = link;
} else {
$favicon = document.createElement("link");
$favicon.rel = "icon";
$favicon.href = link;
document.head.appendChild($favicon);
}
};
window.onfocus = function () {
let icon = "favicon.ico"; // 图片地址
changeFavicon(icon); // 动态修改网站图标
document.title = "轮回阁"; // 动态修改网站标题
};
window.onblur = function () {
let icon = "https://www.baidu.com/favicon.ico"; // 图片地址
changeFavicon(icon); // 动态修改网站图标
document.title = "百度一下,你就知道"; // 动态修改网站标题
};
</script>
<!-- 图标标题变化End -->
适合于上班摸鱼或网页游戏挂机时间伪装使用。
原生JS实现ajax发送post请求并获取返回信息
<script>
var oStr = '';
var postData = {};
var oAjax = null;
//post提交的数据
postData = {"name1":"value1","name2":"value2"};
//这里需要将json数据转成post能够进行提交的字符串name1=value1&name2=value2格式
postData = (function(value){
for(var key in value){
oStr += key+"="+value+"&";
};
return oStr;
}(postData));
//这里进行HTTP请求
try{
oAjax = new XMLHttpRequest();
}catch(e){
oAjax = new ActiveXObject("Microsoft.XMLHTTP");
};
//post方式打开文件
oAjax.open('post','1.php?='+Math.random(),true);
//post相比get方式提交多了个这个
oAjax.setRequestHeader("Content-type","application/x-www-form-urlencoded");
//post发送数据
oAjax.send(postData);
oAjax.onreadystatechange = function(){
//当状态为4的时候,执行以下操作
if(oAjax.readyState == 4){
try{
alert(oAjax.responseText);
}catch(e){
alert('你访问的页面出错了');
};
};
};
</script>
JS根椐不同的省份跳转到不同的页面
<script type="text/javascript" src="https://ip.ws.126.net/ipquery"></script><!--网易IP库-->
<script>
var province=localAddress.province;
if(province.indexOf('广东省')!= -1 || province.indexOf('山东省')!= -1)){
window.location.href = '自定义跳转地址';
}
</script>
JS现10秒倒计时
<div class="box">
<h2>剩余时间:<span class="clock">10</span>秒</h2>
</div>
<script>
var t = 10;
var time = document.getElementsByClassName("clock");
function fun() {
t--;
time.innerHTML = t;
if(t <= 0) {
// location.href = "https://www.baidu.com";
clearInterval(inter);
}
}
var inter = setInterval("fun()", 1000);
</script>
PHP图片转换二进制数
$image = "1.jpg"; //图片地址
$fp = fopen($image, 'rb');
$content = fread($fp, filesize($image)); //二进制数据
列出某指定目录下所有目录名,并将指定的文件复制到目录名下
function list_directory_content($dir){
if(is_dir($dir)){
if($handle = opendir($dir)){
while(($file = readdir($handle)) !== false){
if($file != '.' && $file != '..' && $file != '.htaccess'){
//echo '目录名:<a target="_blank" href="https://www.chenbo.info/u/'.$file.'/">'.$file.'</a>,路径:'.$dir.'/'.$file.'<br>'."\n";
$oldfile='/www/wwwroot/www.chenbo.info/oldfile.php'; //旧目录
$newfile = $dir.'/'.$file.'/newfile.php'; //新目录
$copyresult = copy($oldfile,$newfile); //拷贝到新目录
$newfilesize = filesize($newfile);
if($copyresult || $oldfilesize = $newfilesize){
echo '路径:'.$dir.'/'.$file.'/,目录'.$file.'更新成功!<br>'."\n";
}
}
}
closedir($handle);
}
}
}
PHP获取referer判断来路防止非法访问
$fromurl = $_SERVER['HTTP_REFERER'];
$refererUrl = parse_url($fromurl);
$host = $refererUrl['host'];
if(!isset($fromurl) || $host !="www.chenbo.info") {
header("location: /"); //如果没有来路,或者来路不是本站,跳转到首页。
exit;
}
构造参数采用 file_get_contents 函数以POST方式获取数据并返回结果
///构造提交POST
$data = array(
'test'=>'bar',
'baz'=>'boom',
'site'=>'www.chenbo.info',
'name'=>'chenbo');
$data = http_build_query($data);
$options = array(
'http' => array(
'method' => 'POST',
'header' => 'Content-type:application/x-www-form-urlencoded',
'content' => $data,
'timeout' => 60 // 超时时间(单位:s)
)
);
$url = "http://www.chenbo.info/test.php";
$context = stream_context_create($options);
$result = file_get_contents($url, false, $context);
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));
?>
将图片保存到images目录下,自动读取images图片并输出
PHP随机图片API远程图片版,页面直接输出图片
<?php
$imgku=file('pic.txt');
showImg($imgku);
/*
* php 页面直接输出图片
*/
function showImg($img){
$img = trim($img);
$info = getimagesize($img);
$imgExt = image_type_to_extension($info, 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."\r\n");
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-urlencoded\r\n"."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;//多个查询结果输出
//return $row; 单一的结果可以直接用return
}
unset($dbh); unset($stmt);
}配置的sqlsrv扩展安装教程:https://www.rr6w.com/thread-1540-1-1.html
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;方法一及方法二在截取长段字符串时,碰到过无法截取到的情况,用方法三解决。
调用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;
}
页:
[1]