仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 929|回复: 19
打印 上一主题 下一主题

[学习教程] PHP网页设计PHP的其他功效

[复制链接]
莫相离 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-2-3 23:54:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
建议大家买一本书,而不光是在网上看一些零碎的资料,一本书毕竟会讲的系统一些,全面一些,而且印刷的书不受电脑的限制,但是建议在看书的时候最好旁边有电脑,这样可以很及时地上机实践。   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()必需在任何实践内容杯输入到阅读器之前挪用。以下是一个复杂例子:
<?
if (empty($VisitedBefore))
{
// 假如没有设定cookie,为cookie赋受骗前工夫值
// 函数中的最初一个参数声了然该cookie保留的工夫
// 在这个例子中是1年
// time()函数前往自1970年1月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 button\n";
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 files\n";
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,mp3…
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");
?>

别的,你可以在文件上传的表单中加上一个输出元素去描写该上传的文件。这个元素将被存储在文件中,然后被以上的照片图库的那段代码所读出并显示出来。最近陆续的有人问我学习php的心得,现在整理为下面,希望可以对大家有些帮助。
飘飘悠悠 该用户已被删除
沙发
发表于 2015-2-4 06:58:02 | 只看该作者
开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。
金色的骷髅 该用户已被删除
板凳
发表于 2015-2-6 16:00:17 | 只看该作者
这些都是最基本最常用功能,我们这些菜鸟在系统学习后,可以先对这些功能深入研究。
小女巫 该用户已被删除
地板
发表于 2015-2-7 18:52:19 | 只看该作者
兴趣是最好的老师,百度是最好的词典。
若天明 该用户已被删除
5#
发表于 2015-2-7 19:00:23 | 只看该作者
php里的数组为空的时候是不能拿来遍历的;(这个有点低级啊,不过我刚被这个边界问题墨迹了好长一会)
精灵巫婆 该用户已被删除
6#
发表于 2015-2-28 04:38:21 | 只看该作者
因为blog这样的可以让你接触更多要学的知识,可以接触用到类,模板,js ,ajax
分手快乐 该用户已被删除
7#
发表于 2015-3-6 14:08:58 | 只看该作者
当留言板完成的时候,下步可以把做1个单人的blog程序,做为目标,
深爱那片海 该用户已被删除
8#
发表于 2015-3-13 00:49:33 | 只看该作者
对于初学者来说不推荐去拿钱买的。当然如果一个网站你经常去用,而且里面的资料也比较有用,最好还是买个会员比较好,毕竟那些也是别人的工作成果。
愤怒的大鸟 该用户已被删除
9#
发表于 2015-3-17 23:06:56 | 只看该作者
我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。
灵魂腐蚀 该用户已被删除
10#
发表于 2015-3-25 04:39:33 | 只看该作者
你很难利用原理去编写自己的代码。对于php来说,系统的学习我认为还是很重要的,当你有一定理解后,你可你针对某种效果研究,我想那时你不会只是复制代码的水平了。
兰色精灵 该用户已被删除
11#
发表于 2015-3-27 06:11:14 | 只看该作者
我还是强烈建议自己搭建php环境。因为在搭建的过程中你会遇到一些问题,通过搜索或是看php手册解决问题后,你会更加深刻的理解它们的工作原理,了解到php配置文件中的一些选项设置。
爱飞 该用户已被删除
12#
发表于 2015-3-30 16:09:00 | 只看该作者
对于懒惰的朋友,我推荐php的集成环境xampp或者是wamp。这两个软件安装方便,使用简单。但是我还是强烈建议自己动手搭建开发环境。
蒙在股里 该用户已被删除
13#
发表于 2015-4-26 17:09:36 | 只看该作者
曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线  \\\\\\\'_\\\\\\\' ;
只想知道 该用户已被删除
14#
发表于 2015-5-1 23:10:37 | 只看该作者
Ps:以上纯属原创,如有雷同,纯属巧合
第二个灵魂 该用户已被删除
15#
发表于 2015-5-2 01:31:19 | 只看该作者
装在C盘下面可以利用windows的ghost功能可以还原回来(顺便当做是重转啦),当然啦我的编译目录要放在别的盘下,不然自己的劳动成果就悲剧啦。
乐观 该用户已被删除
16#
发表于 2015-6-6 05:13:39 | 只看该作者
其实没啥难的,多练习,练习写程序,真正的实践比看100遍都有用。不过要熟悉引擎
再现理想 该用户已被删除
17#
发表于 2015-6-6 14:31:23 | 只看该作者
本人接触php时间不长,算是phper中的小菜鸟一只吧。由于刚开始学的时候没有名师指,碰过不少疙瘩,呗很多小问题卡过很久,白白浪费不少宝贵的时间,在次分享一些子的学习的心得。
谁可相欹 该用户已被删除
18#
发表于 2015-6-6 17:25:16 | 只看该作者
如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了,
莫相离 该用户已被删除
19#
 楼主| 发表于 2015-6-22 23:22:52 | 只看该作者
首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。
小魔女 该用户已被删除
20#
发表于 2015-6-24 22:17:38 | 只看该作者
开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-9-21 03:31

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表