ホームページ > バックエンド開発 > PHPチュートリアル > 一般的な PHP 関数を保存する

一般的な PHP 関数を保存する

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-13 13:18:17
オリジナル
659 人が閲覧しました

一般的な PHP 関数のコレクション
最近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 (getenv("REMOTE_ADDR")); getenv ("REMOTE_ADDR");
else
$ip = "Unknown";
return $ip;

詳細なソース参照: http: // /www.jb51.net/article/22199.htm


function DateAdd($date, $int, $unit = "d") { //Increase時間 (時、分、秒を増やすこともでき、時間があるときに追加できます)
$dateArr =explode("-",
$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) { //指定された日付の曜日を計算します
$ dateArr =explode("-", $date);
return date("w", mktime(0,0,0,$dateArr[1],$dateArr[2],$dateArr[0]));
}
?>
詳細なソース参照: http://www.jb51.net/article/22199.htm

$dateArr =explode("-", $date)
if (is_numeric($dateArr[0]) && is_numeric($dateArr[1]) && is_numeric ($dateArr[2])) {
return checkdate( $dateArr[1],$dateArr[2],$dateArr[0]);
return
}
function check_time($time) { //時間が正しいかどうかをチェックします
$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))
true を返す
else
return false;
}
return false;
}
詳細なソース参照: http://www.jb51.net/article/22199.htm


