首页 > 编程技术 > php

php 目录递归函数-列出所文件与目录

发布时间:2016-11-25 16:01

php 目录递归函数-列出所文件与目录

用来实现我的需求。函数的原理很简单,主要就是用了一下递归调用。
function file_list($path){
if ($handle = opendir($path)) {
while (false !== ($file = readdir($handle))) {
if ($file != "." && $file != "..") {
if (is_dir($path."/".$file)) {
echo $path.": ".$file."<br>";//去掉此行显示的是所有的非目录文件
file_list($path."/".$file);
} else {
echo $path.": ".$file."<br>";
}
}
}
}
}

这个函数还可以继续做一些改进,加入一些文件夹或文件的图标什么的

php 实例验证码与登陆实例

<?php
session_start();

if($act == "init")
{
  Header("Content-type: image/png");
  srand(microtime() * 100000);
  $login_check_number = strval(rand("1111","9999"));

  session_register("login_check_number");
  //这里是使用了SESSION来保存校验码.
  //当然也可以用COOKIE
  //setcookie("login_check_number",$login_check_number);
  //然后将第一行的session_start()删除;
  //不推荐使用COOKIE,因为使用COOKIE并不能进行安全的验证.

  $h_img = imagecreate(40,17);
  $c_black = ImageColorAllocate($h_img, 0,0,0);
  $c_white = ImageColorAllocate($h_img, 255,255,255);
  imageline($h_img, 1, 1, 350, 25, $c_black);
  imagearc($h_img, 200, 15, 20, 20, 35, 190, $c_white);
  imagestring($h_img, 5, 2, 1, $login_check_number, $c_white);
  ImagePng($h_img);
  ImageDestroy($h_img);

  die();
}
/*
使用方法:
在HTML文件中加入<input type=text name=number maxlength=4><img alt=使用PHP实现登陆验证码" width=100% src=checkNumber.php?act=init>

在登陆校验PHP页面中加入以下代码(注意:在加入代码前不能有输出,因为使用了SESSION)

//$number 是你输入的校验码的值

include_once("./checkNumber.php");

//检验校验码

if($number != $login_check_number || empty($number))
{
  print("校验码不正确!");
  die();
}
*/
?>
非常全面的一个php技术网站,php 爱好者有相当丰富的文章和源代码.
使用SESSION的问题:
如果打开登陆页在SESSION的失效后才进行登陆,那么登陆会失败.
使用COOKIE的问题:
COOKIE是保存在客户端的,所以如果使用COOKIE的话还不如不用.

针对VBB论坛.保存checkNumber.php后.修改MYSQL数据库template数据表的title 为 logincode forumhome_logincode username_loggedout的template 内容.
然后在member.php的
if ($action=="login")
后加入

  //检验校验码
  include_once("./checkNumber.php");
  if($number != $login_check_number || $number == "")
  {
  print("校验码不正确!");
  die();
  }

php定时自动生成html静态页面
"ob_start()、ob_end_clean()、ob_get_contents()"
ob_start():是打开缓冲区的,就是要把您需要生成的静态文件的内容缓存在这里;
ob_get_contents():是读出缓冲区里的内容,下面有代码为例;
ob_end_clean():这个比较重要,只有使用了这个函数后,缓冲区里的内容才会读取出来;
[复制此代码]CODE:
if(file_exists("./index.htm"))//看静态index.htm文件是否存在
{
time=time();
//文件修改时间和现在时间相差?的话,直接导向htm文件,否则重新生成htm
if(time-filemtime("./index.htm")< 600)
{
header("Location:classhtml/main.htm");
}
}
//在你的开始处加入ob_start();
ob_start();
//首页内容,就是你的动态部分了
//在结尾加入ob_end_clean(),并把本页输出到一个变量中
temp=ob_get_contents();
ob_end_clean();
//写入文件
fp=fopen("./index.htm",'w');
fwrite(fp,temp) or die('写文件错误');
//echo"生成HTML完成!";

SESSION的情况:
  如果窗口A 是已经登陆了的,有SESSION,那么在A 中点击任何一个连接新打开的窗口都是有SESSION。
  从窗口A中,采用window.open()等js方法打开的窗口也都拥有SESSION.
  从窗口A中,点击 文件(F)->新建窗口,这样新建的窗口也有SESSION.
  MyIE中的创建窗口都类似 IE中的在同一窗口点击文件->新建窗口,所以只要输入正确的地址都能取到SESSION
新开窗口取不到SESSION。
  IE,自己手动开启一个新窗口(点击图标,新开一个窗口).这种情况下,即使输入正确的和窗口A一样的地址也取不到SESSION.
  在IE中,打开WebFolder,或者MsOffice等支持HTTP1.1扩展协议的在线编辑的软件,也是取不到SESSION。
总结一下:
  SESSIOn取不到的主要原因是因为http是无状态的通信协议,所以在不同的进程之间无法共享SESSIOn,因为虽然你双击打开的新窗口且输入了同一地址,但是http协议的无状态特性,客户端和服务器都不会主动的去记录他们之间的连接状态.SESSION和COOKIE正是为了明确客户端和服务器之间通信的记录,或者说表明他们之间的关系的这么一种机制..
  你可以把SESSION / COOKIE的这种机制想象成为 京客隆超市 的会员卡. 你有这张会员卡,售货员就能知道你是什么级别的会员,商品应该按照什么样的会员价格卖给你.
  SESSION的处理方式比较多. PHP默认的处理机制是采用在服务器段保存以SESSION_ID的方式保存SESSION.  
  可以这么理解,超市只给了你一个ID卡,你的所有信息都是存放在超市的电脑里,而不是一张IC卡,信息存在卡片里.因为超市的分店之间没有联网,所以你的ID卡,就不能在其他分店里用了

php 入门篇-如何判断mysql数据库连接成功

<?php
$cn = mysql_connect('localhost','root','root');
if( $cn )
{
 die('数据库连接成功');
}
else
{
 die('连接失败');
}
?>

标签:[!--infotagslink--]

您可能感兴趣的文章: