熟妇人妻一区二区-蜜臀av精一区二区三区-一区二区三区日韩在线观看-一本色道久久爱综合网-欧美日韩中文字幕在线一区二区-日韩精品人妻中文字幕视频免费看-国产精品久久久久久久久li-吊视频一区二区三区在线-国产在线观看一区二区三区,亚洲电影中文不卡av,丰满的人妻在线视频,久久免费看女人

廣東福建浙江江蘇上海北京山東遼寧江西河南四川湖北湖南廣西安徽黑龍江天津重慶吉林河北貴州甘肅山西云南新疆寧夏海南陜西西藏青海內(nèi)蒙古

新聞中心

其他功能
發(fā)布時(shí)間:2014-10-11 23:23:34
5.1 生成圖像

PHP可以操作處理圖像。如果你已經(jīng)安裝了GD庫(kù),你甚至可以利用PHP生成圖像。
Header("Content-type: image/gif");
$string=implode($argv," ");
$im = imagecreatefromgif("images/button1.gif");
$orange = ImageColorAllocate($im, 220, 210, 60);
$px = (imagesx($im)-7.5*strlen($string))/2;
ImageString($im,3,$px,9,$string,$orange);
ImageGif($im);
ImageDestroy($im);
?>
(譯者注:以上代碼段缺少注釋,請(qǐng)讀者參考PHP Manual的圖像處理函數(shù)部分)
這段代碼在其他頁(yè)面中通過(guò)以下標(biāo)記調(diào)用,然后以上的那段button.php3代碼取得text值并在另外取得的圖像文件中加上該值--在以上的代碼中該圖像文件是images/button1.gif--最后輸出到瀏覽器。假如你想在表單域中使用圖像按鈕,但是又不希望在每次按鈕上的文字改變后不得不重新生成新的圖像,就可以利用這樣簡(jiǎn)單的方法動(dòng)態(tài)生成圖像文件。

5.2 Cookies

PHP支持基于HTTP的cookies。在需要時(shí)你可以像使用一般變量一樣方便的使用cookie。Cookies是瀏覽器保存于客戶端的一些信息片段,由此你可以知道是否一臺(tái)特定PC上的任何人都訪問(wèn)過(guò)你的站點(diǎn),瀏覽者者在你的站點(diǎn)上的蹤跡等等。使用cookies的典型例子就是對(duì)瀏覽者偏好的甄別。Cookies由函數(shù)setcookie()設(shè)定。與輸出HTTP標(biāo)頭的函數(shù)header()一樣,setcookie()必須在任何實(shí)際內(nèi)容杯輸出到瀏覽器之前調(diào)用。以下是一個(gè)簡(jiǎn)單例子:
if (empty($VisitedBefore))
{
// 如果沒有設(shè)定cookie,為cookie賦上當(dāng)前時(shí)間值
// 函數(shù)中的最后一個(gè)參數(shù)聲明了該cookie保存的時(shí)間
// 在這個(gè)例子中是1年
// time()函數(shù)返回自1970年1月1日以來(lái)的以秒數(shù)計(jì)的時(shí)間
SetCookie("VisitedBefore",time(), time()+(60*60*24*365));
}
else
{
// 歡迎瀏覽者再次光臨
echo "Hello there, welcome back
";
// 讀取cookie并判斷
if ( (time() - $VisitedBefore) >= "(60*60*24*7)" )
echo "Why did you take a week to come back. You should be here more often!? ";
}
?>

5.3 基于HTTP驗(yàn)證

