1. [代码][PHP]代码
<?php
/**
* 完整调用示例:
* 1、combine.php?t=j&b=public&fs=jslib.jquery,function
*
* 该例子调用的是网站根目录下的public/jslib/jquery.js和public/function.js
*
* 2、combine.php?t=j&fs=jslib.jquery,function
*
* 该例子调用的是网站根目录下的jslib/jquery.js和function.js
*
* 3、combine.php?t=c&b=public.css&fs=common,index
*
* 该例子调用的是网站根目录下的public/css/common.css和public/css/index.css
*
* 4、combine.php?t=c&fs=css.common
* 该例子调用的是网站根目录下的css/common.css
*
* 注:多个文件名之间用,分隔;只有一个文件名最后不要有,
* 用,分隔的多个文件会被压缩进一个文件,一次性传给浏览器
**/
$is_bad_request=false;
$cache = true;
$doc_root_uri=$_SERVER[‘DOCUMENT_ROOT‘].‘/‘;
$cachedir = $doc_root_uri . ‘public/cache‘;
//文件类型,j为js,c为css
$type=isset($_GET[‘t‘])?($_GET[‘t‘]==‘j‘||$_GET[‘t‘]==‘c‘?$_GET[‘t‘]:‘‘):‘‘;
//存放js和css文件的基目录, 例如:?b=public.js 代表的是/public/js文件夹,出发点是网站根目录
//基目录参数不是必须的,如果有基目录那么这个基目录就会附加在文件名之前
$base =isset($_GET[‘b‘])?($doc_root_uri.str_replace(‘.‘,‘/‘,$_GET[‘b‘])):$doc_root_uri;
//文件名列表,文件名不带后缀名.比如基目录是
//文件名的格式是 :基目录(如果有)+文件包名+文件名
//例如:类型是j,
// 文件名public.js.jquery
// 如果有基路径且为public,
// 那么转换后的文件名就是/public/public/js/jquery.js
// 如果没有基路径
// 那么转换后的文件名就是/public/js/jquery.js
//多个文件名之间用,分隔
$fs=isset($_GET[‘fs‘])?str_replace(‘.‘,‘/‘,$_GET[‘fs‘]):‘‘;
$fs=str_replace(‘,‘,‘.‘.($type==‘j‘?‘js,‘:‘css,‘),$fs);
$fs=$fs.($type==‘j‘?‘.js‘:‘.css‘);
if($type==‘‘||$fs==‘‘){$is_bad_request=true;}
//die($base);
///////////////http://blog.ddian.cn
if($is_bad_request){header ("HTTP/1.0 503 Not Implemented");}
$file_type=$type==‘j‘?‘javascript‘:‘css‘;
$elements = explode(‘,‘,preg_replace(‘/([^?]*).*/‘, ‘\1‘, $fs));
// Determine last modification date of the files
$lastmodified = 0;
while (list(,$element) = each($elements)) {
$path =$base . ‘/‘ . $element;
if (($type == ‘j‘ && substr($path, -3) != ‘.js‘) ||
($type == ‘c‘ && substr($path, -4) != ‘.css‘)) {
header ("HTTP/1.0 403 Forbidden");
exit;
}
if (substr($path, 0, strlen($base)) != $base || !file_exists($path)) {
header ("HTTP/1.0 404 Not Found");
exit;
}
$lastmodified = max($lastmodified, filemtime($path));
}
// Send Etag hash
$hash = $lastmodified . ‘-‘ . md5($fs);
header ("Etag: \"" . $hash . "\"");
if (isset($_SERVER[‘HTTP_IF_NONE_MATCH‘]) &&
stripslashes($_SERVER[‘HTTP_IF_NONE_MATCH‘]) == ‘"‘ . $hash . ‘"‘)
{
// Return visit and no modifications, so do not send anything
header ("HTTP/1.0 304 Not Modified");
header ("Content-Type: text/" . $file_type);
header (‘Content-Length: 0‘);
}
else
{
// First time visit or files were modified
if ($cache) flash插件
{?http://www.huiyi8.com/flashchajian/?
// Determine supported compression method
$gzip = strstr($_SERVER[‘HTTP_ACCEPT_ENCODING‘], ‘gzip‘);
$deflate = strstr($_SERVER[‘HTTP_ACCEPT_ENCODING‘], ‘deflate‘);
// Determine used compression method
$encoding = $gzip ? ‘gzip‘ : ($deflate ? ‘deflate‘ : ‘none‘);
// Check for buggy versions of Internet Explorer
if (!strstr($_SERVER[‘HTTP_USER_AGENT‘], ‘Opera‘) &&
preg_match(‘/^Mozilla\/4\.0 \(compatible; MSIE ([0-9]\.[0-9])/i‘, $_SERVER[‘HTTP_USER_AGENT‘], $matches)) {
$version = floatval($matches[1]);
if ($version < 6)
$encoding = ‘none‘;
if ($version == 6 && !strstr($_SERVER[‘HTTP_USER_AGENT‘], ‘EV1‘))
$encoding = ‘none‘;
}
// Try the cache first to see if the combined files were already generated
$cachefile = ‘cache-‘ . $hash . ‘.‘ . $file_type . ($encoding != ‘none‘ ? ‘.‘ . $encoding : ‘‘);
if (file_exists($cachedir . ‘/‘ . $cachefile)) {
if ($fp = fopen($cachedir . ‘/‘ . $cachefile, ‘rb‘)) {
if ($encoding != ‘none‘) {
header ("Content-Encoding: " . $encoding);
}
header ("Content-Type: text/" . $file_type);
header ("Content-Length: " . filesize($cachedir . ‘/‘ . $cachefile));
fpassthru($fp);
fclose($fp);
exit;
}
}
}
// Get contents of the files
$contents = ‘‘;
reset($elements);
while (list(,$element) = each($elements)) {
$path = $base . ‘/‘ . $element;
$contents .= "\n\n" . file_get_contents($path);
}
// Send Content-Type
header ("Content-Type: text/" . $file_type);
if (isset($encoding) && $encoding != ‘none‘)
{
// Send compressed contents
$contents = gzencode($contents, 9, $gzip ? FORCE_GZIP : FORCE_DEFLATE);
header ("Content-Encoding: " . $encoding);
header (‘Content-Length: ‘ . strlen($contents));
echo $contents;
}
else
{
// Send regular contents
header (‘Content-Length: ‘ . strlen($contents));
echo $contents;
}
// Store cache
if ($cache) {
if ($fp = fopen($cachedir . ‘/‘ . $cachefile, ‘wb‘)) {
fwrite($fp, $contents);
fclose($fp);
}
}
}
php gizp压缩传输js和css文件
时间: 2024-08-04 17:11:15
php gizp压缩传输js和css文件的相关文章
【翻译】Microsoft Ajax Minifier 快速使用指南(与VS集成使用) 编译后直接压缩项目的JS或CSS文件
网上找了好久终于找到一个能跟VS集成使用的JS和CSS压缩工具,因为害怕忘记,所以给转发过来,顺便翻译一下,大学那会儿学的英语基本上都已经还给老师了,所以翻译的不太好,不过能看懂就成,对吧? 原文地址:http://www.asp.net/ajaxlibrary/AjaxMinQuickStart.ashx 一.在命令行中使用 在下载安装完成Microsoft Ajax Minifier之后,你就可以以命令的方式使用它了.单击“开始”——“所有程序”——“Microsoft Ajax Minif
[转][前端优化]使用Combres合并对js、css文件的请求
本文转自:http://www.cnblogs.com/parry/archive/2011/01/28/Reduce_Http_Request_Using_Combres_For_Js_Css.html 在前端优化的各种金律铁规中,“减少客户端对资源的请求”都会在其中出现,刚好最近对网站做一些优化,使用了一下Combres组件,有点心得,遂整理成文. 园子中也有几篇Combres组件的介绍,如:Combres库学习小结以及部分源码分析和使用Combres 库 ASP.NET 网站优化.可部署时
第十一节:Bundles压缩合并js和css及原理分析
一. 简介 1.背景:浏览器默认一次性请求的网络数是有上限的,如果你得js和css文件太多,就会导致浏览器需要多次加载,影响页面的加载速度, MVC中提供Bundles的方式压缩合并js和css,是MVC中特有的一种优化方式. (当然现在前端也有很多基于node的工作流插件,可以合并压缩混淆js或css) 2. 原理(了解即可):核心方法ApplyTransforms,通过StreamReader不断一次一次进行读取 参考文档:https://docs.microsoft.com/en-us/a
后台修改js或者css文件之后,客户端刷新但是无效的问题
前端开发会遇到一个问题:修改测试前端代码的时候,有时候修改了css或者js文件,但是前端刷新的时候却没有反应,不免让人感觉是不是修改错误,其实这有可能是客户端缓存问题.解决方法: 1)Ctrl+F5,清除浏览器缓存(等同于浏览器-->历史数据-->删除cookies) 2)在js或css后加版本号,这时候浏览器客户端会认为这是不同版本的js或者css文件,会自动重新刷新下载(浏览器会缓存下载页面js和css文件) 2.1)形如:.css?v=x 或者 css?version=x &l
将js和css文件装入localStorage加速程序执行
原理如下: 一次批量加要加载的文件存入数组,采用Ajax方式异步载入各个文件,然后采用循环方式逐个执行下载下来的Js或者Css文件,如果已经被缓存(localStorage)的则省略下载过程. 由于JS采用的是单线程模式运行,在执行某一个js时会阻塞其它并发的js执行,所以会按顺序执行各个js.在执行完所有的脚本之后,图片会被浏览器接着 加载,所以第一次加载速度略慢,后面就会比较快了.在JQuery Mobile 1.4.5+FireFox/微信浏览器下实测效果不错,IE就被省略了,我主要是要在
2个方法通过字[符串参数]加载外部js和css文件
Java语言的异常处理机制可以去确保程序的健壮性,提高系统的可用率,但是Java API提供的异常都是比较低级的(这里的低级是指 " 低级别的 " 异常),只有开发人员才能看的懂,才明白发生了什么问题.而对于终端用户来说,这些异常基本上就是天书,与业务无关,是纯计算机语言的描述,那该怎么办?这就需要我们对异常进行封装了. 近年来,深度学习的研究越来越深入,在各个领域也都获得了不少突破性的进展.基于注意力(attention)机制的神经网络成为了最近神经网络研究的一个热点,本人最近也学习
gulp-rev同时将js和css文件写在一个rev-manifest.json文件里面的方式探讨
参考: https://segmentfault.com/q/1010000002876613 https://github.com/sindresorhus/gulp-rev 测试发现,在官网上最主要的做法是: 加入如下参数: { base: 'build/assets', merge: true } 其中base为存放上一个生成的rev-manifest.json文件,然后merge为是否拼合进去,最后再输出到base这个目录上,就可以实现js和css文件同在一个rev-manifest.j
引入JS和CSS文件加版本号的作用
形如: <script type="text/javascript" src="/resources/js/myFunction.js?version=0.1.0"></script> <link rel="stylesheet" type="text/css" href="/resources/css/styles/myLocation.css?version=0.1.0"
Django中载入js和css文件
Django中载入js和css文件 项目的文件夹结构例如以下: mysite |-mysite |-|-static |-|---js和css文件 |-|-|-init.py |-| |-models.py |-| |-views.py |-|-init.py |-|-settings.py |-|-urls.py |-templates |-|-(template html 文件) settings.py中static变量的设置: STATIC_ROOT = os.path.join(os.p