- 浏览: 354048 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (238)
- j2ee (22)
- mysql (14)
- hibernate (2)
- struts (3)
- spring (7)
- php (28)
- cakephp (12)
- pattern (0)
- 数据结构 (0)
- python (17)
- redis (1)
- sql (2)
- ibatis (1)
- jquery (3)
- 测试 (3)
- linux (37)
- solr (3)
- oracle (5)
- jira (5)
- 版本控制 (3)
- xp (1)
- IDE (3)
- apache (4)
- hadoop (2)
- freemarker (2)
- maven (5)
- 项目管理 (2)
- UML (1)
- Django (6)
- 正则 (1)
- Scrapy (1)
- 文档管理 (3)
- 项目集成 (8)
- MQ (3)
- 架构 (1)
- HTML (1)
- IT (1)
- 云 (0)
- 应用服务器 (4)
- win 7 (1)
- thrift (1)
- 学习 (3)
- OpenStack (3)
- sqlserver (1)
- javascript (1)
- zabbix (3)
- IOS (1)
- rabbitmq (1)
- springcloud (2)
最新评论
-
xushenkun4:
至今仍然有这个bug,0.9.1无法传输中文utf8。
thrift使用出现诡异问题 -
feiniao2029:
[i][/i][u][/u]引用
spring 配置init方法 -
wt811004:
非常感谢朋友慷慨指导
dotproject项目管理工具使用 -
hackpro:
这将是一个经典,就像大话西游...
javaeye怀旧 -
raymond2006k:
个人更偏好 Velocity。我觉得还有个对比点,就是编程方式 ...
jsp freemarker velocity 比较
文件读取函式
文件写入函式
静态页面生成函式
指定条件信息数量检索函式
目录删除函式
目录名称合法性检测函式
分页函式
关于分页函式的使用说明
图片文件上传函式
以下是一些小技巧:
----
文件下载头部输出如何设定
用header输出ftp下载方式,并且支持断点续传
一个例子:
正则匹配中文
批量替换文本里面的超级链接
function PHP_Read($file_name) { $fd=fopen($file_name,r); while($bufline=fgets($fd, 4096)){ $buf.=$bufline; } fclose($fd); return $buf; } ?>
文件写入函式
function PHP_Write($file_name,$data,$method="w") { $filenum=@fopen($file_name,$method); flock($filenum,LOCK_EX); $file_data=fwrite($filenum,$data); fclose($filenum); return $file_data; } ?>
静态页面生成函式
function phptohtm($filefrom,$fileto,$u2u=1){ if($u2u==1){ $data=PHP_Read($filefrom); }else{ $data=$filefrom; } PHP_Write($fileto,$data); return true; } ?>
指定条件信息数量检索函式
function rec_exist($table,$where){ $query="select count(*) as num from $table ".$where; $result=mysql_query($query) or die(nerror(1)); $rowcount=mysql_fetch_array($result); $num=$rowcount["num"]; if ($num==0){ return false; } return $num; } ?>
目录删除函式
function del_DIR($directory){ $mydir=dir($directory); while($file=$mydir->read()){ if((is_dir("$directory/$file")) AND ($file!=".") AND ($file!="..")){ del_DIR("$directory/$file"); }else{ if(($file!=".") AND ($file!="..")){ unlink("$directory/$file"); //echo "unlink $directory/$file ok "; } } } $mydir->close(); rmdir($directory); //echo "rmdir $directory ok "; } ?>
目录名称合法性检测函式
//目录名称合法性检测 function isen($str){ $ret=""; for($i=0;$i $p=ord(substr($str,$i,1)); if(($p<48 & $p!=45 & $p!=46) || ($p>57 & $p<65) || ($p>90 & $p<97 & $p!=95) || $p>122){ nerror("不符合规范!"); } $ret.=chr($p); } return $ret; } ?>
分页函式
//分页函式 function splitlist($HALT,$LRLIST,$ECHOCNT,$paper,$table,$where,$page_id,$userid){ global $splitstr,$sumcnt; if($paper=="" || $sumcnt==""){ $query = "select count(*) as num from $table $where"; $result = mysql_query($query); $row = mysql_fetch_array($result); $sumcnt=$row["num"]; if($sumcnt==0){ nerror("该版内还没有选择发布新闻 !"); } $paper=1; } $sumpaper=($sumcnt-$sumcnt%$ECHOCNT)/$ECHOCNT; if(($sumcnt%$ECHOCNT)!=0) $sumpaper+=1; if($sumpaper==1 && $HALT==0) return($where); $enwhere=base64_encode(base64_encode($where)); if(($LRLIST*2+1) < $sumpaper){ if(($paper-$LRLIST) < 2){ $tract=1; $sub=$LRLIST*2+1; }else if(($paper+$LRLIST) >= $sumpaper){ $tract=$sumpaper-($LRLIST*2); $sub=$sumpaper; }else{ $tract=$paper-$LRLIST; $sub=$paper+$LRLIST; } }else{ $tract=1; $sub=$sumpaper; } $uppaper=$paper-1; $downpaper=$paper+1; $startcnt=($paper-1)*$ECHOCNT; $where.=" limit ${ startcnt },${ ECHOCNT }"; if($tract > 1) { $splitstr="【 << "; } else $splitstr="【 << "; for($i=$tract;$i<=$sub;$i++){ if ($i!=$paper) $splitstr.="".$i." "; else $splitstr.="".$i." "; } if ($sub!=$sumpaper) $splitstr.=">> 】"; else $splitstr.=">> 】"; return($where); } ?>
关于分页函式的使用说明
/* #### 检索分页函式 #### Int $HALT - 检索结果仅分1页时是否(1/0)显示页码条 Int $LRLIST - (页码条显示页码数-1)/2 Int $ECHOCNT - 检索时每页显示记录的数量 Int $paper - 页数,预提取:$paper=$HTTP_GET_VARS[paper]; Varchar $table - 数据表名,预附值:$table="db.table"; Varchar $where - 检索条件,预附值:$where="where field='value'"; Varchar $enwhere - 将原$where进行两次base64_encode()编码后以GET的方式提交 Varchar $splitstr - 页码条输出字串,执行函式后在相应的位置执行 echo $splitstr; 函式调用前需获取变量 - $paper=$HTTP_GET_VARS[paper]; $sumcnt=$HTTP_GET_VARS[sumcnt]; $enwhere=$HTTP_GET_VARS[enwhere]; Return (Varchar $where) - 分页后检索语句的检索条件 注意:本函式需调用出错处理函式 nerror($error); */
图片文件上传函式
//图片文件上传函式 function upload_img($UploadFile,$UploadFile_name,$UploadFile_size,$UploadPath,$max_size=64){ //$TimeLimit=60; //设置超时限制时间 缺省时间为 30秒 设置为0时为不限时 //set_time_limit($TimeLimit); if(($UploadFile!= "none" )&&($UploadFile != "" )){ $FileName=$UploadPath.$UploadFile_name; if($UploadFile_size <1024){ $FileSize="(string)$UploadFile_size" . "字节"; }elseif($UploadFile_size <(1024 * $max_size)){ $FileSize=number_format((double)($UploadFile_size / 1024), 1) . " KB"; }else{ nerror("文件超过限制大小!"); } //{ //$FileSize="number_format((double)($UploadFile_size" / (1024 * 1024)), 1) . " MB"; // } if(!file_exists($FileName)){ if(copy($UploadFile,$FileName)){ return "$UploadFile_name ($FileSize)"; }else{ nerror("文件 $UploadFile_name 上载失败!"); } unlink($UploadFile); }else{ nerror("文件 $UploadFile_name 已经存在!"); } //set_time_limit(30); //恢复缺省超时设置 } }
以下是一些小技巧:
如何判断ip地址合法性 if(!strcmp(long2ip(sprintf("%u",ip2long($ip))),$ip)) echo "is ipn"; ---- email的正则判断 eregi("^[_.0-9a-zA-Z-]+@([0-9a-zA-Z][0-9a-zA-Z_-]+.)+[a-zA-Z]$", $email); 检测ip地址和mask是否合法的例子 $ip = '192.168.0.84'; $mask = '255.255.255.0'; $network = '192.168.0'; $ip = ip2long($ip); $mask = ip2long($mask); $network = ip2long($network); if( ($ip & $mask) == $network) echo "valid ip and maskn"; ?>
----
文件下载头部输出如何设定
header("Content-type: application/x-download"); header("Content-Disposition: attachment; filename=$file_download_name;"); header("Accept-Ranges: bytes"); header("Content-Length: $download_size"); echo 'xxx'
用header输出ftp下载方式,并且支持断点续传
一个例子:
header('Pragma: public'); header('Cache-Control: private'); header('Cache-Control: no-cache, must-revalidate'); header('Accept-Ranges: bytes'); header('Connection: close'); header("Content-Type: audio/mpeg"); header("Location:ftp://download:1bk3l4s3k9s2@232.2.22.22/2222/web技术开发知识库/cn_web.rmvb");
正则匹配中文
ereg("^[".chr(0xa1)."-".chr(0xff)."]+$", $str);
批量替换文本里面的超级链接
<?php function urlParse($str = ''){ if ('' == $str) return $str; $types = array("http", "ftp", "https"); $replace = <<<EOPHP '<a href="'.htmlentities('\1').htmlentities('\2').'">'.htmlentities('\1').htmlentities('\2').'</a>' EOPHP; $ret = $str; while(list(,$type) = each($types)){ $ret = preg_replace("|($type://)([^\s]*)|ie ", $replace, $ret); } return $ret; } ?>
发表评论
-
MAC 安装php+nginx支持oci8等
2015-07-15 10:41 14731. 安装 php brew install php55 ... -
浏览器自动识别编码问题
2012-06-27 17:03 860由于web应用页面编码使用的gbk,但web服务器php的编码 ... -
PHP PACK UNPACK用法
2011-01-25 10:02 1582Pack 与unpack使用说明: ... -
百万级PHP网站架构方案
2010-11-04 18:09 1393在了解过世界最大的PHP ... -
PHP unzip 解压文件
2010-11-03 14:19 9491.unzip <?php $zip ... -
Php防止重复提交问题总结
2010-10-28 14:46 2571用户提交表单时可能因为网速的原因,或者网页被恶意刷新,致使同一 ... -
借用Google API 写一个查看天气预报的类
2010-10-28 13:09 995<? //- Describe: //- Autho ... -
php当前日期的加减操作
2010-10-26 09:29 1956<?php echo "Today:" ... -
PHP 的命令行模式
2010-09-17 10:31 1241PHP 的命令行模式 从版本 4.3.0 开始,PHP 提供 ... -
php soap 错误处理(精简版)
2010-09-17 10:27 19711.使用soap $client = &qu ... -
php soap client 链接问题
2010-09-16 16:04 23371.说明 php 调用jira的soap接口代码: ... -
Handling data in a PHP JSON Object
2010-09-08 14:16 1147Trends data from Twitter Search ... -
php 和 js 保留2位小数
2010-08-24 10:25 27921.php保留两位小数例子 四舍五入 A.nu ... -
zlib 文件操作
2010-08-23 13:44 991<?php //Extracting the co ... -
php pathinfo()函数用法详解
2010-08-23 12:59 1205摘要: php pathinfo()函数用法详解,pathin ... -
Date and Time in PHP
2010-08-18 13:39 856Displaying the current date and ... -
Php学习《五》 ------ 基本知识摘录
2010-08-17 15:31 9531.php中文字符串长度及定长截取问题 使用str_len( ... -
Php学习《四》 ------ 文件上传
2010-08-03 17:29 795通过 PHP,可以把文件上传到服务器。 创建一个文件上传表单 ... -
Php学习《三》 ------ 文件处理
2010-08-03 17:16 792fopen() 函数用于在 PHP 中 ... -
Php学习《二》 ------循环
2010-08-03 17:09 799循环 在您编写代码时,您经常需要让相同的代码块运行很多次。您 ...
相关推荐
本篇文章将深入探讨如何使用PHP进行MySQL数据库的基本操作。 一、连接MySQL数据库 在PHP中,我们可以使用`mysqli`或`PDO`扩展来连接MySQL数据库。以`mysqli`为例,连接代码如下: ```php <?php $servername = ...
这个压缩包文件“php对Cookie进行基本操作的类.zip”提供了一个PHP类,可以帮助开发者更加方便地管理和操作Cookie。 首先,我们要理解Cookie的工作原理。Cookie是由服务器发送到用户的浏览器并存储在本地的一小块...
总结来说,在Windows系统下配置Nginx和PHP,需要掌握服务的启动、重启和停止等基本操作,并能通过快捷方式和批处理脚本来实现。这些操作虽然看似基础,但对于构建一个稳定可靠的Web开发环境来说至关重要。通过本文的...
php mysql dao基本操作,增删改查。以封装成class $my = new MysqlDao(); echo $my->pdo_delete(MODULE.'_network_list', array('id' => 17, 'uniacid' => 6)); $sql = 'select * from '.tablename(MODULE.'_...
下面将详细阐述PHP操作MySQL数据库的基本知识。 1. PHP连接MySQL数据库: 要使用PHP与MySQL交互,首先需要建立一个连接。这可以通过`mysqli_connect()`函数完成,需要提供服务器名、用户名、密码和数据库名作为...
### Memcache安装与基本操作详解 #### 一、前言 Memcache是一种高性能的分布式内存对象缓存系统,用于加速动态Web应用,减轻数据库负担。本文将详细介绍如何安装配置Memcache,并提供基本的操作示例。 #### 二、...
文档中,记录了Mysql的增删改查操作,包括一些多表查询,分组查询,拼接查询、多数据插入、触发器等
PHP开发的一套CMS管理系统,非常适用快速二次开发,内置系统权限管理、系统操作日志等基本功能。满足绝大多数企业日常需求。 PHP开发的一套CMS管理系统,非常适用快速二次开发,内置系统权限管理、系统操作日志等...
PHP中模拟链表和链表的基本操作示例 在编程领域,链表是一种常见的数据结构,它由一系列节点组成,每个节点包含数据和指向下一个节点的指针。链表相较于数组有其独特的优势,例如动态大小、高效的插入和删除操作。...
了解这些基本概念后,开发者可以利用这个PHP Oracle 数据库操作类轻松地实现数据的增删改查操作,创建复杂的业务逻辑,同时确保代码的可读性和可维护性。使用面向对象的方式处理数据库操作,不仅使代码更整洁,也...
PHP 对 XML 文档的基本操作 本文档旨在介绍 PHP 对 XML 文档的基本操作,包括创建 XML 文档、遍历 XML 文档、添加 XML 数据、修改 XML 数据和删除 XML 数据。 创建 XML 文档 要创建 XML 文档,需要使用 PHP 的 ...
综上所述,这个“强大的通用php数据库操作类”不仅封装了基本的数据库操作,还有可能集成数据验证功能,通过优化代码提高了开发效率和系统性能。配合相应的测试文件、实用工具和配置文件,形成了一个完整的数据库...
"好用的php操作excel类"通常指的是PHP中的第三方库,这些库使得与Excel文件交互变得简单而高效。在这个场景中,我们可以关注两个主要的文件:`excel_reader2.php`和`example.php`,它们很可能包含了实现这一功能的...
本篇文章将深入探讨如何使用PHP操作Word内容替换,并生成新的.doc文档。 PHPWord是一个用PHP编写的库,它允许开发者读取、创建和修改Microsoft Office Open XML (OOXML) 格式的文档,包括.docx文件。这种格式是自...
二、PHP操作Word的基本步骤 1. 使用COM组件: - 创建Word对象:`$word = new COM("word.application") or die("无法启动Word");` - 打开文档:`$doc = $word->Documents->Open('path_to_file');` - 写入内容:...
文档是键值对的集合,这些键值对可以包含各种数据类型,包括基本类型、数组和嵌入的子文档。这种设计鼓励数据的嵌套,减少了查询的复杂性,例如在图2所示的例子中,作品和评论可以被设计为一个集合,评论作为子文档...
标题中的“PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】”指的是一个PHP编程中的数据库操作类,该类使用PDO(PHP Data Objects)扩展,允许开发者与MySQL、SQL Server和Oracle等多种数据库系统进行...