`

PHP 经验集锦

    博客分类:
  • php
阅读更多
1、关于PHP重定向
方法一:header("Location: index.php");
方法二:echo "<script>window.location =\"$PHP_SELF\";</script>";
方法三:echo "<META HTTP-EQUIV=\"Refresh\" CONTENT=\"0; URL=index.php\">";

2、获取访问者浏览器


function browse_infor() {
$browser="";$browserver="";
$Browsers =array("Lynx","MOSAIC","AOL","Opera","JAVA","MacWeb","WebExplorer","OmniWeb");
$Agent = $GLOBALS["HTTP_USER_AGENT"];
for ($i=0; $i<=7; $i++) {
if (strpos($Agent,$Browsers[$i])) {
$browser = $Browsers[$i];
$browserver ="";
}
}
if (ereg("Mozilla",$Agent) && !ereg("MSIE",$Agent)) {
$temp =explode("(", $Agent); $Part=$temp[0];
$temp =explode("/", $Part); $browserver=$temp[1];
$temp =explode(" ",$browserver); $browserver=$temp[0];
$browserver =preg_replace("/([\d\.]+)/","\\1",$browserver);
$browserver = " $browserver";
$browser = "Netscape Navigator";
}
if (ereg("Mozilla",$Agent) && ereg("Opera",$Agent)) {
$temp =explode("(", $Agent); $Part=$temp[1];
$temp =explode(")", $Part); $browserver=$temp[1];
$temp =explode(" ",$browserver);$browserver=$temp[2];
$browserver =preg_replace("/([\d\.]+)/","\\1",$browserver);
$browserver = " $browserver";
$browser = "Opera";
}
if (ereg("Mozilla",$Agent) && ereg("MSIE",$Agent)) {
$temp = explode("(", $Agent); $Part=$temp[1];
$temp = explode(";",$Part); $Part=$temp[1];
$temp = explode(" ",$Part);$browserver=$temp[2];
$browserver =preg_replace("/([\d\.]+)/","\\1",$browserver);
$browserver = " $browserver";
$browser = "Internet Explorer";
}
if ($browser!="") {
$browseinfo = "$browser$browserver";
}else {
$browseinfo = "Unknown";
}
return $browseinfo;
}
//调用方法$browser=browseinfo() ;直接返回结果

3、获取访问者操作系统


function osinfo() {
$os="";
$Agent = $GLOBALS["HTTP_USER_AGENT"];
if (eregi('win',$Agent) && strpos($Agent, '95')) {
$os="Windows 95";
}
elseif (eregi('win 9x',$Agent) && strpos($Agent, '4.90')) {
$os="Windows ME";
}
elseif (eregi('win',$Agent) && ereg('98',$Agent)) {
$os="Windows 98";
}
elseif (eregi('win',$Agent) && eregi('nt 5\.0',$Agent)) {
$os="Windows 2000";
}
elseif (eregi('win',$Agent) && eregi('nt',$Agent)) {
$os="Windows NT";
}
elseif (eregi('win',$Agent) && eregi('nt 5\.1',$Agent)) {
$os="Windows XP";
}
elseif (eregi('win',$Agent) && ereg('32',$Agent)) {
$os="Windows 32";
}
elseif (eregi('linux',$Agent)) {
$os="Linux\";
}
elseif (eregi('unix',$Agent)) {
$os="Unix";
}
elseif (eregi('sun',$Agent) && eregi('os',$Agent)) {
$os="SunOS";
}
elseif (eregi('ibm',$Agent) && eregi('os',$Agent)) {
$os="IBM OS/2";
}
elseif (eregi('Mac',$Agent) && eregi('PC',$Agent)) {
$os="Macintosh";
}
elseif (eregi('PowerPC',$Agent)) {
$os="PowerPC";
}
elseif (eregi('AIX',$Agent)) {
$os="AIX";
}
elseif (eregi('HPUX',$Agent)) {
$os="HPUX";
}
elseif (eregi('NetBSD',$Agent)) {
$os="NetBSD";
}
elseif (eregi('BSD',$Agent)) {
$os="BSD";
}
elseif (ereg('OSF1',$Agent)) {
$os="OSF1";
}
elseif (ereg('IRIX',$Agent)) {
$os="IRIX";
}
elseif (eregi('FreeBSD',$Agent)) {
$os="FreeBSD\";
}
if ($os=='') $os = "Unknown";
return $os;
}
//调用方法$os=os_infor() ;

4、文件格式类

$mime_types = array(
'gif' => 'image/gif',
'jpg' => 'image/jpeg',
'jpeg' => 'image/jpeg',
'jpe' => 'image/jpeg',
'bmp' => 'image/bmp',
'png' => 'image/png',
'tif' => 'image/tiff',
'tiff' => 'image/tiff',
'pict' => 'image/x-pict',
'pic' => 'image/x-pict',
'pct' => 'image/x-pict',
'tif' => 'image/tiff',
'tiff' => 'image/tiff',
'psd' => 'image/x-photoshop',

'swf' => 'application/x-shockwave-flash',
'js' => 'application/x-javascript',
'pdf' => 'application/pdf',
'ps' => 'application/postscript',
'eps' => 'application/postscript',
'ai' => 'application/postscript',
'wmf' => 'application/x-msmetafile',

'css' => 'text/css',
'htm' => 'text/html',
'html' => 'text/html',
'txt' => 'text/plain',
'xml' => 'text/xml',
'wml' => 'text/wml',
'wbmp' => 'image/vnd.wap.wbmp',

'mid' => 'audio/midi',
'wav' => 'audio/wav',
'mp3' => 'audio/mpeg',
'mp2' => 'audio/mpeg',

'avi' => 'video/x-msvideo',
'mpeg' => 'video/mpeg',
'mpg' => 'video/mpeg',
'qt' => 'video/quicktime',
'mov' => 'video/quicktime',

'lha' => 'application/x-lha',
'lzh' => 'application/x-lha',
'z' => 'application/x-compress',
'gtar' => 'application/x-gtar',
'gz' => 'application/x-gzip',
'gzip' => 'application/x-gzip',
'tgz' => 'application/x-gzip',
'tar' => 'application/x-tar',
'bz2' => 'application/bzip2',
'zip' => 'application/zip',
'arj' => 'application/x-arj',
'rar' => 'application/x-rar-compressed',

'hqx' => 'application/mac-binhex40',
'sit' => 'application/x-stuffit',
'bin' => 'application/x-macbinary',

'uu' => 'text/x-uuencode',
'uue' => 'text/x-uuencode',

'latex'=> 'application/x-latex',
'ltx' => 'application/x-latex',
'tcl' => 'application/x-tcl',

'pgp' => 'application/pgp',
'asc' => 'application/pgp',
'exe' => 'application/x-msdownload',
'doc' => 'application/msword',
'rtf' => 'application/rtf',
'xls' => 'application/vnd.ms-excel',
'ppt' => 'application/vnd.ms-powerpoint',
'mdb' => 'application/x-msaccess',
'wri' => 'application/x-mswrite',
);

5、php生成excel文档

<?
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:filename=test.xls");
echo "test1\t";
echo "test2\t\n";
echo "test1\t";
echo "test2\t\n";
echo "test1\t";
echo "test2\t\n";
echo "test1\t";
echo "test2\t\n";
echo "test1\t";
echo "test2\t\n";
echo "test1\t";
echo "test2\t\n";
?>
//改动相应文件头就可以输出.doc .xls等文件格式了

6、时间比较问题
举一个简单例子说明:比如一个论坛对当天发表的贴子用new图片标记一下。
方法一:
//$db->rows[$i][date]中为数据库中datetime字段值.
$today=time();
$theDay=date("Y-m-d H:i:s",$today-24*3600);
$newTag=$db->rows[$i][date]>=$theDay?"<img src='../image/newinfor.gif'>":"";
方法二:
$newTag=$db->rows[$i][date]>=date("Y-m-d 00:00:00")?"<img src='../image/newinfor.gif'>":"";

7.数据库封装例子

<?php
//------------------------------------------------------------------------------------------
// ※Database()                   构造函数,数据库初始参数
// ※Select()                     查询
// ※GetRows()                    返回查询的记录总数
// ※Insert()                     插入记录
// ※Update()                     更新
// ※Delete()                     删除
// ※Halt()                       中断并显示错误信息*/
//------------------------------------------------------------------------------------------
define("DATABASETYPE","1");       //定义数据库类型:1为MySql;2为SQL Server;3为Oracle;4为Odbc
define("SERVER","localhost");     //Host name or IP address of the database server
define("DATABASE","dbName");   //要连接的数据库名
define("USER","tableName");     //用于连接数据库的用户名
define("PASSWORD","paswd");    //用于连接数据库的密码 

class Database{
var $dbLink;                      //连接句柄
var $result;                      //查询句柄
var $insId;                       //Insert()成功返回AUTO_INCREMENT列的值
var $rows;                        //返回数据数组
var $numRows;                     //返回数据数目
var $dbHost, $dbUser, $userPassword, $database;
var $dbType=DATABASETYPE;
var $msgFlag = "yes" ;            //yes:show the Mysql message ; no: die by show "Halted."
function Database($dbHost=SERVER,$dbUser=USER,$userPassword=PASSWORD,$database=DATABASE){
   switch($this->dbType){
     case 1:
      $this->dbLink=@mysql_pconnect($dbHost,$dbUser,$userPassword);// or die("Can't Connect to Remote Host!");
      @mysql_select_db($database,$this->dbLink);// or die ("Can't Connect to Remote Host!");
      break;
    case 2:
      break;   
  }
   return true;
}

/*SQL:Select() 返回为false无结果*/
function Select($table,$columns,$condition=1){
  $sql="select $columns from $table where $condition "; 
  //echo $sql."<br>";  
  $this->result=@mysql_query($sql,$this->dbLink); 
  unset($this->rows);
  if($this->result){
   $i=0;
   if(!($this->rows=array("$i"=>@mysql_fetch_array($this->result))))
    return false;
   if(($this->numRows=@mysql_num_rows($this->result))==0)
    return false;
   while($tempRows=@mysql_fetch_array($this->result)){
    array_push($this->rows,$tempRows);
   }     
  }else{
   $this->Halt($sql);
   return false;
  } 
  return true;
}

/*SQL:GetRows() 返回查询的记录总数*/
function GetRows($table,$condition=1){
  $sql="select count(1) as count from $table where $condition"; 
  //echo $sql."<br>";     
  $this->result=@mysql_query($sql,$this->dbLink);   
  if($this->result){
    $temp=@mysql_fetch_array($this->result);
   $this->numRows=$temp[count];
  }else{
   $this->Halt($sql);
   return false;
  } 
  return $this->numRows;
}
 
/*SQL:Insert()*/
 
function Insert($table,$columns,$values){
  $sql="insert into $table ($columns) values ($values)";
  //echo $sql;
  $this->result=@mysql_query($sql,$this->dbLink);
  if ($this->result)
    $this->insId=@mysql_insert_id($this->dbLink);
   else{
   $this->Halt($sql);
   return false;
  }
  return true;
}

/*SQL:Update()*/
 
function Update($table,$setings,$condition){
  $sql="update $table set $setings where $condition";
  //echo $sql;
  $this->result=@mysql_query($sql,$this->dbLink);
  if ($this->result)
    $this->numRows=@mysql_affected_rows($this->result);
   else{
   $this->Halt($sql);
   return false;
  }
  return true;
}

/*SQL:Delete*/

function Delete($table,$condition){
  $sql="delete from $table where $condition";
  $this->result=@mysql_query($sql,$this->dbLink);
  if ($this->result)
     $this->numRows=@mysql_affected_rows($this->result);
   else{
   $this->Halt($sql);
   return false;
  } 
   
  return true;
}

/*Halt():error message */

function Halt($msg){
  if($this->msgFlag=="yes"){
   printf("<b>Database Query Error:</b> %s<br>\n", $msg);
   printf("<b>MySql Error:</b> %s<br>\n",mysql_error());
  }else
   echo "<META HTTP-EQUIV=REFRESH CONTENT='0;URL=../include/error.htm'>";//自定一个出错提示文件
    return false;
}
}
  switch($db->dbType){
   case 1:
     @mysql_close();    
    break;
  case 2:
     
    break;   
  }
  $db = new Database();
?>


分享到:
评论

相关推荐

    php开发实战经验

    根据提供的文件信息,我们可以总结出一系列与PHP开发相关的实战经验和知识点。下面将详细解析这些内容。 ### PHP开发实战经验 #### 1. 错误处理 - **Notice和Error级别控制**:`error_reporting(E_ALL ^ E_NOTICE)...

    学习PHP的一些经验

    学习PHP的一些经验--犀利牛为你精讲...

    3年php面试经验总结

    对于3年经验的开发者来说,面试中可能会考察你对网络请求的处理能力以及理解Web协议的能力。以下是一些基本概念: - **HTTP协议**: 超文本传输协议,用于Web服务器和客户端之间进行通信。 - **TCP/IP协议栈**: 一...

    PHP 网站开发经验总结与手册

    PHP 网站开发经验总结与手册PHP 网站开发经验总结与手册PHP 网站开发经验总结与手册PHP 网站开发经验总结与手册PHP 网站开发经验总结与手册PHP 网站开发经验总结与手册PHP 网站开发经验总结与手册PHP 网站开发经验...

    php开发流程和经验

    ### PHP开发流程与经验详解 #### 一、PHP学习与成长之路 对于初学者来说,学习PHP的过程可能会显得有些曲折。作者在接手一个手机网游门户的开发任务时,只有两个月的PHP学习经历,几乎是从零开始。在这个过程中,...

    CentOS7 php7.0 升级到php7.3

    文章的作者 Lansonli 用亲身经历记录了整个升级过程,分享了他的经验和教训。 备份之前的 PHP 7.0 配置 文章开头,作者强调了备份之前的 PHP 7.0 配置的重要性。如果不备份,直接升级到 PHP 7.3,可能会导致服务器...

    介绍围绕PHP的相关资料,包括PHP入门知识,PHP框架,开发工具,PHP项目,PHP笔试,面试及开发的相关经验等.zip

    这份压缩包文件“介绍围绕PHP的相关资料”包含了从初学者到专业人士所需了解的全面PHP知识,涵盖了PHP入门、框架、开发工具、项目实践、笔试面试技巧以及开发经验等多个方面。 1. PHP入门知识:PHP(Hypertext ...

    PHP-X让有一定工作经验的PHP程序员都能扩展.doc

    这个项目的目标就是让有一定工作经验的PHP程序都能够具备扩展开发的能力。   0x00 初衷 从2013年开始编写swoole,现在算来已经有5个年头了。我发现编写一个 PHP 扩展这个工作非常艰难。PHP 程序员群体...

    微博升级PHP7经验分享

    胡波作为微博移动应用服务的负责人,分享了微博在升级PHP7过程中的经验。 #### 直面用户需求 微博移动服务直接面向用户,需求频繁变动且需要快速响应。这要求系统具备高可伸缩性和高可靠性。 #### 应对高流量和...

    PHP实例开发源码-php某网店推广经验交流站.zip

    该压缩包文件“PHP实例开发源码-php某网店推广经验交流站.zip”主要涉及的是PHP编程语言在实际应用中的一个示例,特别是针对网店推广经验交流站点的建设。PHP(Hypertext Preprocessor,超文本预处理器)是一种广泛...

    PHP Manager 1.2 X64 for IIS 7.5和PHP Manager 1.4 X64 for IIS 10

    总的来说,PHP Manager是Windows IIS服务器管理PHP环境的利器,无论是对于新手还是经验丰富的系统管理员,都能显著提升工作效率,确保PHP应用的稳定运行。随着IIS版本的升级,PHP Manager也在不断进化,以更好地满足...

    PHPWord中文手册_Office_word_读取word_php_

    在IT行业中,PHP是一种广泛应用的服务器端脚本语言,尤其在网页开发中占有重要地位。当我们需要处理Microsoft Word...因此,无论你是初学者还是经验丰富的开发者,都应该掌握PHPWord的使用,以提升你的PHP开发技能。

    PHP官方API文档

    PHP中文手册提供了详细的函数参考,包括每个函数的参数、返回值、使用示例和注意事项,这对于初学者和经验丰富的开发者来说都是极其宝贵的资源。手册中的API文档涵盖了PHP的所有核心功能和扩展,使得开发者可以快速...

    编写PHP高效代码的经验探讨.pdf

    编写PHP高效代码的经验探讨 本文旨在探讨编写高效PHP代码的经验和技巧,帮助开发者提高PHP编程效率。文章从理论和实践结合的角度论述编写高效代码的方法和途径,以及一些应用技巧。着重介绍了自主开发的内容管理...

    PHP学习经验分享与练习

    php学习方法,经验总结,以及经典练习题

    2017第三届PHP全球开发者大会ppt

    大会中,来自世界各地的PHP专家和开发者们聚集一堂,分享他们的经验和洞察,共同探讨PHP在软件开发领域的最新进展和未来方向。这些分享可能涵盖了以下主题: 1. PHP版本更新:2017年时,PHP 7已经发布并逐渐成为...

    php五级分销源码带代理自定义广告,多年实战经验php源码,现在共享

    本文将深入探讨“php五级分销源码带代理自定义广告”的相关知识点,结合多年的实战经验,帮助开发者理解并应用这个系统。 首先,我们要了解什么是分销系统。分销系统是一种商业模式,通过将产品销售网络分为多个...

    PHP工程师简历-简洁橙色-1-3年经验简历模板WOROD版本.pdf

    PHP工程师简历-简洁橙色-1-3年经验简历模板WOROD版本.pdf

Global site tag (gtag.js) - Google Analytics