phppcache的簡單介紹

本文目錄一覽:

安裝wordpress使用tengine怎麼樣

後台之前使用的Tengine+HHVM環境, 前段時間更新了 HHVM 之後,感覺訪問 Blog 的速度慢了很多,不知道是不是與使用的某些插件不兼容的原因,正好 Aliyun 添加了 Ubuntu14.04鏡像,趁這次更新系統的機會,重新採用Tengine+PHP-FPM的架構來運行 WordPress.下面記錄一下安裝的過程.

備份好數據之後,在 Aliyun 後台更新系統盤,選擇 Ubuntu 14.04這個鏡像.

完成之後,登錄到伺服器.

先進行一些系統參數的優化設置.

#Synchronization timerm -rf /etc/localtimeln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtimeapt-get install -y ntpdatentpdate -u pool.ntp.orgdate#Disable SeLinuxif [ -s /etc/selinux/config ]; thensed -i ‘s/SELINUX=enforcing/SELINUX=disabled/g’ /etc/selinux/configfiif [ -s /etc/ld.so.conf.d/libc6-xen.conf ]; thensed -i ‘s/hwcap 1 nosegneg/hwcap 0 nosegneg/g’ /etc/ld.so.conf.d/libc6-xen.conffi#set sysctl\cp /etc/sysctl.conf /etc/sysctl.conf.baksed -i ‘s/net\.ipv4\.tcp_syncookies.*/net\.ipv4\.tcp_syncookies = 1/’ /etc/sysctl.confif cat /etc/sysctl.conf | grep “aliyun web add” /dev/null ;thenecho “”elsecat /etc/sysctl.conf /dev/null;then echo “”else echo “* soft nofile 65535” /etc/security/limits.conffiif cat /etc/security/limits.conf | grep “* hard nofile 65535” /dev/null ;then echo “”else echo “* hard nofile 65535” /etc/security/limits.conffi

然後更新系統,安裝必要的系統組件.

apt-get updateapt-get autoremove -yapt-get -fy installapt-get install -y build-essential gcc g++ makefor packages in build-essential gcc g++ make cmake automake autoconf re2c wget cron bzip2 libzip-dev libperl-dev libc6-dev iptables file libaio* rcconf flex vim nano bison m4 gawk less make cpp binutils diffutils unzip tar bzip2 unrar p7zip libncurses5-dev libncurses5 libncurses5-dev libncurses5-dev libtool libevent-dev libpcre3 libpcre3-dev libpcrecpp0 zlibc openssl libsasl2-dev libltdl3-dev libltdl-dev libmcrypt-dev zlib1g zlib1g-dev libbz2-1.0 libbz2-dev libglib2.0-0 libglib2.0-dev libpng3 libjpeg62 libjpeg62-dev libpng-dev libpng12-0 libpng12-dev curl libcurl3 libmhash2 libmhash-dev libpq-dev libpq5 gettext libncurses5-dev libjpeg-dev libxml2-dev libfreetype6 libfreetype6-dev libssl-dev libcurl3 libcurl4-openssl-dev libcurl4-gnutls-dev mcrypt libcap-dev diffutils ca-certificates debian-keyring debian-archive-keyring;do apt-get install -y $packages –force-yes;apt-get -fy install;apt-get -y autoremove; done

接著下載Tengine並編譯安裝,我使用的是截至到當前的最新版本2.0.3.

wget -c zxf tengine-2.0.3.tar.gzcd tengine-2.0.3./configure –prefix=/usr/local/nginx \–user=www-data \–group=www-data \–with-http_stub_status_module \–without-http-cache \–with-http_ssl_module \–with-http_gzip_static_module \–with-http_concat_module CPU_NUM=$(cat /proc/cpuinfo | grep processor | wc -l)if [ $CPU_NUM -gt 1 ];then make -j$CPU_NUMelse makefimake install

Tengine安裝過程還是很快的,用不了幾分鐘,就安裝完成.接著下載一個 Tengine 的控制腳本,用於使用 service nginx start/stop/reload 等操作,並添加nginx 開機啟動.

wget -O /etc/init.d/nginxchmod +x /etc/init.d/nginxservice nginx status # to poll for current statussudo update-rc.d -f nginx defaults

至此,Tengine已經安裝結束,使用 service nginx start啟動Tengine之後,使用瀏覽器訪問網站就可以看到相關的 Welcome 界面了.接下來我們開始安裝 PHP.同樣,我使用的也是當前的最新版本,PHP 5.5.17.