関数 DateDiff ($date1, $date2, $unit = "") { //時間比較関数。2 つの日付間の差異を秒、分、時間、または日単位で返します。
switch ($unit) {
case 's' :
$配当 = 1;
ケース 'i':
ケース 'h':
$配当 = 3600 ;
break;
case 'd':
$dividend = 86400;
if ($time1 && $time2); / $dividend;
return false;
}
?>
詳細なソース参照: http://www.jb51.net/article/22199.htm


方法 1: header("Location:index.php");
方法 2: echo "<script>window.location ="$PHP_SELF";</script> 🎜>方法 3: echo "";
?
詳細なソース参照: http://www .jb51.net/article/22199.htm

PHP リダイレクト
次のようにコードをコピーします。
方法 1: header("Location:index.php");
方法 2: echo "window.location ="$PHP_SELF";< ;/script>";
方法 3: echo "";

訪問者のブラウザを取得します
関数は次のとおりです:
{
$browser="";$browserver="";
$Browsers = array("Lynx","MOSAIC","AOL","Opera","JAVA","MacWeb"," WebExplorer","OmniWeb");
$Agent = $GLOBALS["HTTP_USER_AGENT"];
for ($i=0; $i<=7; $i++)
{
if ( strpos($Agent,$Browsers[$i]))
{
$browser = $browserver =""
}
; if (ereg("Mozilla",$Agent) && !ereg("MSIE",$Agent))
{
$temp =explode("(", $Agent); $Part=$temp[0 ];
$temp =explode("/", $browserver=$temp [1];
$temp =explode(" ",$browserver); ;
$browserver =preg_replace("/([d.]+)/","1 ",$browserver);
$browserver = " $browserver"; ;
}
if (ereg("Mozilla",$Agent) && ereg(" Opera",$Agent))
{
$temp =explode("(", $Agent); $Part=$temp[1];
$temp =explode(")", $Part ); $browserver=$temp[1];
$temp =explode(" ",$browserver);ブラウザーver=$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);ブラウザーバー";
$browser = "Internet Explorer";
}
if ($browser!="")
{
$browseinfo = "$browser$browserver";
}
else
{
$browseinfo = "Unknown";
}
return $browseinfo;
}
// $browser=browseinfo() メソッドを直接呼び出します。結果
?>
詳細なソース参照: http://www.jb51.net/article/22199.htm

訪問者のオペレーティング システムを取得します
次のようにコードをコピーします:
関数 osinfo() {
$os="";
if ('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', $ エージェント)) {
$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 = "Unknown";
return $os;
}
//メソッド $os=os_infor()> 🎜 >
詳細なソース参照: http://www.jb51.net/article/22199.htm

ファイル形式クラス
次のようにコードをコピーします:
$ mime_types = array(
'gif' => 'image/gif',
'jpg' => 'image/jpeg',
'jpeg' => 'image/jpeg '、
'jpe' => '画像/jpeg'、
'bmp' => '画像/bmp'、
'png' => '画像/png'、
'tif' => '画像/tiff'、
'tiff' => '画像/tiff'、
'ピクト' => 'image/x-pict',
'pct' => 'image/x-pict',
'tif' => 'image/tiff' => ' image/tiff'、
'psd' => 'image/x-photoshop'、
'swf' => 'application/x-shockwave-flash'、
'js' => 'application/x-javascrīpt',
'pdf' => 'application/pdf',
'ps' => 'application/postscript',
'eps' => 'application/postscript',
'ai' => 'application/postscript'、
'wmf' => 'application/x-msmetafile'、
'css' => 'text/css'、
'htm' => 'text/html',
'html' => 'text/html',
'txt' => 'text/plain',
'xml ' => 'text/xml' 、
'wml' => 'text/wml'、
'wbmp' => 'image/vnd.wap.wbmp'、
'mid' => 'audio/midi'、
'wav' => 'オーディオ/wav'、
'mp3' => 'オーディオ/mpeg'、
'avi' => 'ビデオ/x-msvideo'、
'mpeg' => 'ビデオ/mpeg'、
'mpg' => 'ビデオ/mpeg' 、
'qt' =>ビデオ/クイックタイム'、
'mov' => 'ビデオ/クイックタイム'、
'lha' => 'アプリケーション/x-lha'、
'lzh' => -lha'、
'z' => 'アプリケーション/x-compress'、
'gtar' => 'アプリケーション/x-gtar'、
'gz' => 'アプリケーション/x -gzip'、
'gzip' => 'application/x-gzip'、
'tgz' => 'application/x-gzip'、
'tar' => 'application/x-tar ',
'bz2' => 'application/bzip2',
'zip' => 'application/zip',
'arj' => 'application/x-arj',
'rar' => 'application/x-rar-compressed',
'hqx' => 'application/mac-binhex40',
'sit' => 'application/x-stuffit',
'bin' => 'application/x-macbinary',
「うー」 => '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' => 'application/msword',
'rtf' => 'application/rtf',
'xls' => 'application/vnd.ms-excel',
'ppt' => 'application/vnd.ms-powerpoint',
'mdb' => 'application/x-msaccess',
'wri' => 'application/x-mswrite',
);
?>

详细出处 参考:http://www.jb51.net/article/22199.htm

php生成excel文档
复制代码代码如下:
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:filename=test.xls");
「test1t」をエコー;
「test2tn」をエコー;
「test1t」をエコー;
「test2tn」をエコー;
「test1t」をエコー;
「test2tn」をエコー;
「test1t」をエコー;
「test2tn」をエコー;
「test1t」をエコー;
「test2tn」をエコー;
「test1t」をエコー;
「test2tn」をエコー;
//改相应文件头就可出出.doc .xls等文件格式了
?>

详细出处 参考:http://www.jb51.net/article/22199.htm

時間比较问题
一例一例说明:比如一论坛对当天播表的
方法 1:
を次のように作成します:
//$db->rows[$i][date]中はデータベース库中のdatetimeフィールドです。
$today=time();
$theDay=date("Y-m-d H:i:s",$today-24*3600);
$newTag=$db->rows[$i][date]>=$theDay?"":"";
//方法二:
$newTag=$db->rows[$i][date]>=date("Y-m-d 00:00:00")?"一般的な PHP 関数を保存する?>

复制代网次のとおり:
//引取页面と浏览器引取量、作用はPHP.INI开了全局变量
@extract($_SERVER, EXTR_SKIP);
@extract($_SESSION, EXTR_SKIP);
@extract($_POST, EXTR_SKIP);
@extract($_FILES, EXTR_SKIP);
@extract($_GET, EXTR_SKIP);
@extract($_ENV, EXTR_SKIP);
?>

复制代码代码如下:
//读取文件関数
function readfromfile($file_name) {
if (file_exists($file_name)) {
$filenum=fopen($file_name,"r");
flock($filenum,LOCK_EX);
$file_data=fread($filenum, filesize($file_name));
巻き戻し($filenum);
fclose($filenum);
$file_data を返す;
}
}
?>

复制代码代码如下:
//写入文件関数
function writetofile($file_name,$data,$method="w") {
$filenum=fopen($file_name,$method);
flock($filenum,LOCK_EX);
$file_data=fwrite($filenum,$data);
fclose($filenum);
$file_data を返す;
}
?>

复制代码代码如下:
//页面快速转向
functionturntoppage($url="index.php",$info = "页面转向中...",$second=2){
print "nn页面转向中....n";
print "n";
print "n";
print "nn";
print "

n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print "
n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print " n";
print "
页面转向通知
$info
n";
print " 如果你的浏览器不支持自动跳转、请按这里
n";
print "n";

ランダムな文字列関数を生成します。 >次のようにコードをコピーします:
functionrandom($length) {
$hash = @#@#;
$chars = @#ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz@#; max = strlen($chars) - 1;
mt_srand((double)microtime() * 1000000);
for($i = 0; $i <$length; $i++) {
$ hash .= $chars[mt_rand(0, $max)];
}
return $hash;
}
?>

特定の長さの文字列をインターセプトしますこの関数は GB2312 で有効です)
次のようにコードをコピーします:
function Wordscut($string, $length,$sss=0) {
if(strlen($string) ) > $length) {
if($sss){
$length=$length - 3;
$addstr=@# ...@#; $i = 0; $i if(ord($string[$i]) > 127) {
$wordscut .= $string[$i] string[$ i + 1];
$i++;
} else {
$wordscut .= $string[$i]
}
}
return $wordscut.$ addstr;
}
return $string;
}

