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\.]+)/",");
- $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\.]+)/",");
- $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\.]+)/",");
- $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()){
- 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){
- );
- $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经验集锦的更多相关文章
- win7+win10系统使用日常经验集锦
请保留此份 Cmd Markdown 的欢迎稿兼使用说明, 当然你也可以使用彩色字体. 或者使用小体字. 或者使用大体字. 如需撰写新稿件,点击顶部工具栏右侧的 新文稿 或者使用快捷键 Ctrl+Al ...
- Linux内核“问题门” - 学习问题、经验集锦
陈宪章说:“学贵有疑,小疑则小进,大疑则大进.疑者,觉悟之机也,一番觉悟一番长进.” 培根说:“多问的人将多得.” 还在学校的时候导师在激情讲演之后对着会议室里形态各异但均静默不语的我们痛心疾首的说: ...
- 【Unity游戏开发】AssetBundle杂记--AssetBundle的二三事
一.简介 马三在公司大部分时间做的都是游戏业务逻辑和编辑器工具等相关工作,因此对Unity AssetBundle这块的知识点并不是很熟悉,自己也是有打算想了解并熟悉一下AssetBundle,掌握一 ...
- Linux内核(9) - 精华版 之 方法论
到目前为之,博客上分享的精华篇都可以归为方法论的范畴,在很多时候,都是方法论要比细节紧要得多.而这些精华篇又可细分为三个专题:Linux大史记:内核学习的方法论:驱动开发的方法论. Linux大史记 ...
- ( [原创] 4s摄像头出现的问题及解决办法集锦。
[原创] 4s摄像头出现的问题及解决办法集锦. [复制链接] HPagani 34主题 126帖子 13人气 级别: 青苹果 帖子 126 经验 160 精华 人气 13 粉丝1 发消息 ...
- Web前端优化最佳实践及工具集锦
Web前端优化最佳实践及工具集锦 发表于2013-09-23 19:47| 21315次阅读| 来源Googe & Yahoo| 118 条评论| 作者王果 编译 Web优化Google雅虎P ...
- 足球运动训练心得及经验分析-c语言学习调查
在准备预备作业02之前,我参考娄老师的提示,阅读了<[做中学(Learning By Doing)]之乒乓球刻意训练一年总结>一文. 在文章描述的字里行间,给予我的印象是系统.负责,娄老师 ...
- 最有用的Linux命令行使用技巧集锦
最近在Quora上看到一个问答题目,关于在高效率Linux用户节省时间Tips.将该题目的回答进行学习总结,加上自己的一些经验,记录如下,方便自己和大家参考. 下面介绍的都是一些命令行工具,这些工具在 ...
- Mac OS X操作系统常见快捷键集锦
Mac OS X操作系统常见快捷键集锦 启动时的快捷键 启动时按住 X 键 : 强制从 Mac OS X 启动(适用于那些在同一宗卷上安装了 Mac OS X 和 Mac OS 9 双系统的 Mac ...
随机推荐
- mysql数据库主外键级联删除脚本RESTRICT --> CASCADE
在项目中,我们一般在数据库设计的时候做主外键关联设计,要么就不做.但是这样不符合规范,呵呵. 建立主外键关系的时候,默认是不能级联删除的.而出现往往在删除主表的数据时报错, 需要先删除从表然后再删除主 ...
- 简单易懂的现代魔法——Play Framework攻略4
接前文:简单易懂的现代魔法——Play Framework攻略3 1.The Object 时隔2个多月,Play Framework系列又更新了,本次的主题是:利用Play Framework实现R ...
- 【c/c++】内存分配大小
测试平台:linux 32位系统 用sizeof()运算符计算分配空间大小.单位:字节 1. 数组名与变量名的区别 int main() { char q[] = "hello"; ...
- JDBC学习总结(五)
取得数据库连接是件耗时间及资源的动作,尽量利用已打开的连接,也就是重复利用取得的Connection实例,是改善数据库连接性能的一个方式,而采用连接池是基本做法.由于取得Connection的方式根据 ...
- Btrace入门到熟练小工完全指南
BTrace是神器,每一个需要每天解决线上问题,但完全不用BTrace的Java工程师,都是可疑的. BTrace的最大好处,是可以通过自己编写的脚本,获取应用的一切调用信息.而不需要不断地修改代码, ...
- flex布局全解析
前言 很长一段时间, 我知道有flex这个布局方式, 但是始终没有去学它. 3点原因: 感觉还比较新, 担心兼容性不好. 普通的布局方式能满足我的绝大多数需求. 好像蛮复杂的. 最近由于开发需要, 学 ...
- jQuery选择器最佳实践--来自jQ官网
1.基于ID选择器进行查询,并且使用find方法. //快速 $("#container div.footer"); //超快 $("#container"). ...
- Android HandlerThread 使用
HandlerThread 继承了 Thread,添加了 looper,queue 的支持.可以为 Handler 提供线程服务,并可对 执行的任务进行简单的管理. Handler 默认工作在主线程, ...
- 车牌识别LPR(八)-- 字符识别
第八篇:字符识别 车牌定位.车牌倾斜校正.车牌字符分割都是为车牌字符识别做的前提工作,这些前提工作直接关系到车牌识别系统的性能.车牌字符识别是车牌识别系统的核心部分,车牌字符识别的准确率是衡量车牌识 ...
- web rest api tools
https://chrome.google.com/webstore/search/postman-REST%20Client