wget -c zxf php-5.5.17.tar.gzcd php-5.5.17./configure –prefix=/usr/local/php \–with-config-file-path=/usr/local/php/etc \–enable-fpm \–with-fpm-user=www-data \–with-fpm-group=www-data \–with-mysql=mysqlnd \–with-mysqli=mysqlnd \–with-pdo-mysql=mysqlnd \–enable-opcache \–enable-static \–enable-inline-optimization \–enable-sockets \–enable-wddx \–enable-zip \–enable-calendar \–enable-bcmath \–enable-soap \–with-zlib \–with-iconv \–with-gd \–with-xmlrpc \–enable-mbstring \–with-curl \–enable-ftp \–with-mcrypt \–disable-ipv6 \–disable-debug \–with-openssl \–disable-maintainer-zts \–disable-fileinfoCPU_NUM=$(cat /proc/cpuinfo | grep processor | wc -l)echo “make php”if [ $CPU_NUM -gt 1 ];then make ZEND_EXTRA_LIBS=’-liconv’ -j$CPU_NUMelse make ZEND_EXTRA_LIBS=’-liconv’fimake install

PHP的編譯時間比Tengine要長一些,耐心等待 PHP 編譯安裝完全之後,需要進入一些軟鏈接操作.同時對 php.ini 和 php-fpm.conf 進行一些優化設置.

ln -s /usr/local/php/bin/php /usr/bin/phpln -s /usr/local/php/bin/phpize /usr/bin/phpizeln -s /usr/local/php/sbin/php-fpm /usr/bin/php-fpmmkdir -p /usr/local/php/etccp php.ini-production /usr/local/php/etc/php.inised -i ‘s@expose_php = On@expose_php = Off@g’ /usr/local/php/etc/php.inised -i ‘s/post_max_size = 8M/post_max_size = 50M/g’ /usr/local/php/etc/php.inised -i ‘s/upload_max_filesize = 2M/upload_max_filesize = 50M/g’ /usr/local/php/etc/php.inised -i ‘s/;date.timezone =/date.timezone = PRC/g’ /usr/local/php/etc/php.inised -i ‘s/short_open_tag = Off/short_open_tag = On/g’ /usr/local/php/etc/php.inised -i ‘s/; cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/g’ /usr/local/php/etc/php.inised -i ‘s/; cgi.fix_pathinfo=0/cgi.fix_pathinfo=0/g’ /usr/local/php/etc/php.inised -i ‘s/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/g’ /usr/local/php/etc/php.inised -i ‘s/max_execution_time = 30/max_execution_time = 300/g’ /usr/local/php/etc/php.inised -i ‘s/register_long_arrays = On/;register_long_arrays = On/g’ /usr/local/php/etc/php.inised -i ‘s/magic_quotes_gpc = On/;magic_quotes_gpc = On/g’ /usr/local/php/etc/php.inised -i ‘s/disable_functions =.*/disable_functions = passthru,exec,system,chroot,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_restore,dl,pfsockopen,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,fsockopen/g’ /usr/local/php/etc/php.ini#enable opcachesed -i ‘/;opcache.enable=0/i\zend_extension=opcache.so’ /usr/local/php/etc/php.inised -i ‘s/;opcache.enable=0/opcache.enable=1/g’ /usr/local/php/etc/php.inised -i ‘s/;opcache.enable_cli=0/opcache.enable_cli=1/g’ /usr/local/php/etc/php.inised -i ‘s/;opcache.memory_consumption=64/opcache.memory_consumption=128/g’ /usr/local/php/etc/php.inised -i ‘s/;opcache.interned_strings_buffer=4/opcache.interned_strings_buffer=8/g’ /usr/local/php/etc/php.inised -i ‘s/;pcache.max_accelerated_files=2000/pcache.max_accelerated_files=4000/g’ /usr/local/php/etc/php.inised -i ‘s/;opcache.revalidate_freq=2/opcache.revalidate_freq=60/g’ /usr/local/php/etc/php.inised -i ‘s/;opcache.fast_shutdown=0/opcache.fast_shutdown=1/g’ /usr/local/php/etc/php.inicat /usr/local/php/etc/php-fpm.confEOF[global]pid = /usr/local/php/var/run/php-fpm.piderror_log = /usr/local/php/var/log/php-fpm.loglog_level = notice[www]listen = /var/run/php5-fpm.socklisten.backlog = -1listen.allowed_clients = 127.0.0.1listen.owner = www-datalisten.group = www-datalisten.mode = 0666user = www-datagroup = www-datapm = dynamicpm.max_children = 10pm.start_servers = 2pm.min_spare_servers = 1pm.max_spare_servers = 6request_terminate_timeout = 100request_slowlog_timeout = 0slowlog = var/log/slow.logEOFcp ./php-5.5.17/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpmchmod +x /etc/init.d/php-fpm