基于HTTP驗(yàn)證當(dāng)PHP以CGI模式運(yùn)行時(shí)不能實(shí)現(xiàn)。我們可以使用函數(shù)header()發(fā)送HTTP標(biāo)頭強(qiáng)制驗(yàn)證,客戶端瀏覽器則彈出供輸入用戶名和密碼的對(duì)話框。這兩個(gè)變量被儲(chǔ)存在$PHP_AUTH_USER和$PHP_AUTH_PW中,你可以使用這兩個(gè)變量驗(yàn)證合法并允許進(jìn)入。以下的例子通過(guò)用戶名稱/密碼對(duì)為tnc/nature的驗(yàn)證一名用戶的登錄:
if(!isset($PHP_AUTH_USER))
{
Header("WWW-Authenticate: Basic realm="My Realm"");
Header("HTTP/1.0 401 Unauthorized");
echo "Text to send if user hits Cancel button ";
exit;
}
else
{
if ( !($PHP_AUTH_USER=="tnc" && $PHP_AUTH_PW=="nature") )
{
// 如果是錯(cuò)誤的用戶名稱/密碼對(duì),強(qiáng)制再驗(yàn)證
Header("WWW-Authenticate: Basic realm="My Realm"");
Header("HTTP/1.0 401 Unauthorized");
echo "ERROR : $PHP_AUTH_USER/$PHP_AUTH_PW is invalid.";
exit;
}
else
{
echo "Welcome tnc!";
}
?>
事實(shí)上再實(shí)際引用中不大可能如上面使用代碼段明顯的用戶名稱/密碼對(duì),而是利用數(shù)據(jù)庫(kù)或者加密的密碼文件存取它們。

5.4 文件上傳

你可以利用PHP實(shí)現(xiàn)文件的功能,注意客戶端的瀏覽器應(yīng)該是Netscape3以上或者IE3以上。以下就是該功能的簡(jiǎn)單演示:
( upload.html ):


Upload Your File


ENCTYPE="multipart/form-data" METHOD=POST>
NAME="MAX_FILE_SIZE" VALUE="2000000">
NAME="uploadfile" SIZE="24" MAXLENGTH="80">



NAME="sendit">
NAME="cancelit">


(You may notice a slight
delay while we upload your file.)




下面是處理上傳的文件:
( receiver.php3 ):
function do_upload ()
{
global $uploadfile, $uploadfile_size;
global $local_file, $error_msg;
if ( $uploadfile == "none" )
{
$error_msg = "You did not specify a file for uploading.";
return;
}
if ( $uploadfile_size > 2000000 )
{
$error_msg = "Sorry, your file is too large.";
return;
}
$the_time = time ();
// 你需要對(duì)以下目錄有寫權(quán)限
$upload_dir = "/local/uploads";
$local_file = "$upload_dir/$the_time";
if ( file_exists ( ’$local_file’ ) )
{
$seq = 1;
while ( file_exists ( "$upload_dir/$the_time$seq" ) ) { $seq++; }
$local_file = "$upload_dir/$the_time$seq";
};
rename ( $uploadfile, $local_file );
display_page ();
}
function display_page ()
{
// 這里是你的頁(yè)面內(nèi)容
}


php3 Receiving Script


if ( $error_msg ) { echo "$error_msg

"; }
if ( $sendit )
{
do_upload ();
}
elseif ( $cancelit )
{
header ( "Location: $some_other_script" );
exit;
}
else
{
some_other_func ();
}
?>



5.5 常用函數(shù)

我們簡(jiǎn)單來(lái)看看一些常用的函數(shù)。

數(shù)組


array - 生成數(shù)組
count - 數(shù)組元素個(gè)數(shù)
sort - 數(shù)組排序,另有其他幾種排序函數(shù)可供使用
list - 列出數(shù)組元素
each - 返回下一個(gè)key/value對(duì)
current - 返回當(dāng)前數(shù)組元素
next,prev - 傳回當(dāng)前數(shù)組元素前后指針



日期和時(shí)間

checkdate - 驗(yàn)證日期/時(shí)間格式
date - 生成日期/時(shí)間格式
time - 當(dāng)前時(shí)間信息
strftime - 格式化日期/時(shí)間

目錄、文件系統(tǒng)

chdir - 改變目錄
dir - 目錄類別
opendir, readdir, closedir - 開啟、讀取、關(guān)閉目錄
fopen, fclose - 開啟、關(guān)閉文件
fgets, fgetss - 逐行讀取內(nèi)容
file - 將整個(gè)文件讀入一個(gè)數(shù)組變量中

正則表達(dá)式

ereg - 匹配正則表達(dá)式
eregi - 大小寫非敏感匹配正則表達(dá)式
ereg_replace -匹配正則表達(dá)式并替換
eregi_replace -大小寫非敏感匹配正則表達(dá)式并替換
split - 依規(guī)則切開字符串并以數(shù)組形勢(shì)存儲(chǔ)



字符串

AddSlashes - 加上斜杠后使用字符串
echo - 輸出一個(gè)或多個(gè)字符串
join, implode - 將數(shù)組元素合并為字符串
htmlentities, htmlspecialchars - 將HTML特殊字符轉(zhuǎn)換為HTML標(biāo)記形式
split - 依規(guī)則切開字符串并以數(shù)組形勢(shì)存儲(chǔ)
5.6 擴(kuò)展我們的范例主頁(yè)

我們將使用以上提到的一些函數(shù)和思想為我們的范例主頁(yè)添加更多的動(dòng)態(tài)內(nèi)容。我們可以在每個(gè)頁(yè)面的頂部加上導(dǎo)航欄,同時(shí)使得當(dāng)前頁(yè)自動(dòng)的不被鏈接顯示;同時(shí)還可以添加一個(gè)用戶驗(yàn)證表單以便上傳音樂(lè)、圖像等文件并自動(dòng)更新頁(yè)面。

導(dǎo)航欄

實(shí)際上就是在footer.inc文件中加上一段代碼。假設(shè)你的web站點(diǎn)中所有后綴為.php3的文件都會(huì)出現(xiàn)在導(dǎo)航欄中,以下就是被存為include/navbar.inc的代碼:
/* 輸出該導(dǎo)航欄,鏈接所有除當(dāng)前頁(yè)的站內(nèi).php3文件 */
# 讀取目錄
$d = dir("./");
echo "

| ";
while($entry = $d->read())
{
// 忽略無(wú)文件情況
if ( !is_file($entry) )
continue;
/* 將文件名與擴(kuò)展名分開。由于.是正則表達(dá)式特殊字符,應(yīng)該用引出 */
list($filenm, $fileext) = split(".",$entry, 2);
// 忽略非.php3文件情況
if( $fileext != "php3" )
continue;
/* 現(xiàn)在我們已經(jīng)把.php3文件都選出,下面搜尋文件中的第一行(標(biāo)題)
類似$title="something";
并將以上標(biāo)題內(nèi)容分開,用作鏈接文字 */
$linknm = "";
$fp=fopen($entry,"r");
while($buffer=fgets($fp, 4096))
{
$buffer = trim($buffer);
// 我們已經(jīng)把每個(gè)文件的標(biāo)題放在文件的第一行以便搜索
// 但是當(dāng)你改變變量名稱時(shí)可能會(huì)帶來(lái)****煩
if (ereg("title *= *"", $buffer))
{
/* 我們已經(jīng)取得了標(biāo)題內(nèi)容并可以在此基礎(chǔ)上
進(jìn)行去除空格等處理。
必須以PHP代碼方式處理,比如$title = "blah blah" */
eval($buffer);
// 然后將鏈接文字顯示為標(biāo)題文字
$linknm = $title;
break;
}
}
fclose($fp);
if ( $entry == basename($PHP_SELF) )
echo "$linknm";
else
echo "$linknm";
echo " | ";
}
$d->close();
echo "

";
?>

照片收藏夾

我們將引用基于HTTP的驗(yàn)證、文件系統(tǒng)函數(shù)和文件上傳功能維護(hù)放置圖像文件的目錄。
同時(shí)我們需要建立一個(gè)可以列出在該目錄下所有照片的頁(yè)面。

文件上傳
include("include/common.inc");
// 我們?cè)谶@里再做一次用戶驗(yàn)證
if(!isset($PHP_AUTH_USER))
{
Header("WWW-Authenticate: Basic realm="$MySiteName"");
Header("HTTP/1.0 401 Unauthorized");
echo "Sorry, you are not authorized to upload files ";
exit;
}
else
{
if ( !($PHP_AUTH_USER==$MyName && $PHP_AUTH_PW==$MyPassword ) )
{
// 如果是錯(cuò)誤的用戶名稱/密碼對(duì),強(qiáng)制再次認(rèn)證
Header("WWW-Authenticate: Basic realm="My Realm"");
Header("HTTP/1.0 401 Unauthorized");
echo "ERROR : $PHP_AUTH_USER/$PHP_AUTH_PW is invalid.

";
exit;
}
}
if ( $cancelit )
{
// 當(dāng)瀏覽者按下"取消"按鈕則轉(zhuǎn)向首頁(yè)面
header ( "Location: front_2.php3" );
exit;
}
function do_upload () {
global $userfile, $userfile_size, $userfile_name, $userfile_type;
global $local_file, $error_msg;
global $HTTP_REFERER;
if ( $userfile == "none" ) {
$error_msg = "You did not specify a file for uploading.";
return;
}
if ( $userfile_size > 2000000 )
{
$error_msg = "Sorry, your file is too large.";
return;
}
// Wherever you have write permission below...
$upload_dir = "photos";
$local_file = "$upload_dir/$userfile_name";
if ( file_exists ( $local_file ) ) {
$error_msg = "Sorry, a file with that name already exists";
return;
};
// 你還可以由此檢查文件名稱/類型對(duì)以確定是何種文件:gif,jpg,mp3…
rename($userfile, $local_file);
echo "The file is uploaded
";
echo "Go Back
";
}
$title = "Upload File";
include("include/header.inc");
if (empty($userfile) || $userfile=="none")
{
// 輸出以下表單
?>
" ENCTYPE="multipart/form-data" METHOD=POST>









(You may notice a slight delay while we upload your file.)
} else {
if ( $error_msg ) { echo "$error_msg

"; }
if ( $sendit ) {
do_upload ();
}
}
include("include/footer.inc");
?>

照片圖庫(kù)


include("include/common.inc");
$title = "Gallery";
include("include/header.inc");
?>


Here are some of our family photos. This PHP script can really
be made better, by splitting into multiple pages.


$d = dir("photos");
while($entry = $d->read())
{
if (is_file("photos/$entry"))
echo " ";
}
$d->close();
?>
include("include/footer.inc");
?>

另外,你可以在文件上傳的表單中加上一個(gè)輸入元素去描述該上傳的文件。這個(gè)元素將被存儲(chǔ)在文件中,然后被以上的照片圖庫(kù)的那段代碼所讀出并顯示出來(lái)。



相關(guān)說(shuō)明: 您可以通過(guò)電話:020-85421558 與我們聯(lián)系,我們會(huì)根據(jù)您所從事的行業(yè)領(lǐng)域和網(wǎng)站類型,在最短的時(shí)間內(nèi)請(qǐng)我們的營(yíng)銷顧問(wèn)與您預(yù)約后上門拜訪您,直接面談交流為您解答所有的網(wǎng)站建設(shè)疑問(wèn)。
国产自产拍高清av-久久久久国产精品中文字幕-久久99性生活-亚洲精品日韩中文字幕在线 | 日本熟女五十路巨尻-日韩视频在线播放一区二区-黄色片黄色片黄色片亚洲黄色片-天堂网2016天堂 | 开心五月六月丁香伊人-国外黄色网在线观看-亚洲精品av日韩-久久在线爱爱视频 | 天天操天天干天天日天天操-人妻少妇久久久一区二区三区-日韩男女三级视频-国产又粗又猛又爽又黄的黄牛视频 | 国产视频一区二区三区网址-亚洲中文字幕粉嫩蜜乳av-欧洲精品免费观看mv在线观看-二区日韩三区日韩 | 精品视频蜜桃久久久久-日韩美免费观看视频-精品99国产乱码久久久久密-久久久久久亚洲女同第一区暖暖 | 人人妻人人澡人人爽久久-99久久99久久精品国产片果冰-日韩亚洲丝袜在线-久久99成人精品 | 1024手机看片欧美日韩-久久三级人妻熟妇-欧美日韩亚洲第六页-av日韩在线观看网站 | 日韩激情视频免费看-欧美黑人xxxx黑人最猛-午夜久久桃色福利-国产精品999网站 | 欧美日韩激情伦理故事不卡一区二区-日韩欧美国产视频一区二区在线观看-国产成人精品激情视频-免费色婷婷在线视频 | 日韩天天综合网久久天天综合精品-欧美激情视频区一区二区三在线-九九热国产在线经典-69国产亚洲精品成人av久久 | 久久草视频在线播放-日韩在线亚洲一区-久久精品国产77777蜜臀-最新中文中文字幕 | 99re国产在线精品-国产av一区二区三区日韩接吻-久久久久久国产精品免费免费中文-久久久久久久久久97国产 | 亚洲成年人在线天堂-人妻精品久久久久中文字幕偷-日韩少妇之情色-日韩在线1区2区3区 | 超碰223天天操-亚洲中文不卡高清av-日本一区二区三区高清不卡-91久久久精品国产 | 国产日本久久中文字幕-中文字幕成人免费观看-91久久精品国产原创91久久-99精品视频在线观看视频在线 | 麻豆免费在线观看高清视频-日本中文字幕在线观看电影-日韩情趣视频在线观看-成人激情av在线免费观看 | 97超碰免费人人澡-中文字幕久久免费-国产成人av亚洲精品久久久久-精品久久久久久久人妻蜜臀av | 亚洲天堂男人网亚洲天堂女人网-亚洲精品久久中文字幕xx-久久久久久久精美人妻-国产激情黑人91蜜 天天操天天干天天日天天操-人妻少妇久久久一区二区三区-日韩男女三级视频-国产又粗又猛又爽又黄的黄牛视频 | 亚洲 熟女 久久-日韩一区二区三区四区五区六区七区-97人妻一区二区三区一区-亚洲欧美成人自拍偷拍 | 丰满熟女一区二区三区四区黑色的-成人91免费在线观看-亚洲国产av一级大全-久久久男人的性感天堂 99精品久久99久久久久一-日韩三级a视频在线观看-国产精品99精品免费视频-日日夜夜有免费视频观看 | 欧美日韩激情伦理故事不卡一区二区-日韩欧美国产视频一区二区在线观看-国产成人精品激情视频-免费色婷婷在线视频 | 国产麻豆成人av精品网站-亚洲欧美日本韩国乱片-97久久碰人妻一区二区-日韩精品中文字幕在线视频 神马午夜久久久av-中文日韩av在线免费观看-日韩欧美一级一区二区-国产激情在线视频免费 | 国内一区二区三区精品-91老司机精品在线-91久久精品丝袜-丁香六月天久久婷婷 | 日韩一级黄片视频播放-日韩区欧美区一区二区三区-www日韩精品视频-无套内射人妻19p | 日韩精品成人亚洲欧美在线-日韩av高清在线不卡免费观看-日韩av电影观看-国产乱子伦一区二区内容 森泽佳奈中文字幕在线-人妻丰满少妇久久久久久久久-久久熟妇人妻一区二区-av中文字幕网 | 91精品国产91久久久久久最新-久久美剧在线观看-91免费看欧美-中文字幕一区二区三区三区 | 欧美日韩国产综合视频在线观看-久久中文字幕完整版-久久99热免费最新版-日韩女v在线观看视频播放 | 色婷婷激情五月综合-日韩欧美情色片-日韩av在线观看不卡-蜜桃系列一区二区三区 | 伊人久久久av老熟妇二区三区-日本国产欧美在线视频一区-国产又粗又黄又硬视频-久久久久精品一区二区三区不卡 | 精品自拍美女视频色-五月开开婷婷综合久久-精品人妻一区二区免费蜜桃视频-六月婷婷不卡的 | 超碰人妻黑人中文版-18岁成年人黄色片-日韩在线一区第一页-91精品国产高清久久久久久久久 | 日韩欧美p久久内射-日本人精品一区二区-69精品麻豆性色aⅴ人妻斩-久久久91精品国产极品美女 | 中文字幕熟女人妻丝袜在线-午夜精品久久久久久久精品乱码开元-聚伦 人妻 少妇 中文字幕-久久久久人妻一区精品色戒 | 99久久生活综合精品-国产日韩欧美一区二区综合-99久久免费精品国产男女性高-日本少妇人妻一区 | 天天日天天操天天拍天天射-人妻熟女aⅴ中文字幕在线看-国产精品97久久-日韩人妻综合一区二区 | 国产精品久久久久最猛-日韩精品在线观看视频在线-97人妻一区二区三区蜜桃-日韩成人小视频 | 中文字幕人成乱码熟女-久久久久黑人强伦奸人妻-日韩中文字幕乱码一-婷婷免费精品视频在线 | 日韩一级黄片视频播放-日韩区欧美区一区二区三区-www日韩精品视频-无套内射人妻19p | 六月婷婷丁香网-欧美高清一区三区在线专区-亚洲国产日产中文视频-国产又粗又猛又硬又爽的视频 | 色狠狠久久av五月综合-蜜臀人妻中文字幕一区二区-91精品一区二区三区4区蜜桃-久久99热国家这里只有精品 |
上一篇:從實(shí)例開始       下一篇:PHP入門

提供全國(guó)各地網(wǎng)站建設(shè)服務(wù)

上海北京深圳廣州天津南京大連杭州沈陽(yáng)成都東莞濟(jì)南佛山無(wú)錫長(zhǎng)沙武漢寧波長(zhǎng)春蘇州青島珠海大慶福州廈門常州鄭州煙臺(tái)西安合肥南寧重慶東營(yíng)昆明威海中山南昌紹興太原惠州溫州徐州揚(yáng)州淄博鎮(zhèn)江鞍山保定銀川南通洛陽(yáng)嘉興臺(tái)州桂林貴陽(yáng)蘭州盤錦漳州黃石唐山濰坊湘潭肇慶吉林江門?株洲泉州泰州包頭柳州德州韶關(guān)寶雞金華鹽城新鄉(xiāng)十堰廊坊玉溪濟(jì)寧滄州蕪湖湖州梧州泰安安陽(yáng)遼陽(yáng)舟山梅州常德三明連云港哈爾濱秦皇島馬鞍山石家莊呼和浩特

 
備案系統(tǒng)認(rèn)證 舉報(bào)不良網(wǎng)站 我們的支付方式 AAA級(jí)信用
廣州萬(wàn)戶網(wǎng)絡(luò)信息科技有限公司 旗下網(wǎng)站建設(shè)品牌:萬(wàn)戶網(wǎng) www.9z001.com 版權(quán)所有 ©2000-2019 All Rights Reserved
網(wǎng)站備案編號(hào):粵ICP備15049595號(hào) 地址:廣州市番禺區(qū)大石街北聯(lián)圍仔工業(yè)路2號(hào)E座305
電話:020-85421558   傳真:020-88140140   郵編:510515