其他功能

转自php中文顾客5. 其他杂项
5.1 生成图像

PHP能够操作管理图像。就算您早已设置了GD库,你还是能运用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);
?>
(译者注:以上代码段缺乏注释,请读者仿照效法PHP Manual的图像管理函数部分)
这段代码在其余页面中通过以下标志<img
src=”button.php3?text”>调用,然后以上的这段button.php3代码获得text值并在别的得到的图像文件中增多该值–在上述的代码中该图像文件是images/button1.gif–最终输出到浏览器。若是你想在表单域中央银行使图像按键,可是又不指望在每回开关上的文字改造后必须要再一次生成新的图像,就能够使用这样轻便的不二秘技动态变化图像文件。

5.2 Cookies

PHP援救基于HTTP的cookies。在急需时您能够像使用相仿变量同样方便的施用cookie。Cookies是浏览器保存于客商端的后生可畏都部队分信息片段,由此你能够知晓是或不是后生可畏台一定PC上的任何人都访谈过你的站点,浏览者者在你的站点上的踪影等等。使用cookies的天下无敌例子正是对浏览者偏爱的甄别。Cookies由函数setcookie(卡塔尔(قطر‎设定。与出口HTTP标头的函数header(卡塔尔同样,setcookie(State of Qatar必须在任何实际内容杯输出到浏览器早先调用。以下是三个归纳例子:
<?
if (empty($VisitedBefore))
{
// 若无设定cookie,为cookie赋上脚下光阴值
// 函数中的尾数参数注脚了该cookie保存的年月
// 在这里个事例中是1年
// time(卡塔尔函数重临自一九六九年11月1日来讲的以秒数计的日子
SetCookie(“VisitedBefore”,time(), time()+(60*60*24*365));
}
else
{
// 应接浏览者再次亲临
echo “Hello there, welcome back<BR>”;
// 读取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验证

基于HTTP验证当PHP以CGI格局运作时不可能促成。大家得以使用函数header(卡塔尔(قطر‎发送HTTP标头强迫验证,顾客端浏览器则弹出供输入顾客名和密码的对话框。这两个变量被储存在$PHP_AUTH_USER和$PHP_AUTH_PW中,你能够选取那五个变量验证合法并允许进入。以下的事例通过顾客名称/密码对为tnc/nature的证实一名客户的登入:
<?
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 buttonn”;
exit;
}
else
{
if ( 澳门新葡萄京官网首页,!($PHP_AUTH_USER==”tnc” && $PHP_AUTH_PW==”nature”) )
{
// 假诺是荒唐的客户名称/密码对,逼迫再作证
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!”;
}
?>
实则再实际援引中十分小恐怕如上边使用代码段分明的顾客名称/密码对,而是选取数据库可能加密的密码文件存取它们。

5.4 文件上传

你能够利用PHP落成公文的效应,注意客商端的浏览器应该是Netscape3以上或然IE3以上。以下就是该意义的简约演示:
( upload.html ):
<HTML>
<HEAD>
<TITLE>Upload Your File</TITLE>
</HEAD>
<BODY>
<FORM ACTION=”receiver.php3″
ENCTYPE=”multipart/form-data” METHOD=POST>
<INPUT TYPE=”HIDDEN”
NAME=”MAX_FILE_SIZE” VALUE=”2000000″>
<INPUT TYPE=”FILE”
NAME=”uploadfile” SIZE=”24″ MAXLENGTH=”80″>
<BR><BR>
<INPUT TYPE=”SUBMIT” VALUE=”Upload File!”
NAME=”sendit”>
<INPUT TYPE=”SUBMIT” VALUE=”Cancel”
NAME=”cancelit”><BR>
</FORM>
<I><FONT SIZE=”2″>(You may notice a slight
delay while we upload your file.)</FONT></I>
</BODY>
</HTML>

上面是拍卖上传的文件:
( 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 ();
// 你须求对以下目录有写权限
$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 ()
{
// 这里是你的页面内容
}
<HTML>
<HEAD>
<TITLE>php3 Receiving Script</TITLE>
</HEAD>
<BODY>
<?
if ( $error_msg ) { echo
“<B>$error_msg</B><BR><BR>”; }
if ( $sendit )
{
do_upload ();
}
elseif ( $cancelit )
{
header ( “Location: $some_other_script” );
exit;
}
else
{
some_other_func ();
}
?>
</BODY>
</HTML>

5.5 常用函数

笔者们大致来看看一些常用的函数。

数组

array – 生成数组
count – 数组成分个数
sort – 数组排序,另有别的两种排序函数可供使用
list – 列出数组元素
each – 重返下二个key/value对
current – 重临当前数组元素
next,prev – 传回当前数组成分前后指针

日期和岁月

checkdate – 验证日期/时间格式
date – 生成日期/时间格式
time – 当前光阴音讯
strftime – 格式化日期/时间

目录、文件系统

chdir – 更动目录
dir – 目录项目
opendir, readdir, closedir – 开启、读取、关闭目录
fopen, fclose – 开启、关闭文件
fgets, fgetss – 逐行读取内容
file – 将全体文件读入三个数组变量中

正则表明式

ereg – 相称正则表明式
eregi – 大小写非敏感相称正则表明式
ereg_replace -相称正则表明式并替换
eregi_replace -大小写非敏感相配正则表明式并替换
split – 依准绳切开字符串并以数组局势存款和储蓄

字符串

AddSlashes – 加上斜杠后接收字符串
echo – 输出二个或多个字符串
join, implode – 将数组成分合并为字符串
htmlentities, htmlspecialchars – 将HTML特殊字符调换为HTML标识格局
split – 依法则切开字符串并以数组时局存款和储蓄
5.6 扩大大家的范例主页

大家将运用上述提到的生龙活虎部分函数和沉凝为大家的轨范主页加多更加多的动态内容。大家得以在各类页面包车型客车顶端加上导航栏,同有时候使妥帖前页自动的不被链接彰显;同一时间还足以加多多少个客商验证表单以便上传音乐、图像等公事并自动更新页面。

导航栏

实在便是在footer.inc文件中加上生机勃勃段代码。倘令你的web站点中颇有后缀为.php3的文件都晤面世在导航栏中,以下便是被存为include/navbar.inc的代码:
<?
/* 输出该导航栏,链接全部除当前页的站内.php3文件 */
# 读取目录
$d = dir(“./”);
echo “<P ALIGN=”CENTER”> | n”;
while($entry = $d->read())
{
// 忽视无文件情形
if ( !is_file($entry) )
continue;
/* 将文件名与强大名分别。由于.是正则表明式特殊字符,应该用引出 */
list($filenm, $fileext) = split(“.”,$entry, 2);
// 忽视非.php3文件情状
if( $fileext != “php3” )
continue;
/* 未来大家已经把.php3文件都选出,上面搜寻文件中的第大器晚成行(标题)
类似$title=”something”;
并将以上标题内容分别,用作链接文字 */
$linknm = “”;
$fp=fopen($entry,”r”);
while($buffer=fgets($fp, 4096))
{
$buffer = trim($buffer);
// 大家已经把各样文件的标题放在文件的第黄金时代行以便查找
// 但是当你改换变量名称时或者会带给大麻烦
if (ereg(“title *= *””, $buffer))
{
/* 大家已经拿到了标题内容并得以在这里幼功上
進展去除空格等拍卖。
必须要以PHP代码格局管理,比如$title = “blah blah” */
eval($buffer);
// 然后将链接文字呈现为标题文字
$linknm = $title;
break;
}
}
fclose($fp);
if ( $entry == basename($PHP_SELF) )
echo “$linknm”;
else
echo “<A HREF=”$entry”>$linknm</A>”;
echo ” | “;
}
$d->close();
echo ” </P>n”;
?>

照片收藏夹

咱俩将引用基于HTTP的认证、文件系统函数和文件上传功用维护放置图像文件的目录。
与此同临时间大家供给构造建设多少个得以列出在该目录下全体照片的页面。

文本上传
<?
include(“include/common.inc”);
// 大家在此再做叁次客商验证
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 filesn”;
exit;
}
else
{
if ( !($PHP_AUTH_USER==$MyName && $PHP_AUTH_PW==$MyPassword ) )
{
// 假使是指鹿为马的顾客名称/密码对,强逼再度验证
Header(“WWW-Authenticate: Basic realm=”My Realm””);
Header(“HTTP/1.0 401 Unauthorized”);
echo “ERROR : $PHP_AUTH_USER/$PHP_AUTH_PW is invalid.<P>”;
exit;
}
}
if ( $cancelit )
{
// 当浏览者按下”打消”按钮则转向首页面
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;
};
// 你仍然为能够透过检查文件名称/类型对以显明是何种文件:gif,jpg,DVD…
rename($userfile, $local_file);
echo “The file is uploaded<BR>n”;
echo “<A HREF=”$HTTP_REFERER”>Go
Back</A><BR>n”;
}
$title = “Upload File”;
include(“include/header.inc”);
if (empty($userfile) || $userfile==”none”)
{
// 输出以下表单
?>
<FORM ACTION=”<? echo “$PHP_SELF”; ?>”
ENCTYPE=”multipart/form-data” METHOD=POST>
<INPUT TYPE=”HIDDEN” NAME=”MAX_FILE_SIZE” VALUE=”2000000″>
<INPUT TYPE=”FILE” NAME=”userfile” SIZE=”24″ MAXLENGTH=”80″>
<BR><BR>
<INPUT TYPE=”SUBMIT” VALUE=”Upload File!” NAME=”sendit”>
<INPUT TYPE=”SUBMIT” VALUE=”Cancel” NAME=”cancelit”><BR>
</FORM>
<I><FONT SIZE=”2″>(You may notice a slight delay while we
upload your file.)</FONT></I>
<?
} else {
if ( $error_msg ) { echo
“<B>$error_msg</B><BR><BR>”; }
if ( $sendit ) {
do_upload ();
}
}
include(“include/footer.inc”);
?>

照片图库

<?
include(“include/common.inc”);
$title = “Gallery”;
include(“include/header.inc”);
?>
<P>
Here are some of our family photos. This PHP script can really
be made better, by splitting into multiple pages.
</P>
<?
$d = dir(“photos”);
while($entry = $d->read())
{
if (is_file(“photos/$entry”))
echo “<IMG SRC=”photos/$entry”>n”;
}
$d->close();
?>
<?
include(“include/footer.inc”);
?>

别的,你能够在文件上传的表单中丰盛一个输入成分去描述该上传的文本。这几个因素将被积累在文书中,然后被上述的照片图库的这段代码所读出并体现出来。

发表评论

电子邮件地址不会被公开。 必填项已用*标注