最後,掛載備份的數據盤.從備份盤恢復網站數據,並修改 Nginx 的配置,恢復網站的正常訪問.

mkdir -p /backupecho ‘/dev/xvdb1 /backup ext4 barrier=0 0 0’ /etc/fstab mount -a

我已經將上面的過程編寫成了一個腳本,可下載後查看(install.zip),也可以直接下載到伺服器運行.完成之後,只需要添加 vhost的配置reload 一下 nginx 就可以正常訪問了.

需要說明的是由於我使用了阿里雲的 RDS,所以沒有在伺服器上安裝 MySql.

如何關閉PHP緩存

header(“Cache-Control: no-cache, must-revalidate”); //禁止頁面緩存

set cache = false;//如何關閉PHP緩存

PHP中cache-control的no-cache是什麼意思,有什麼作用。言簡意賅。

no-cache

必須先與伺服器確認返回的響應是否被更改,然後才能使用該響應來滿足後續對同一個網址的請求。因此,如果存在合適的驗證令牌 (ETag),no-cache 會發起往返通信來驗證緩存的響應,如果資源未被更改,可以避免下載。

;ref=wisessid=0from=7300001auid=0pu=sz%401320_480%2Ccuid%40luSCi0upH80yuSaR_uHZugia2aj7uHaK0iStijaM2iKWL5SlB%2Ccua%40_avLCgaH-i46ywoUfpw1z4adXi45a2iLA%2Ccut%400fStNJtN2i4faXiDzuDs8gIVQRlYkSO6A%2Cosname%40baiduboxapp%2Cctv%402%2Ccfrom%401001187r%2Ccen%40cuid_cua_cut%2Ccsrc%40app_mainbox_txt%2Cta%40zbios_2_5.0_6_5.0%2Cusm%402%2Cvmgdb%400020100228ybd_page_type=1baiduid=A32D22DBFA75863948456F48E2B0F986tj=Xv_1_0_10_title

PHP做圖標,pChart怎麼用啊?圖在哪裡輸出?

pChart是一個開源的圖表生成庫,主要涉及3個Class: pChart.class , pData.class , pCache.class ,可生成20多種簡單或複雜的圖表,支持PNG,JPG,GIF通用圖片格式。數據源可以來自於Database,CSV,當然也可以手寫。使用該程序PHP需要開啟GD服務,先來看看p

pChart是一個開源的圖表生成庫,主要涉及3個Class:, , ,可生成20多種簡單或複雜的圖表,支持PNG,JPG,GIF通用圖片格式。數據源可以來自於Database,CSV,當然也可以手寫。使用該程序PHP需要開啟GD服務,先來看看pChart的工作流程:

主要分為三步:

* 讀取用於生成圖表數據(資料庫、文件)

* 設計圖表樣式(圓角、底色等)

* 製作標籤、題目、圖例並生成圖表

下面看一個簡單的柱狀圖表:

代碼如下:

