- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章php技巧小结【推荐】由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1 如何定义linux和window通用的文件分隔符号 。
DIRECTORY_SEPARATOR :
目录分隔符,是定义php的内置常量。在调试机器上,在windows我们习惯性的使用“\”作为文件分隔符,但是在linux上系统不认识这个标识,于是就要引入这个php内置常量了:DIRECTORY_SEPARATOR 。
这样可以不用判断是在linux还是window系统下 。
2 PHP压缩与解压缩类 。
PclZip是一个很强大的压缩与解压缩zip文件的PHP类,PclZip library能够压缩与解压缩Zip格式的压缩档(WinZip、PKZIP);且能对此类类档案进行处理,包括产生压缩档、列出压缩档的内容以及解压缩档案等等。同时也可以对现有的ZIP包进行添加或删除文件.
最近在压缩文件方面用到了它 。
生成zip文件 。
用法一:
1
2
3
4
5
6
7
8
|
<?php
include_once
(
'pclzip.lib.php'
);
$archive
=
new
PclZip(
'archive.zip'
);
$v_list
=
$archive
->create(
'file.txt,data/text.txt,folder'
);
if
(
$v_list
== 0) {
die
(
"Error : "
.
$archive
->errorInfo(true));
}
?>
|
用法二:
1
2
3
4
5
6
7
8
9
10
|
<?php
include_once
(
'pclzip.lib.php'
);
$archive
=
new
PclZip(
'archive.zip'
);
$v_list
=
$archive
->create(
'data/file.txt,data/text.txt'
,
PCLZIP_OPT_REMOVE_PATH,
'data'
,
PCLZIP_OPT_ADD_PATH,
'install'
);
if
(
$v_list
== 0) {
die
(
"Error : "
.
$archive
->errorInfo(true));
}
?>
|
官方网站:http://www.phpconcept.net/pclzip/ 。
3 一小段“劣质”的PHP代码优化的过程,请仔细体会优化过程 。
下面这一小段“劣质”的PHP代码是一道简化了的测试题。这种问题就像在问:你该怎样优化这段代码?
1
2
3
4
|
<?
echo
(
"<p>Search results for query: "
.
$_GET
[
'query'
] .
".</p>"
);
?>
|
这段代码的主要问题在于它把用户提交的数据直接显示到了网页上,从而产生XSS漏洞。其实有很多方法可以填补这个漏洞。那么,什么代码是我们想要的呢?
1
2
3
4
|
<?
echo
(
"<p>Search results for query: "
.
htmlspecialchars(
$_GET
[
'query'
]) .
".</p>"
);
?>
|
这是最低要求。XSS漏洞用htmlspecialchars函数填补了,从而屏蔽了非法字符.
1
2
3
4
5
6
7
|
<?php
if
(isset(
$_GET
[
'query'
]))
{
echo
'<p>Search results for query: '
,
htmlspecialchars(
$_GET
[
'query'
], ENT_QUOTES),
'.</p>'
;
}
?>
|
接着优化:
1
2
3
4
5
6
7
|
<?php
if
(isset(
$_GET
[
'query'
]))
{
echo
'<p>Search results for query: '
,
htmlspecialchars(
$_GET
[
'query'
], ENT_QUOTES),
'.</p>'
;
}
?>
|
4 不用三方类库导出MySQL数据到Excel 。
如果你经常导出数据,那你可能会遇到用第三方类库导出上限,这是一个很无奈的事情,在超过两万条数据的时候,经常导出失败。很容易到达PHP内存使用上限 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
// 输出Excel文件头,可把user.csv换成你要的文件名
header(
'Content-Type: application/vnd.ms-excel'
);
header(
'Content-Disposition: attachment;filename="user.csv"'
);
header(
'Cache-Control: max-age=0'
);
// 从数据库中获取数据,为了节省内存,不要把数据一次性读到内存,从句柄中一行一行读即可
$sql
=
'select * from tbl where ……'
;
$stmt
=
$db
->query(
$sql
);
// 打开PHP文件句柄,php://output 表示直接输出到浏览器
$fp
=
fopen
(
'php://output'
,
'a'
);
// 输出Excel列名信息
$head
=
array
(
'姓名'
,
'性别'
,
'年龄'
,
'Email'
,
'电话'
,
'……'
);
foreach
(
$head
as
$i
=>
$v
) {
// CSV的Excel支持GBK编码,一定要转换,否则乱码
$head
[
$i
] = iconv(
'utf-8'
,
'gbk'
,
$v
);
}
// 将数据通过fputcsv写到文件句柄
fputcsv
(
$fp
,
$head
);
// 计数器
$cnt
= 0;
// 每隔$limit行,刷新一下输出buffer,不要太大,也不要太小
$limit
= 100000;
// 逐行取出数据,不浪费内存
while
(
$row
=
$stmt
->fetch(Zend_Db::FETCH_NUM)) {
$cnt
++;
if
(
$limit
==
$cnt
) {
//刷新一下输出buffer,防止由于数据过多造成问题
ob_flush();
flush
();
$cnt
= 0;
}
foreach
(
$row
as
$i
=>
$v
) {
$row
[
$i
] = iconv(
'utf-8'
,
'gbk'
,
$v
);
}
fputcsv
(
$fp
,
$row
);
}
|
这里的方法是利用fputcsv写CSV文件的方法,直接向浏览器输出Excel文件.
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持我! 。
原文链接:http://www.cnblogs.com/zhenghongxin/p/6283496.html 。
最后此篇关于php技巧小结【推荐】的文章就讲到这里了,如果你想了解更多关于php技巧小结【推荐】的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我是新手。查看 Google 新闻...上下滚动页面时请注意左侧导航栏。 看看它是如何滚动一点,然后在它消失之前粘在页面顶部的? 关于如何做到这一点有什么想法吗? jQuery 和 CSS 可以复制吗
技巧 1:在 Web 服务器上缓存常用数据 技巧 2:在 Application 或 Session 对象中缓存常用数据 技巧 3:在 Web 服务器磁盘上缓存数据和 HTML 技巧 4:避免
我在 excel 中有一个电子表格,其中包含以下行: COLUMN Value1.Value2.Value3 Value4.Value5.Value6 Value7.Value8.Val
GNU Makefile 中是否有任何技巧来获取规则的所有依赖项? 例子: rule1: dep1_1 dep1_2 dep1_3 rule2: dep2_1 dep2_2 rule1 dump_
人们使用什么来追踪内存泄漏?我已经通过代码检查设法解决了一些问题,但我不知道下一步该做什么/当我的程序变大时我将如何管理问题。我知道我在泄漏什么类型的对象,但我不知道是什么让它保持活力。 在 Wind
有什么好的方法可以将“xlSum”、“xlAverage”和“xlCount”等字符串转换为它们在 Microsoft.Office.Interop.Excel.XlConsolidationFunc
我们都见过这个: javascript:document.body.contentEditable='true'; document.designMode='on';无效 0 但我的问题是,这实际上是
我的应用程序将输出一个图形,其布局由用户定义。自定义布局类应该实现我定义的接口(interface)。我应该怎么做?有一个特殊的文件夹,我可以在其中查找布局类?用户是否将类名作为参数传递给应用? 如有
我在弄清楚如何在 Javascript 中自引用表行时遇到了一些麻烦。 这是简化的代码: $( "#listitems tbody" ).append( "" + "" + id.va
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 6 年前。 Improve this q
我正在将代码库从一种编程风格转移到另一种编程风格。 我们有一个名为 Operand 的类型,定义如下: class Operand {...}; 然后我们有 class OperandFactory
我使用以下缩略图类在我的内容包装器中显示 4x3 缩略图: .thumbnail { float:left; width:300px; height:200px; ma
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我认为这是不可能的,但我想在放弃之前问问你。 我想要类似 constexpr 增量的东西。 #include constexpr int inc() { static int inc = 0;
是否有任何适合 C++ 新手的技术和描述的好列表。我在想一个描述 RAII、RVO、左值的列表……这适用于目前不了解这些技术或来自不适用这些技术的其他语言的新手。 最好是短小精悍的:-) 最佳答案 是
我有一个二进制字符串 '01110000',我想在不编写 forloop 的情况下返回前面的前导零数。有谁知道如何做到这一点?如果字符串立即以“1”开头,最好也返回 0 最佳答案 如果您真的确定它是一
我需要优化我的应用程序的 RAM 使用率。 请省去那些告诉我在编写 Python 代码时不应该关心内存的讲座。我有内存问题,因为我使用非常大的默认字典(是的,我也想快点)。我目前的内存消耗是 350M
有时,当我看到一个我喜欢的网站或来自受人尊敬的人的网站时,我会查看源代码并尝试理解它们(就像我们所有人一样)。 关于 Jeremy Keiths他使用以下代码的网站: [role="navigatio
这是我怎样设置 Git 来管理我的家目录的方法。 我有好几台电脑。一台笔记本电脑用于工作,一台工作站放在家里,一台树莓派(或四台),一台 Pocket CHIP,一台 运行
shell 技巧 表变量 HBase 0.95 版本增加了为表提供 jruby 风格的面向对象引用的 shell 命令。以前,作用于表的所有 shell 命令都具有程序风格,该风格始终将表的名称作
我是一名优秀的程序员,十分优秀!