よく使うPHP関数のまとめと保存_PHPチュートリアル
内容:
function GetIP() { //IP を取得
if ($_SERVER["HTTP_X_FORWARDED_FOR"])
$ip = $_SERVER[ "HTTP_X_FORWARDED_FOR " ];
else if ($_SERVER["HTTP_CLIENT_IP"])
$ip = $_SERVER["HTTP_CLIENT_IP"];
else if ($_SERVER["REMOTE_ADDR"])
$ip = $_SERVER["REMOTE_ADDR "];
else if (getenv("HTTP_X_FORWARDED_FOR"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
else if (getenv("HTTP_CLIENT_IP"))
$ip = getenv("HTTP_CLIENT_IP");
else if ( "remote_addr")$ ip = getEnv( "remote_addr");コードは次のとおりです:
function DateAdd($date, $int, $unit = "d") { //時間の増加 (時間、分、秒の増加に改良することもできます)時間があるときに追加してください)
$dateArr =explode("-", $date);
$value[$unit] = $int;
return date("Y-m-d", mktime(0,0,0, $) dateArr[1] + $value['m' ], $dateArr[2] + $value['d'], $dateArr[0] + $value['y']));
function GetWeekDay($) date) { //指定された日付を計算します
$timeArr =explode(":", $time);
if (is_numeric($timeArr[0]) && is_numeric($timeArr[1]) && is_numeric($timeArr[2])) {
if (($timeArr) [0] >= 0 && $timeArr[0] < = 23) && ($timeArr[1] >= 0 && $timeArr[1] <= 59) && ($timeArr[2] >= 0 && $timeArr[2] <= 59))
return true;
else
return false;
コードをコピーします
コードは次のとおりです。 function DateDiff($date1, $date2, $unit = "") { // 時間比較関数。2 つの日付の差を秒、分、時間、または日単位で返します
switch ($unit) {
$配当 = 1;
if ($time1 && $time2)
return (float); time1 - $time2) / $dividend;
return false
}
?>
コードは次のとおりです:
"Location:index.php");
方法 2: echo "
方法 3: echo "
コードをコピーします
コードは次のとおりです:
関数browse_infor()
{
$browser="";$browserver="";
$Browsers =array("Lynx","MOSAIC","AOL","Opera","JAVA","MacWeb","WebExplorer","OmniWeb");
$エージェント = $GLOBALS["HTTP_USER_AGENT"];
for ($i=0; $i{
if (strpos($Agent,$Browsers[$i]))
{
$browser = $Browsers[$i];
$ブラウザサーバー = ";
}
}
if (ereg("Mozilla",$Agent) && !ereg("MSIE",$Agent))
{
$temp =explode("(", $Agent); $Part=$temp[ 0];
$temp =explode("/", $browserver=$temp[1];
$temp =explode(" ",$browserver);ブラウザーバー =preg_replace("/([d.]+)/","1",$browserver);
$browserver = "$browserver";
$browser = "Netscape Navigator"; Mozilla",$Agent) && ereg("Opera",$Agent))
{
$temp =explode("(", $Agent); $Part=$temp[1];
$temp =explode(") ", $Part); $browserver=$temp[1];
$temp =explode(" ",$browserver);$browserver=$temp[2];
$browserver =preg_replace("/([d.] +)/","1",$browserver);
$browserver = " $browserver";
$browser = "Opera";
}
if (ereg("Mozilla",$Agent) && ereg("MSIE" ,$Agent))
{
$temp =explode("(", $Agent); $Part=$temp[1];
$temp =explode(";",$Part); $Part=$temp[ 1];
$temp =explode(" ",$Part);$browserver=$temp[2];
$browserver =preg_replace("/([d.]+)/","1",$browserver) ;
$browserver = "$browserver";
$browser = "Internet Explorer"
if ($browser!="")
{
$browseinfo = "$browser$browserver";
}
else
{
$browseinfo = "不明";
}
$browseinfo を返します。
}
//调用方法$browser=browseinfo() ;直接結果を返します
?>
获取访问者操作系统
复制代码
if (eregi('win',$Agent) && strpos($Agent, '95')) {
$os="Windows 95";
}
elseif (eregi('win 9x',$Agent) && strpos($Agent, '4.90')) {
$os="Windows ME";
}
elseif (eregi('win',$Agent) && ereg('98',$Agent)) {
$os="Windows 98";
}
elseif (eregi('win',$Agent) && eregi('nt 5.0',$Agent)) {
$os="Windows 2000";
}
elseif (eregi('win',$Agent) && eregi('nt',$Agent)) {
$os="Windows NT";
}
elseif (eregi('win',$Agent) && eregi('nt 5.1',$Agent)) {
$os="Windows XP";
}
elseif (eregi('win',$Agent) && ereg('32',$Agent)) {
$os="Windows 32";
}
elseif (eregi('linux',$Agent)) {
$os="Linux";
}
elseif (eregi('unix',$Agent)) {
$os="Unix";
}
elseif (eregi('sun',$Agent) && eregi('os',$Agent)) {
$os="SunOS";
}
elseif (eregi('ibm',$Agent) && eregi('os',$Agent)) {
$os="IBM OS/2";
}
elseif (eregi('Mac',$Agent) && eregi('PC',$Agent)) {
$os="Macintosh";
}
elseif (eregi('PowerPC',$Agent)) {
$os="PowerPC";
}
elseif (eregi('AIX',$Agent)) {
$os="AIX";
}
elseif (eregi('HPUX',$Agent)) {
$os="HPUX";
}
elseif (eregi('NetBSD',$Agent)) {
$os="NetBSD";
}
elseif (eregi('BSD',$Agent)) {
$os="BSD";
}
elseif (ereg('OSF1',$Agent)) {
$os="OSF1";
}
elseif (ereg('IRIX',$Agent)) {
$os="IRIX";
}
elseif (eregi('FreeBSD',$Agent)) {
$os="FreeBSD";
}
if ($os=='') $os = "不明";
$os を返します;
}
//调用メソッド$os=os_infor() ;
?>
文件格式类
复制代码
$mime_types = array(
'gif' => 'image/gif',
'jpg' => 'image/jpeg',
'jpeg' => 'image/jpeg',
'jpe' = > '画像/jpeg'、
'bmp' => '画像/png'、
'tif' => ' => '画像/tiff'、
'pict' => '画像/x-pict'、
'pct' => x-pict'、
'tif' => '画像/tiff'、
'psd' => '画像/x-photoshop'、
'swf' => 'アプリケーション/x-shockwave-flash',
'js' => 'アプリケーション/x-javascript',
'pdf' => /postscript',
'eps' => 'application/postscript',
'ai' => 'application/x-msmetafile',
'css' = > 'text/css'、
'htm' => 'text/html'、
'txt' => ' => 'text/xml'、
'wml' => 'image/vnd.wap.wbmp'、
'mid' => midi'、
'wav' => 'オーディオ/wav'、
'mp2' => 'オーディオ/mpeg'、
'avi' => video/x-msvideo',
'mpeg' => 'ビデオ/mpeg',
'mpg' => 'video/mpeg',
'qt' => 'ビデオ/クイックタイム',
'mov' => 'ビデオ/クイックタイム',
'lha' => 'application/x-lha',
'lzh' => 'application/x-lha',
'z' => 'application/x-compress',
'gtar' => 'application/x-gtar',
'gz' => 'application/x-gzip',
'gzip' => 'application/x-gzip',
'tgz' => 'application/x-gzip',
'tar' => 'application/x-tar',
'bz2' => 'application/bzip2',
'zip' => 'アプリケーション/zip',
'arj' => 'application/x-arj',
'rar' => 'application/x-rar-compressed',
'hqx' => 'application/mac-binhex40',
'sit' => 'application/x-stuffit',
'bin' => 'application/x-macbinary',
'uu' => 'text/x-uuencode',
'uue' => 'text/x-uuencode',
'latex'=> 'application/x-latex',
'ltx' => 'application/x-latex',
'tcl' => 'application/x-tcl',
'pgp' => 'application/pgp',
'asc' => 'application/pgp',
'exe' => 'application/x-msdownload',
'doc' => 'アプリケーション/msword',
'rtf' => 'application/rtf',
'xls' => 'application/vnd.ms-excel',
'ppt' => 'application/vnd.ms-powerpoint',
'mdb' => 'application/x-msaccess',
'wri' => 'application/x-mswrite',
);
?>
php生成excel文档
复制代码
代码如下:
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:filename=test.xls");
「test2tn」をエコーします。
エコー「test1t」;
「test2tn」をエコーします。
エコー「test1t」;
「test2tn」をエコーします。
//改相应文件头就可出出.doc .xls等文件格式了
?>
比较时间问题
举一个例子例子:比如比如一个论坛论坛对当天用用用
//$db->rows[$i][date]中はデータベース库中のdatetimeフィールドです。
$today=time();
$theDay=date("Y-m-d H:i:s",$today-24*3600);

//方法二:
$newTag=$db->rows[$i][date]>=date("Y-m-d 00:00:00")?"

//提取页面と浏览器提交的变量,作用はPHP.INI开了全局变量に相当します
@extract($_SERVER, EXTR_SKIP);
@extract($_SESSION, EXTR_SKIP);
@extract($_POST, EXTR_SKIP);
@extract($_FILES, EXTR_SKIP);
@extract($_GET, EXTR_SKIP);
?>
代码如下:
//ファイルの読み取り関数
function readfromfile($file_name) {
if (file_exists($file_name)) {
$filenum=fopen($file_name,"r"); );
$file_data=fread($filenum, filesize($file_name));
$file_data を返す
コードをコピーします
コードは次のとおりです:
//ファイル書き込み関数
コードは次のとおりです:
//クイックページリダイレクト
functionturntopage($url="index.php",$info = "ページリダイレクト...",$second=) 2){
print "nn
print "n";
print "n"; ;/head>nn";
print "
n"; print " | ||
ページ リダイレクト プロンプト情報 | n"; print "
print "
print " < tr> ;n";
print "
print "
print "
print " n
終了;
?> ) {
$hash = @#@#;
$chars = @#ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz@#; len($chars) - 1;
mt_srand((double)microtime() * 1000000) ;
for($i = 0; $i $hash .= $chars[mt_rand(0, $max)] ;
}
return $hash;
}
?>
文字列の長さを切り取る (この関数は GB2312 で有効です)
コードは次のとおりです:
関数 Wordscut($string, $length,$sss=0) {
if(strlen( $string) > $length) {
if($sss){
$length=$length - 3 ;
$addstr=@# ...@#;
}
for($i = 0; $i if(ord($string[$i]) > 127) {
$wordscut .= $string[$i].$string[$i + 1];
$wordscut .= $string[$i]
}
コードは次のとおりです:
function GetIP(){
if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown"))
$ip = getenv("HTTP_CLIENT_IP"); getEnv( "http_x_forwarded_for")&& strcasecmp( "http_x_forwarded_for")、 "unknown"))) ), "不明"))
$ip = getenv("REMOTE_ADDR");
else if (isset($_SERVER[@#REMOTE_ADDR@#]) && $_SERVER[@#REMOTE_ADDR@#] && strcasecmp($_SERVER[ @#REMOTE_ADDR@#], "不明"))
$ip = $_SERVER[@#REMOTE_ADDR@#];
$ip = "不明"
?>
メールアドレスを決定します
コードをコピーします
ページング (2 つの関数を一緒に使用します)
コードをコピーします
if($rs = mysql_fetch_array($result)) $sums = $rs[0];
$totalpage = ceil($sums/$ page_size);
if((! $page)($page<1)) $page=1;
$startpos = ($page-1)*$page_size;
$sql .=" 制限 $startpos,$page_size " ;
$sql を返す
}
関数 showbar($string="")
{
global $page,$totalpage;
$out="Total". $totalpage."page";
$linkNum =4;
$start = ($page-round($linkNum/2))>0 ? ($page-round($linkNum/2)) : "1"
$end = ($page+round($linkNum/2))$prestart =$start-1;
if($page<>1)
$out .= "最初のページ ";
if($start>1)
$out.="..<< ";
for($t=$start;$t<=$end;$t++)
{
$out .= ($page= = $t) "[".$t."] " : " $t ";
}
if($end<$totalpage)
$out.="< ; a href=@#?page=".$nextend."&&".$string."@# title=次のページ>>>..";
if($page<> ; $totalpage)
$out .= " last page"; out;
}
?>
コードをコピーします
コードは次のとおりです:
//現在のスクリプト URL を取得します
>
$scriptName = $ _SERVER["REQUEST_URI"]
}else{
コードをコピーします
コードは次のとおりです:
for( $i=0;$i<=9;$i++) $fnum = str_replace($nums[ $i],$fnums[$i],$fnum);
$fnum = ereg_replace("[^0-9. ]|^0{1,}","",$fnum);
if($fnum ==="") $fnum=0;
return $fnum;
}
?>
コードをコピーします
コードは次のとおりです:
//HTML タグを削除します
function Text2Html($txt){
$txt = str_replace(" "," ",$txt); ,$txt);
$txt = str_replace(">",">>,$txt);
$txt = preg_replace("/[rn]{1,}/isU","
rn",$ txt);
return $txt;
?> feed_url) {
preg_match('/(http|https|ftp):///', $feed_url, $protocol); http|https|ftp|news):///" , "", $feed_url);
$server_url = preg_replace("//.*/", "", $server_url);
if ($server_url == ' ') {
}
コードは次のとおりです:
//すべてのリンクを取得します
< ?
function get_all_url($code){
preg_match_all('/< as+href=["|']?([^>"' ]+)["|']?s*[^>]* >([^>]+)/ i',$code,$arr);
return array('name'=>$arr[2],'url'=>$arr) [1]);
}
?>
コードをコピーします
コードは次のとおりです:
//HTML タグを削除します
$table = preg_replace("' <[/!]*?[^<>]*?>'si" ,"",$table);
//空白文字を削除
$table = preg_replace("'([rn])[ s]+'","",$table);
$table = str_replace(" ", "",$table);
$table = str_replace(" ","",$table);
$table = 爆発(",{tr}",$table);
return $ table;
function get_td_array($ table) {
$table = preg_replace("'