?php // Standard inclusionsinclude(“pChart/pData.class”);

 include(“pChart/pChart.class”);

 // Dataset definition $DataSet = newpData;

 //圖表數據 $DataSet-AddPoint(array(1,4,-3,2,-3,3,2,1,0,7,4),”Serie1″);

 $DataSet-AddPoint(array(3,3,-4,1,-2,2,1,0,-1,6,3),”Serie2″);

 $DataSet-AddPoint(array(4,1,2,-1,-4,-2,3,2,1,2,2),”Serie3″);

 $DataSet-AddAllSeries();

 $DataSet-SetAbsciseLabelSerie();

 //數據圖例 $DataSet-SetSerieName(“Microsoft”,”Serie1″);

 $DataSet-SetSerieName(“IBM”,”Serie2″);

 $DataSet-SetSerieName(“Google”,”Serie3″);

 // Initialise the graph $Test = newpChart(700,230);

 //設置圖表尺寸、樣式 $Test-setFontProperties(“Fonts/tahoma.ttf”,8);

 $Test-setGraphArea(50,30,680,200);

 $Test-drawFilledRoundedRectangle(7,7,693,223,5,240,240,240);

 $Test-drawRoundedRectangle(5,5,695,225,5,230,230,230);

 $Test-drawGraphArea(255,255,255,TRUE);

 $Test-drawScale($DataSet-GetData(),$DataSet-GetDataDescription(),SCALE_NORMAL,150,150,150,TRUE,0,2,TRUE);

 $Test-drawGrid(4,TRUE,230,230,230,50);

 // Draw the 0 line $Test-setFontProperties(“Fonts/MankSans.ttf”,6);

 $Test-drawTreshold(0,143,55,72,TRUE,TRUE);

 // Draw the bar graph //柱狀圖要使用drawBarGraph() $Test-drawBarGraph($DataSet-GetData(),$DataSet-GetDataDescription(),TRUE,80);

 // Finish the graph //製作圖例、標題、字體等屬性 $Test-setFontProperties(“Fonts/MankSans.ttf”,10);

 $Test-drawLegend(596,150,$DataSet-GetDataDescription(),255,255,255);

 $Test-setFontProperties(“Fonts/MankSans.ttf”,10);

 $Test-drawTitle(50,22,”Example”,50,50,50,585);

 

 //生成圖表 $imageFile =”example12.png”;

 $Test-Render($imageFile);

 echo ‘img src=”‘.$imageFile.'”‘

php中getcache的用法

PHP的getcache是 讀取緩存文件的函數

比如常見的當前站點類別,是保存在緩存文件中的,讀取的時候用:

$this-categorys = getcache(『category_content_』.$this-siteid,』commons』);

具體實例:

?php

$iterator = new ArrayIterator(array(1, 2, 3));

$cache    = new CachingIterator($iterator, CachingIterator::FULL_CACHE);

$cache-next();

$cache-next();

var_dump($cache-getCache());

$cache-next();

var_dump($cache-getCache());

?

以上常式會輸出:

array(2) {

 [0]=

 int(1)

 [1]=

 int(2)

}

array(3) {

 [0]=

 int(1)

 [1]=

 int(2)

 [2]=

 int(3)

}

php網站如何更新緩存

每個程序使用的緩存,可能都不一樣,你最好找程序作者問一下

PHP 輸出緩存詳解

作者: 字體:[增加 減小] 類型:轉載

Output Control

函數可以讓你自由控制腳本中數據的輸出。它非常地有用,特別是對於:當你想在數據已經輸出後,再輸出文件頭的情況。

輸出控制函數不對使用 header() 或 setcookie(),

發送的文件頭信息產生影響,只對那些類似於 echo() 和 PHP 代碼的數據塊有作用。

我們先舉一個簡單的例子,讓大家對Output

Control有一個大致的印象:

Example 1.

複製代碼

代碼如下:

?php

ob_start(); //打開緩衝區

echo

\”Hellon\”; //輸出

header(「location:index.php」); //把瀏覽器重定向到index.php

ob_end_flush();//輸出全部內容到瀏覽器

?

所有對header()函數有了解的人都知道,這個函數會發送一段文件頭給瀏覽器,但是如果在使用這個函數之前已經有了任何輸出(包括空輸出,比如空格,回車和換行)就會提示出錯。如果我們去掉第一行的ob_start(),再執行此程序,我們會發現得到了一條錯誤提示:「Header

had all ready send

by」!但是加上ob_start,就不會提示出錯,原因是當打開了緩衝區,echo後面的字元不會輸出到瀏覽器,而是保留在伺服器,直到你使用

flush或者ob_end_flush才會輸出,所以並不會有任何文件頭輸出的錯誤!

一、 相關函數簡介:

1、Flush:刷新緩衝區的內容,輸出。

函數格式:flush()

說明:這個函數經常使用,效率很高。

2、ob_start :打開輸出緩衝區

函數格式:void ob_start(void)

說明:當緩衝區激活時,所有來自PHP程序的非文件頭信息均不會發送,而是保存在內部緩衝區。為了輸出緩衝區的內容,可以使用ob_end_flush()或flush()輸出緩衝區的內容。

3 、ob_get_contents :返回內部緩衝區的內容。

使用方法:string

ob_get_contents(void)

