例1,php 内置压缩函数的例子
<?PHP
/**
* php 内置函数压缩
* www.
*/
if(Extension_Loaded('zlib')) Ob_Start('ob_gzhandler');
Header("Content-type: text/html");
?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>php程序员的笔记</title>
</head>
<body>
<?php
for($i=0;$i<10000;$i++){
echo 'Hello World!';
}
?>
</body>
</html>
<?PHP
if(Extension_Loaded('zlib')) Ob_End_Flush();
?>
例2,自写函数实现压缩
<?php ob_start('ob_gzip'); ?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>自写函数压缩_www.</title>
</head>
<body>
</body>
</html>
<?php
ob_end_flush();
//压缩函数
function ob_gzip($content){
if(!headers_sent()&&extension_loaded("zlib")&&strstr($_SERVER["HTTP_ACCEPT_ENCODING"],"gzip")){
$content = gzencode($content,9);
header("Content-Encoding: gzip");
header("Vary: Accept-Encoding");
header("Content-Length: ".strlen($content));
}
return $content;
}
?>从thinkphp中抽取出来的代码,看看人家是如何实现大数据分表的。
数据表:
house_member_0
house_member_1
house_member_2
house_member_3
model:
class MemberModel extends AdvModel {
protected $partition = array('field'=>'username','type'=>'id','num'=>'4');
public function getDao($data=array()) {
$data = empty($data) ? $_POST : $data;
$table = $this->getPartitionTableName($data);
return $this->table($table);
}
}
action:
class MemberAction extends BaseAction {
public function login() {
if($this->isPost()) {
$this->validToken();
$dao = D('Member')->getDao();
$res = $dao->where('username = '.$_POST['username'])->find();
// output 为自定义方法
// $isAjax - bool
$this->output(false);
}
$this->display();
}
}首先,来了解下压缩的优势:
1)、将多个CSS/JS文档合并成一个文件,以减少HTTP请求。
2)、对合并后的文件进行文档压缩,比如分别使用js compressor和CSS compress。
3)、如果使用到一些主流的JavaScript框架,比如JQuery, Mootools或者YUI,强烈推荐直接使用Google AJAX Library以外部链接的形式导入基库。
4)、使用GZIP在服务器端对JS/CSS文档进行压缩。
用PHP使用GZIP压缩非常简单,其核心是使用ob_gzhandler。
注意:并非所有浏览器都支持GZIP传送到客户端的数据,容错处理一定要考虑到。
为大家举一个PHP通过GZIP压缩CSS的例子。
在存放CSS的文件夹中,新建一个style.php文件。
文件style.php:
<?php
if(extension_loaded('zlib')){//检查是否开启zlib
ob_start('ob_gzhandler');
}
header('content-type: text/css; charset: gb2312');//编码,可修改
header('cache-control: must-revalidate');
$offset = 60 * 60 * 24;//css文件的距离现在的过期时间,这里设置为一天
$expire = 'expires: ' . gmdate('D, d M Y H:i:s', time() + $offset) . ' GMT';
header($expire);
ob_start('compress');
function compress($buffer) {//去除文件中的注释
$buffer = preg_replace('!/*[^*]**+([^/][^*]**+)*/!', '', $buffer);
return $buffer;
}
//包含你的全部css文档
include('global.css');
include('layout.css');
if(extension_loaded('zlib')){
ob_end_flush();//输出buffer中的内容,即压缩后的css文件
}
?>
以上代码只是用于压缩css文件,如果需要压缩JavaScript文件,要将上面代码中的第5行的Content-type修改为:
header('content-type:application/x-javascript; charset: gb2312');
同时要注意文件的编码,这里用的是gb2312,如果你采用的是UTF-8或其他编码,修改成对应的(即 utf-8)即可。
修改完成之后,引入相关需要的CSS文件,然后再原HTML引入CSS的地方相应的替换为如下的引入方式:
<link rel="stylesheet" media="screen" href="/blog_article/style/css/v/100415.html" />
同理JS引入方式如下:
<script type="text/javascript" src="/blog_article/js/js/v/121.html"></script>
由于上面代码中使用到了HTTP的Expires(过期)属性用于在客户端缓存CSS/JS代码,所以,如果过期时间设置的太长(比如一 年),当你在服务器端修改了JS/CSS代码时,客户端可能不会立即生效。
解决办法:
在php文件后面添加一个随机参数,如上面例子中的v=121,当下次修改了文件时,记得相应修改此随机参数(比如修改为122)即可。
就是这些了,希望大家亲自动手测试一下,看看压缩前后的网站访问速度,是不是会有大的改观!
,祝大家学习进步,天天向上,向上!!