我在訪問時光網(wǎng)、網(wǎng)易云音樂等網(wǎng)站時,發(fā)現(xiàn)將它們頁面中的一些圖片URL修改一下就可以得到不同尺寸的圖片,于是思考了其實現(xiàn)方案,我的思路是:URL Rewrite + 實時處理 + 緩存,對用戶請求的URL進行重寫,然后利用圖片處理類庫對圖片進行處理,接著緩存該尺寸圖片并輸出到瀏覽器。使用PHP和Node.js實現(xiàn)了一遍,基本達到了需要的效果。

1、Nginx+Node.js(express)實現(xiàn)

URL重寫
這里Nginx主要是做一個URL重寫和反向代理的功能,配置如下所示:

location ~ /upload/{
    if ($request_uri ~* ^/upload/(.+)_(\d+)x(\d+)\.(jpg|png|gif)$) {
        set $src $1;
        set $w $2;
        set $h $3;
        set $t $4;
        rewrite . /resize?src=$src&w=$w&h=$h&type=$t break;
    }
    proxy_pass        http://127.0.0.1:3000;
}

這里說明一下:Nginx監(jiān)聽本地的80端口,Node.js監(jiān)聽的是3000端口。當用戶訪問類似

延伸閱讀

學(xué)習(xí)是年輕人改變自己的最好方式-Java培訓(xùn),做最負責(zé)任的教育,學(xué)習(xí)改變命運,軟件學(xué)習(xí),再就業(yè),大學(xué)生如何就業(yè),幫大學(xué)生找到好工作,lphotoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)學(xué)習(xí)是年輕人改變自己的最好方式