說明:這個函數會返回當前緩衝區中的內容,如果輸出緩衝區沒有激活,則返回 FALSE 。

4、ob_get_length:返回內部緩衝區的長度。

使用方法:int

ob_get_length(void)

說明:這個函數會返回當前緩衝區中的長度;和ob_get_contents一樣,如果輸出緩衝區沒有激活。則返回

FALSE。

5、ob_end_flush :發送內部緩衝區的內容到瀏覽器,並且關閉輸出緩衝區。

使用方法:void ob_end_flush(void)

說明:這個函數發送輸出緩衝區的內容(如果有的話)。

6、ob_end_clean:刪除內部緩衝區的內容,並且關閉內部緩衝區

使用方法:void

ob_end_clean(void)

說明:這個函數不會輸出內部緩衝區的內容而是把它刪除!

7、ob_implicit_flush:打開或關閉絕對刷新

使用方法:void

ob_implicit_flush ([int flag])

說明:使用過Perl的人都知道$|=x的意義,這個字元串可以打開/關閉緩衝區,而ob_implicit_flush函數也和那個一樣,默認為關閉緩衝區,打開絕對輸出後,每個腳本輸出都直接發送到瀏覽器,不再需要調用

flush()

二、深入了解:

1. 關於Flush函數:

這個函數在PHP3中就出現了,是一個效率很高的函數,他有一個非常有用的功能就是刷新browser的cache.我們舉一個運行效果非常明顯的例子來說明flush.

Example 2.

複製代碼

代碼如下:

?php

for($i = 1; $i = 300; $i++

) print(「 「);

// 這一句話非常關鍵,cache的結構使得它的內容只有達到一定的大小才能從瀏覽器里輸出

//

換言之,如果cache的內容不達到一定的大小,它是不會在程序執行完畢前輸出的。經

//

過測試,我發現這個大小的底限是256個字元長。這意味著cache以後接收的內容都會

// 源源不斷的被發送出去。

For($j = 1; $j

= 20; $j++) {

echo $j.」

」;

flush();

//這一部會使cache新增的內容被擠出去,顯示到瀏覽器上

sleep(1); //讓程序「睡」一秒鐘,會讓你把效果看得更清楚

}

?

具體效果你可以到這裡看看

PHP2000的最新的PHP聊天室就是用的這個技術,可惜的是源代碼未公開 L

註:如果在程序的首部加入ob_implicit_flush()打開絕對刷新,就可以在程序中不再使用flush(),這樣做的好處是:提高效率!

2. 關於ob系列函數:

我想先引用我的好朋友y10k的一個例子:

Example 3.

比如你用得到伺服器和客戶端的設置信息,但是這個信息會因為客戶端的不同而不同,如果想要保存phpinfo()函數的輸出怎麼辦呢?在沒有緩衝區控制之前,可以說一點辦法也沒有,但是有了緩衝區的控制,我們可以輕鬆的解決:

複製代碼

代碼如下:

?php

ob_start(); //打開緩衝區

phpinfo(); //使用phpinfo函數

$info=ob_get_contents(); //得到緩衝區的內容並且賦值給$info

$file=fopen(\’info.txt\’,\’w\’); //打開文件info.txt

fwrite($file,$info);

//寫入信息到info.txt

fclose($file); //關閉文件info.txt

?

用以上的方法,就可以把不同用戶的phpinfo信息保存下來,這在以前恐怕沒有辦法辦到!其實上面就是將一些「過程」轉化為「函數」的方法!

或許有人會問:「難道就這個樣子嗎?還有沒有其他用途?」當然有了,比如筆者論壇的PHP

語法加亮顯示就和這個有關(PHP默認的語法加亮顯示函數會直接輸出,不能保存結果,如果在每次調用都顯示恐怕會很浪費CPU,筆者的論壇就把語法加亮函數顯示的結果用控制緩衝區的方法保留了),大家如果感興趣的話可以來看看!

可能現在大家對ob_start()的功能有了一定的了解,上面的一個例子看似簡單,但實際上已經掌握了使用ob_start()的要點。

1.使用ob_start打開browser的cache,這樣可以保證cache的內容在你調用flush(),ob_end_flush()(或程序執行完畢)之前不會被輸出。

2.現在的你應該知道你所擁有的優勢:可以在任何輸出內容後面使用header,setcookie以及session,這是

ob_start一個很大的特點;也可以使用ob_start的參數,在cache被寫入後,然後自動運行命令,比如

ob_start(\”ob_gzhandler\”);而我們最常用的做法是用ob_get_contents()得到cache中的內容,然後再進行處理……

3.當處理完畢後,我們可以使用各種方法輸出,flush(),ob_end_flush(),以及等到程序執行完畢後的自動輸出。當然,如果你用的是ob_get_contents(),那麼就要你自己控制輸出方式了。

來,讓我們看看能用ob系列函數做些什麼……

一、 靜態模版技術

簡介:所謂靜態模版技術就是通過某種方式,使得用戶在client端得到的是由PHP產生的html頁面。如果這個html頁面不會再被更新,那麼當另外的用戶再次瀏覽此頁面時,程序將不會再調用PHP以及相關的資料庫,對於某些信息量比較大的網站,例如sina,163,sohu。類似這種的技術帶來的好處是非常巨大的。

我所知道的實現靜態輸出的有兩種辦法:

1.通過y10k修改的phplib的一個叫template.inc.php類實現。

2.使用ob系列函數實現。

對於第一種方法,因為不是這篇文章所要研究的問題,所以不再贅述。

我們現在來看一看第二種方法的具體實現:

Example 4.

?php

ob_start();//打開緩衝區

?

php頁面的全部輸出

?

$content =

ob_get_contents();//取得php頁面輸出的全部內容

$fp = fopen(「output00001.html」, 「w」);

//創建一個文件,並打開,準備寫入

fwrite($fp, $content);

//把php頁面的內容全部寫入output00001.html,然後……

fclose($fp);

?

這樣,所謂的靜態模版就很容易的被實現了……

二、 捕捉輸出

以上的Example

4.是一種最簡單的情況,你還可以在寫入前對$content進行操作……

你可以設法捕捉一些關鍵字,然後去對它進行再處理,比如Example

3.所述的PHP語法高亮顯示。個人認為,這個功能是此函數最大的精華所在,它可以解決各種各樣的問題,但需要你有足夠的想像力……

Example 5.

?

Function run_code($code) {

If($code) {

ob_start();

eval($code);

$contents = ob_get_contents();

ob_end_clean();

}else {

echo 「錯誤!沒有輸出」;

exit();

}

return $contents;

}

以上這個例子的用途不是很大,不過很典型$code的本身就是一個含有變數的輸出頁面,而這個例子用eval把$code中的變數替換,然後對輸出結果再進行輸出捕捉,再一次的進行處理……

Example 6. 加快傳輸

?

/*

** Title………: PHP4 HTTP

Compression Speeds up the Web

** Version…….: 1.20

** Author……..:

catoc catoc@163.net

** Filename……: gzdoc.php

** Last

changed..: 18/10/2000

** Requirments…: PHP4 = 4.0.1

** PHP was

configured with –with-zlib[=DIR]

** Notes………: Dynamic Content

Acceleration compresses

** the data transmission data on the fly

** code

by sun jin hu (catoc) catoc@163.net

** Most newer browsers since

1998/1999 have

** been equipped to support the HTTP 1.1

** standard

known as \”content-encoding.\”

** Essentially the browser indicates to the

** server that it can accept \”content encoding\”

** and if the server

is capable it will then

** compress the data and transmit it. The

**

browser decompresses it and then renders

** the page.

**

** Modified

by John Lim (jlim@natsoft.com.my)

** based on ideas by Sandy McArthur, Jr

** Usage……..:

** No space before the beginning of the first

\’?\’ tag.

** ————Start of file———-

** |?

** |

include(\’gzdoc.php\’);

** |?

** |HTML

** |… the page

** |/HTML

** |?

** | gzdocout();

** |?

** ————-End of file———–

*/

ob_start();

ob_implicit_flush(0);

function CheckCanGzip(){

global

$HTTP_ACCEPT_ENCODING;

if (headers_sent() || connection_timeout() ||

connection_aborted()){

return 0;

}

if (strpos($HTTP_ACCEPT_ENCODING,

\’x-gzip\’) !== false) return \”x-gzip\”;

if

(strpos($HTTP_ACCEPT_ENCODING,\’gzip\’) !== false) return \”gzip\”;

return

0;

}

/* $level = compression level 0-9, 0=none, 9=max */

function

GzDocOut($level=1,$debug=0){

$ENCODING = CheckCanGzip();

if ($ENCODING){

print \”n!– Use compress $ENCODING –n\”;

$Contents =

ob_get_contents();

ob_end_clean();

if ($debug){

$s = \”pNot

compress length: \”.strlen($Contents);

$s .= \”

Compressed length:

\”.strlen(gzcompress($Contents,$level));

$Contents .= $s;

}

header(\”Content-Encoding: $ENCODING\”);

print

\”x1fx8bx08x00x00x00x00x00\”;

$Size = strlen($Contents);

$Crc =

crc32($Contents);

$Contents = gzcompress($Contents,$level);

$Contents =

substr($Contents, 0, strlen($Contents) – 4);

print $Contents;

print

pack(\’V\’,$Crc);

print pack(\’V\’,$Size);

exit;

}else{

ob_end_flush();

exit;

}

}

?

這是catoc的一段很早以前的代碼,是在weblogs.com看到的,他利用了zlib的函數,對傳輸的內容進行了壓縮,測試表明,對於10k以上的頁面,會產生效果,而且頁面越大,效果越明顯……

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/153267.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-14 03:04
下一篇 2024-11-14 03:04

相關推薦

  • Python簡單數學計算

    本文將從多個方面介紹Python的簡單數學計算,包括基礎運算符、函數、庫以及實際應用場景。 一、基礎運算符 Python提供了基礎的算術運算符,包括加(+)、減(-)、乘(*)、除…

    編程 2025-04-29
  • Python滿天星代碼:讓編程變得更加簡單

    本文將從多個方面詳細闡述Python滿天星代碼,為大家介紹它的優點以及如何在編程中使用。無論是剛剛接觸編程還是資深程序員,都能從中獲得一定的收穫。 一、簡介 Python滿天星代碼…

    編程 2025-04-29
  • Python海龜代碼簡單畫圖

    本文將介紹如何使用Python的海龜庫進行簡單畫圖,並提供相關示例代碼。 一、基礎用法 使用Python的海龜庫,我們可以控制一個小海龜在窗口中移動,並利用它的「畫筆」在窗口中繪製…

    編程 2025-04-29
  • Python櫻花樹代碼簡單

    本文將對Python櫻花樹代碼進行詳細的闡述和講解,幫助讀者更好地理解該代碼的實現方法。 一、簡介 櫻花樹是一種圖形效果,它的實現方法比較簡單。Python中可以通過turtle這…

    編程 2025-04-28
  • Python大神作品:讓編程變得更加簡單

    Python作為一種高級的解釋性編程語言,一直被廣泛地運用於各個領域,從Web開發、遊戲開發到人工智慧,Python都扮演著重要的角色。Python的代碼簡潔明了,易於閱讀和維護,…

    編程 2025-04-28
  • 用Python實現簡單爬蟲程序

    在當今時代,互聯網上的信息量是爆炸式增長的,其中很多信息可以被利用。對於數據分析、數據挖掘或者其他一些需要大量數據的任務,我們可以使用爬蟲技術從各個網站獲取需要的信息。而Pytho…

    編程 2025-04-28
  • 如何製作一個簡單的換裝遊戲

    本文將從以下幾個方面,為大家介紹如何製作一個簡單的換裝遊戲: 1. 遊戲需求和界面設計 2. 使用HTML、CSS和JavaScript開發遊戲 3. 實現遊戲的基本功能:拖拽交互…

    編程 2025-04-27
  • Guava Limiter——限流器的簡單易用

    本文將從多個維度對Guava Limiter進行詳細闡述,介紹其定義、使用方法、工作原理和案例應用等方面,並給出完整的代碼示例,希望能夠幫助讀者更好地了解和使用該庫。 一、定義 G…

    編程 2025-04-27
  • 製作一個簡單的管理系統的成本及實現

    想要製作一個簡單的管理系統,需要進行技術選型、開發、測試等過程,那麼這個過程會花費多少錢呢?我們將從多個方面來闡述製作一個簡單的管理系統的成本及實現。 一、技術選型 當我們開始思考…

    編程 2025-04-27
  • 2的32次方-1:一個看似簡單卻又複雜的數字

    對於計算機領域的人來說,2的32次方-1(也就是十進位下的4294967295)這個數字並不陌生。它經常被用來表示IPv4地址或者無符號32位整數的最大值。但實際上,這個數字卻包含…

    編程 2025-04-27

發表回復

登錄後才能評論