コードは次のとおりです。 🎜>function GetIP() {
if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown"))
$ip = getenv("HTTP_CLIENT_IP")
else; if (getenv("HTTP_X_FORWARDED_FOR ") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown"))
$ip = getenv("HTTP_X_FORWARDED_FOR")
else if (getenv("REMOTE_ADDR") && strcasecmp (getenv("REMOTE_ADDR" ), "unknown"))
$ip = getenv("REMOTE_ADDR");
else if (isset($_SERVER[@#REMOTE_ADDR@#]) && $_SERVER[@# REMOTE_ADDR@#] && strcasecmp ($_SERVER[@#REMOTE_ADDR@#], "不明"))
$ip = $_SERVER[@#REMOTE_ADDR@#]
else
$ip = "不明";
return ($ip);
}
?>

メールアドレスを判定
コードは次のとおりです:
関数checkEmail($inAddress)
{
return (ereg("^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a- zA-Z0-9_-])+" ,$inAddress));
}
?>

ページング (2 つの関数を一緒に使用します)

コードは次のとおりです
function getpage ($sql,$page_size=20)
{
global $page,$totalpage,$sums; //out param
$page = $ _GET["page"];
//$ eachpage = $page_size;
$pagesql = strstr($sql," from ");
$pagesql = "select count(*) as ids ". $pagesql;
$result = mysql_query($pagesql );
if($rs = $rs[0]) $sums/$ page_size);
if((!$page) ($page<1)) $page=1;
$startpos = ($page-1)*$sql .= 制限$startpos,$page_size ";
return $sql ;
}
function showbar($string="")
{
global $page,$totalpage;
$out= "total".$totalpage."
$linkNum =4;
$start = ($page-round($linkNum/2))>0 ? ($page-round($linkNum/2)) : "1"; ($linkNum/2))<$totalpage ? ($page+round($linkNum/2)) : $totalpage;
$prestart=$start-1;
if($page<>1)
$out .= "First page ";
if($ start>1)
$out.="..<<< ;/a> ";
for($t=$start;$t<=$end;$t++)
{
$out .= ($page==$t) ? "< font [".$t ."]color=@#red@#>[".$t."]
" : "$t ";
}
if($end<$totalpage)
$out.=">>..";
if($page<> $totalpage)
$out .= " last page"; 🎜> return $out;
}
?>

新しく挿入されたデータの ID を取得します。

mysql_insert_id( );
?>
コードは次のとおりです:
//現在のスクリプト URL を取得します
function get_php_url(){
if(! _server["REQUEST_URI"])) {
$scriptName = $_SERVER["REQUEST_URI"];
$nowurl = $scriptName>}else{
$scriptName = $_SERVER["PHP_SELF" ];
if(空 ($_SERVER["QUERY_STRING"])) $nowurl = $scriptName;
else $nowurl = $scriptName."?".$_SERVER["QUERY_STRING"];
return $nowurl;
}
?>

コードは次のとおりです。
//全角数字を半角数字に変換します
関数 GetAlabNum($fnum){
$nums = array("0","1","2","3","4","5","6","7","8","9"); fnums = "0123456789";
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 = str_replace("<","<",$txt);
$txt = str_replace(">", "> ",$txt);
$txt = preg_replace("/[rn]{1,}/isU","
rn",$txt); >}
?>

コードは次のとおりです:
//相対パスを絶対パスに変換します
function reverse_to_absolute($content, $feed_url) {
preg_match(' /(http|https|ftp):///', $feed_url, $protocol);
$server_url = preg_replace("/(http|https|ftp|news):/// ", "", $ feed_url);
$server_url = preg_replace("//.*/", "", $server_url);
if ($server_url == '') {
return $コンテンツ;
}
if (isset($protocol[0])) {
$new_content = preg_replace('/href="//', 'href="'.$protocol[0]. $server_url.'/' , $content);
$new_content = preg_replace('/src="//', 'src="'.$protocol[0].$server_url.'/', $new_content) ;
} else {
$new_content = $content;
return $new_content;
?> コードをコピーします。以下:
//すべてのリンクを取得
function get_all_url($code){
preg_match_all('/ "' ]+)["|'] ?s*[^>]*>([^>]+)/i',$code,$arr); ('name'=>$arr[2],'url'=>$arr[1]);
}
?> 次のようにコードをコピーします。 >//HTML テーブルの各行を CSV 形式に変換します array
function get_tr_array($table) {
$table = preg_replace("']*? >'si",'"',$table );
$table = str_replace("",'",',$table);
$table = str_replace("< /tr>","{tr}",$ table);
//HTML タグを削除
$table = preg_replace("'<[/!]*?[^<>]*? >'si","",$table) ;
//空白文字を削除
$table = preg_replace("'([rn])[s]+'","",$table);
$table = str_replace(" "," ",$table);
$table = str_replace(" ","",$table);
$table =explode(",{tr}" ,$table);
array_pop($table ;
function get_td_array($table) {
$table = preg_replace("']*?>) ;'si","",$table);
$table = preg_replace("']*?>'si","",$table);
$table = preg_replace("'] *?>si","",$table);
$table = str_replace("","{tr}", $table);
$table = str_replace(" ","{td}",$table);
//HTML タグを削除します
$table = preg_replace("'< [/!]*?[^<>] *?>'si","",$table);
//空白文字を削除
$table = preg_replace("'([rn] )[s]+'","",$table );
$table = str_replace(" ","",$table);
$table = str_replace(" ","",$table) ;
$table =explode('{tr} ', $table);
array_pop($table);
foreach ($table as $key=>$tr) {
$td = 爆発('{td}', $tr);
array_pop($td);
$td_array;
>?>

コード コードをコピーします。
//文字列 $distinct=true 内のすべての単語を返し、重複を削除します。

function split_en_str($str,$? unique=true) {
preg_match_all('/([ a-zA-Z]+)/',$str,$match);
if ($distinct == true) {
$match[ 1] = array_unique($match[1]);
}
sort($match[1]);
}
? >
次のようにコードをコピーします:
// この PHP プロジェクトに貢献した人のリストを出力します
string phpcredits(void)
?>

//現在のスクリプト URL を取得します
function get_php_url(){
if(!empty($_SERVER["REQUEST_URI"])){
$scriptName = $_SERVER["REQUEST_URI "];
$nowurl = $scriptName ;
Else {
$ scriptname = $ _Server ["pHP_SELF"];
if (EMPTY ($ _server ["query_string"]) $ nowUrl = $ スクリプト名
                else $nowurl = $scriptName."?".$_SERVER["QUERY_STRING"];
        }
        return $nowurl;



}
//把全角数字转为半角数字
function GetAlabNum($fnum){
        $nums = array("0","1","2","3","4","5","6","7","8","9");
        $fnums = "0123456789";
        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 = str_replace("<","<",$txt);
$txt = str_replace(">",">",$txt);
        $txt = preg_replace("/[\r\n]{1,}/isU","
\r\n",$txt);
        return $txt;
}


//清除HTML标记
function ClearHtml($str){
        $str = str_replace('<','<',$str);
$str = str_replace('>','>',$str);
        return $str;
}
//相对路径转化成绝对路径
function relative_to_absolute($content, $feed_url) {
    preg_match('/(http|https|ftp):\/\//', $feed_url, $protocol);
    $server_url = preg_replace("/(http|https|ftp|news):\/\//", "", $feed_url);
    $server_url = preg_replace("/\/.*/", "", $server_url); 

    if ($server_url == '') {
        return $content;
    }



    if (isset($protocol[0])) {
        $new_content = preg_replace('/href="\//', 'href="'.$protocol[0].$server_url.'/', $content);
        $new_content = preg_replace('/src="\//', 'src="'.$protocol[0].$server_url.'/', $new_content);
    } else {
        $new_content = $content;
    }
    return $new_content;
}
//取得所有链接
function get_all_url($code){
        preg_match_all('/"\' ]+)["|\']?\s*[^>]*>([^>]+)<\/a>/i',$code,$arr);
        return array('name'=>$arr[2],'url'=>$arr[1]);
}




//获取指定标记中的内容
function get_tag_data($str, $start, $end){
        if ( $start == '' || $end == '' ){
               return;
        }
        $str = explode($start, $str);
        $str = explode($end, $str[1]);
        return $str[0];
}
//HTML表格的每行转为CSV格式数组
function get_tr_array($table) {
        $table = preg_replace("']*?>'si",'"',$table);
        $table = str_replace("",'",',$table);
        $table = str_replace("","{tr}",$table);
        //去掉 HTML 标记




        $table = preg_replace("'<[\/\!]*?[^<>]*?>'si","",$table);
        //去掉空白字符
        $table = preg_replace("'([\r\n])[\s]+'","",$table);
        $table = str_replace(" ","",$table);
        $table = str_replace(" ","",$table); 

        $table = explode(",{tr}",$table);
        array_pop($table);
        return $table;


//HTML テーブルの各行と列を配列に変換し、テーブル データを収集します。
function get_td_array($table) {
$table = preg_replace("']*?> ' si","",$table);
$table = preg_replace("']*?>'si","",$table);
$table = preg_replace ("']*?>'si","",$table);
$table = str_replace("","{tr}",$ table ; !]*?[^<>]*?>'si","",$table);
//空白文字を削除
$table = preg_replace("'([rn] )[ s]+'","",$table);




$table = str_replace(" ","",$table);
$table = str_replace (" ","",$table);
key = & gt; $ tr) {
$ td = Explode ('{td}', $ tr);
Array_pop ($ td); );
$ td_array [] = $ td;
}}}
return $td_array;
}

// 文字列 $distinct=true 内のすべての単語を返します重複
function split_en_str($str,$distinct=true) {
preg_match_all('/([a-zA-Z]+)/',$str,$match);
1]);
}
sort($match[1]);
return $match[1];
}





//ファイル読み取り関数
function PHP_Read($file_name) {
$fd=fopen($file_name,r);
while($bufline=fgets($fd, 4096)){
$buf. =$bufline;
}
fclose($fd);
return $buf;
}
?>






ファイル書き込み関数




//ファイル書き込み関数
function PHP_Write($file_name,$data, $method="w") {
$filenum=@fopen($file_name,$method);
flock($filenum,LOCK_EX);
$file_data=fwrite($filenum,$data);
fclose($filenum);
return $file_data;
}
?>


静的ページ生成関数


/ /静的ページ生成関数
function phptohtm( $filefrom,$fileto,$u2u=1){
if($u2u==1){
$data=PHP_Read($filefrom);
}else{
$data=$filefrom ;
}
PHP_Write($fileto,$data);
return true;
}
?>






条件情報量取得関数を指定




//条件情報量取得関数を指定
function rec_exist($table,$where){
$query="select count(*) as num from $table ".$where;
$result=mysql_query($query) または die(nerror(1) );
$rowcount=mysql_fetch_array($result) );
$num=$rowcount["num"];
if ($num==0){
return false;
}
return $num;
}
?>





ディレクトリ削除関数


// ディレクトリ削除関数
function del_DIR($directory){
$mydir=dir($directory);
while($file=$mydir->read()){
if((( is_dir("$directory/$file")) AND ( $file!=".") AND ($file!="..")){
del_DIR("$directory/$file");
}else{
if(($file!=".") AND ($file!="..")){
unlink("$directory/$file");
//echo "$directory/$ のリンクを解除ファイル OK ";
}
}
}


$mydir->close();
rmdir($directory);
//echo " rmdir $directory ok ";
}
?>



ディレクトリ名正当性検出機能


//ディレクトリ名正当性検出
関数 isen($str){
$ret="";
for($i=0;$i $p=ord(substr($str,$i,1));
if (($p57 & $p90 & $p122){
nerror("仕様を満たしていません!");
}
$ret.=chr($p);
}
return $ ret;
}
?>



ページング関数


//ページング関数
function splitlist($HALT ,$LRLIST) ,$ECHOCNT,$paper,$table,$where,$page_id,$userid){
global $splitstr,$sumcnt;
if($paper=="" || $sumcnt== "") {
$query = "select count(*) as num from $table $where";
$result = mysql_query($query);
$row = mysql_fetch_array($result);
$ sumcnt=$row["num"];
if($sumcnt==0){
nerror("この版にはニュースは掲載されていません!");
}
$paper= 1;
}


$sumpaper=($sumcnt-$sumcnt%$ECHOCNT)/$ECHOCNT;
if(($sumcnt%$ECHOCNT)!=0 ) $sumpaper+ =1;
if($sumpaper==1 && $HALT==0) return($where);
$enwhere=base64_encode(base64_encode($where));
if(( $LRLIST* 2+1) if(($paper-$LRLIST)
$tract=1;
$sub=$LRLIST*2+1 ;
}else if(($paper+$LRLIST) >= $sumpaper){
$tract=$sumpaper-($LRLIST*2);
$sub=$sumpaper;
} else{
$tract=$paper-$LRLIST;
$sub=$paper+$LRLIST;
}
}else{
$tract=1;
$sub=$ sumpaper;
}
$uppaper=$paper-1;
$downpaper=$paper+1;
$startcnt=($paper-1)*$ECHOCNT;
$where 。 ${ startcnt },${ ECHOCNT }";



if($tract > 1) { $splitstr="【 << "; }
else $splitstr ="【 << ";
for($i=$tract;$i<=$sub;$i++){
if ($i!=$paper) $splitstr.= ""。 $i." ";
else $splitstr.="".$i." ";
}
if ($sub!=$sumpaper) $splitstr.=">> ; ]" ;
else $splitstr.=">> ]";
return($where);
}
?>



ページング関数の使用
/*
#### 検索ページング関数####
Int $HALT - 検索結果が 2 つに分割されただけの場合にページ番号 (1/0) を表示するかどうか1 ページ Bar
Int $LRLIST - (ページバーに表示されるページ番号 - 1)/2
Int $ECHOCNT - 検索中に各ページに表示されるレコード数
Int $paper - レコード数ページ、抽出前: $paper= $HTTP_GET_VARS[paper];
Varchar $table - データ テーブル名、事前に添付された値: $table="db.table";
Varchar $where - 検索条件、事前に添付された値: $where="where field ='value'";

Varchar $enwhere - Base64_encode() は元の $where を 2 回エンコードし、GET
Varchar $splitstr の形式で送信します。 - ページ番号バーの出力文字列、関数実行後、対応する位置でエコーを実行 $splitstr;

関数を呼び出す前に変数を取得する必要があります -
$paper=$HTTP_GET_VARS[paper];
$sumcnt=$HTTP_GET_VARS[sumcnt];
$enwhere=$HTTP_GET_VARS[enwhere];

Return (Varchar $where) - ページング後の検索文の検索条件
注: この関数はエラー処理関数 nerror($error);
*/




画像ファイルアップロード関数




//画像ファイルアップロード関数
function Upload_img($UploadFile,$UploadFile_name,$UploadFile_size,$UploadPath,$max_size=64){

//$TimeLimit=60;タイムアウト制限時間を設定します。デフォルトの時間は 30 秒で、0 に設定されます。時間制限はありません
//set_time_limit($TimeLimit);
if(($UploadFile!= "none" )&&($UploadFile != "" )){
$FileName=$UploadPath.$UploadFile_name;
if( $UploadFile_size <1024){
$FileSize="(string)$UploadFile_size" . "Bytes";
}elseif($UploadFile_size <(1024 * $max_size)){



$FileSize=number_format((double)($UploadFile_size / 1024), 1) . " KB";
}else{
nerror("ファイルがサイズ制限を超えています!");
}
//{
//$FileSize="number_format((double)($UploadFile_size" / (1024 * 1024)), 1) . " MB";
// }
if (!file_exists($FileName)){
if(copy($UploadFile,$FileName)){
return "$UploadFile_name ($FileSize)";
}else{
nerror(" ファイル$UploadFile_name のアップロードに失敗しました! ");
}
unlink($UploadFile);
}else{
nerror("ファイル $UploadFile_name はすでに存在します!");
}
//set_time_limit(30); //デフォルトのタイムアウト設定に戻す
}
}




IP アドレスの正当性を判断する方法
if (!strcmp (long2ip(sprintf("%u",ip2long($ip))),$ip)) echo "is ipn";
----

メール正規性判定
eregi( "^[_.0-9a-zA-Z-]+@([0-9a-zA-Z][0-9a-zA-Z_-]+.)+[a-zA-Z]$ ", $email);



IP アドレスとマスクが正当かどうかを確認する例





$ip = '192.168.0.84 ';
$mask = '255.255.255.0';
$network = '192.168.0';
$ip = ip2long($ip);
$mask = ip2long( $mask);
$network = ip2long($network);

if( ($ip & $mask) == $network) echo "有効な IP とマスク";
?>



----



ファイルダウンロードヘッダ出力の設定方法





header("Content-type: application/x-download");
header("Content-Disposition:attachment; filename=$file_download_name;");
header("Accept-Ranges: bytes ");
header("Content-Length: $download_size");
echo 'xxx'



ヘッダーを使用して FTP ダウンロード メソッドを出力し、ブレークポイントによるダウンロードの再開をサポートします
a 例:




header('Pragma: public');
header('Cache-Control: private');
header('キャッシュ制御: キャッシュなし、必須再検証');
header('Accept-Ranges: bytes');
header('Connection: close');
header("Content-Type: audio/mpeg" );
header("Location:ftp://download:1bk3l4s3k9s2@232.2.22.22/2222/Web テクノロジー開発知識ベース/cn_web.rmvb");







通常の中国語一致
ereg("^[".chr(0xa1)."-".chr(0xff)."]+$", $str) ;

テキスト内のハイパーリンクを一括置換





function urlParse($str = ''){
if ( '' == $str) return $str;
$types = array("http", "ftp", "https");

$replace = << ''.htmlentities('1').htmlentities('2').'
EOPHP;


$ret = $str;

while(list(,$type) = each($types) {
$ret = preg_replace("|($type://)([^s]*)|ie ", $replace, $ret);
}



return $ret;
}
?>



ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート