Nginx代理輸出縮放圖片怎麼實現
nginx 設定檔:
# document ppt convert configuration. upstream document.polyv.net { server 127.0.0.1:8080; } server { listen 80; server_name document.polyv.net; index index.html index.htm; charset utf-8; client_max_body_size 1000m; # ignore favicon.ico not exist. location = /favicon.ico { log_not_found off; access_log off; } # not allow to visit hidden files. location ~ /\. { deny all; access_log off; log_not_found off; } location / { if ($request_filename ~* ^.*?\.(txt|doc|pdf|rar|gz|zip|docx|exe|xlsx|ppt|pptx)$) { add_header content-disposition: 'attachment;'; add_header content-type: 'application/octet-stream'; } proxy_pass http://document.polyv.net; proxy_set_header x-real-ip $remote_addr; proxy_set_header x-forwarded-for $proxy_add_x_forwarded_for; proxy_set_header request_host $host; # include proxy.conf; charset utf-8; } # user upload files location /images/ { #expires 7d; alias /data03/ovp/blobs/; proxy_store on; proxy_store_access user:rw group:rw all:rw; proxy_set_header accept-encoding ""; if ( !-f $request_filename ) { proxy_pass http://document.polyv.net; } } location /blobs/ { #expires 7d; alias /data03/ovp/blobs/; } location /preview/images/ { #expires 7d; alias /data03/ovp/blobs/; proxy_store on; proxy_store_access user:rw group:rw all:rw; proxy_set_header accept-encoding ""; if ( !-f $request_filename ) { proxy_pass http://document.polyv.net; } } }
代理程式輸出縮放圖片
rrreee圖片縮放的業務
package com.document.handle.controller; import java.io.bufferedinputstream; import java.io.file; import java.io.ioexception; import java.io.outputstream; import java.net.httpurlconnection; import java.net.url; import javax.servlet.http.httpservletrequest; import javax.servlet.http.httpservletresponse; import org.apache.commons.lang3.stringutils; import org.slf4j.logger; import org.slf4j.loggerfactory; import org.springframework.stereotype.controller; import org.springframework.web.bind.servletrequestutils; import org.springframework.web.bind.annotation.pathvariable; import org.springframework.web.bind.annotation.requestmapping; import com.document.tool.imagemagickutils; import com.document.tool.systemconfig; @controller public class imageagentcontroller { private static final logger log = loggerfactory.getlogger(imageagentcontroller.class); /** * ppt预览图片代理输出 * @throws ioexception */ @requestmapping("/preview/images/{year}/{month}/{md5id}/{preview}/{filename}.{ext}") public void cropimage(@pathvariable string year, @pathvariable string month, @pathvariable string md5id, @pathvariable string preview, @pathvariable string filename, @pathvariable string ext, httpservletrequest request, httpservletresponse response) throws ioexception { // string rootdir = "/data03/ovp/blobs/"; string rootdir = systemconfig.getblobdirectory(); string oname = filename.substring(1, filename.length());// 原图文件名 string dirstring = rootdir + year + "/" + month + "/" + md5id + "/" + oname + "." + ext; string targetfilestring = rootdir + year + "/" + month + "/" + md5id + "/preview/" + filename + "." + ext; //如果原图存在 file originimage = new file(oname); if(originimage.exists()){ log.info("corpimage..." + dirstring + " -> " + targetfilestring); file newfile = new file(targetfilestring); string pathstring = newfile.getparent(); log.info("pathstring...{} {}", pathstring); file pathfile = new file(pathstring); if (!pathfile.exists()) { log.info("---create file---"); pathfile.mkdirs(); } boolean status = imagemagickutils.scale(dirstring, targetfilestring, 240, 180); if (status) { response.reset(); response.setcontenttype("image/" + ext); java.io.inputstream in = new java.io.fileinputstream(targetfilestring); // filenameurlutils.getimagefilename(targetfilestring); if (in != null) { byte[] b = new byte[1024]; int len; while ((len = in.read(b)) != -1) { response.getoutputstream().write(b); } in.close(); } } }else{ log.info("原图目录不存在-preview:{}",dirstring); } } /** * ppt固定尺寸图片代理输出 * @throws ioexception * https://cache.yisu.com/upload/ask_collection/20210726/113/19154.png * * http://document.polyv.net/images/2016/03/de37d2ceb11ac068c18c5e4428541075/jpg-3.png */ @requestmapping("/images/{year}/{month}/{md5id}/{filename}/{width}x{height}.{ext}") public void cropfixedimage(@pathvariable string year, @pathvariable string month, @pathvariable string md5id, @pathvariable string filename, @pathvariable integer width, @pathvariable integer height, @pathvariable string ext, httpservletrequest request, httpservletresponse response) throws ioexception { // string rootdir = "/data03/ovp/blobs/"; string rootdir = systemconfig.getblobdirectory(); //string oname = filename.substring(1, filename.length());// 原图文件名 string dirstring = rootdir + year + "/" + month + "/" + md5id + "/" + ( filename + "." + ext); string targetfilestring = rootdir + year + "/" + month + "/" + md5id + "/" + filename + "/" + (width + "x" + height + "." + ext); //如果原图存在 file originimage = new file(dirstring); if(originimage.exists()){ file targetfilestringfile = new file(targetfilestring); if(!targetfilestringfile.exists()){ log.info("corpimage..." + dirstring + " -> " + targetfilestring); file newfile = new file(targetfilestring); string pathstring = newfile.getparent(); log.info("pathstring...{} {}", pathstring); file pathfile = new file(pathstring); if (!pathfile.exists()) { log.info("---create file---"); pathfile.mkdirs(); } imagemagickutils.resizewh(dirstring, targetfilestring,width,height); } response.setcontenttype("image/" + ext); java.io.inputstream in = null; try{ in = new java.io.fileinputstream(targetfilestring); response.setcontentlength(in.available()); byte[] buffer = new byte[1024]; int count = 0; while ((count = in.read(buffer)) > 0) { response.getoutputstream().write(buffer, 0, count); } response.flushbuffer(); }catch(exception e){ e.printstacktrace(); }finally { try { in.close(); } catch (exception e) { } } }else{ log.info("原图目录不存在:{}",dirstring); } } /** * 图片下载 */ @requestmapping("get/image/data") public void downloadimage(httpservletrequest request, httpservletresponse response) throws ioexception { string filepath = servletrequestutils.getstringparameter(request, "filepath", ""); //图片访问路劲 string filename = servletrequestutils.getstringparameter(request, "filename", ""); //名称 if(stringutils.isnotblank(filepath) || stringutils.isnotblank(filename)){ string desturl = filepath; //log.info("--------------"+filepath); string fileformat=filepath.substring(filepath.lastindexof(".")); //string name=filename.trim()+fileformat; string name=filepath.substring(filepath.lastindexof("/")+1, filepath.length()); //file f = new file(filepath); //response.setheader("content-disposition", "attachment; filename="+java.net.urlencoder.encode(f.getname(),"utf-8")); //log.info("--------------"+f.getname()); // 建立链接 url url = new url(desturl); httpurlconnection httpurl = (httpurlconnection) url.openconnection(); // 连接指定的资源 httpurl.connect(); // 获取网络输入流 bufferedinputstream bis = new bufferedinputstream(httpurl.getinputstream()); integer lenf=httpurl.getcontentlength(); //string lenf=this.getfilelength(4189053, 7189053); response.setcontenttype("application/x-msdownload"); response.setheader("content-length", lenf.tostring());//文件大小值5几m response.setheader("content-disposition", "attachment; filename="+java.net.urlencoder.encode(name,"utf-8")); outputstream out = response.getoutputstream(); byte[] buf = new byte[1024]; if (desturl != null) { bufferedinputstream br = bis; int len = 0; while ((len = br.read(buf)) > 0){ out.write(buf, 0, len); } br.close(); } out.flush(); out.close(); } } }
伺服器上要安裝imagemagick。
以上是Nginx代理輸出縮放圖片怎麼實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

可以通過以下步驟查詢 Docker 容器名稱:列出所有容器(docker ps)。篩選容器列表(使用 grep 命令)。獲取容器名稱(位於 "NAMES" 列中)。

如何在 Windows 中配置 Nginx?安裝 Nginx 並創建虛擬主機配置。修改主配置文件並包含虛擬主機配置。啟動或重新加載 Nginx。測試配置並查看網站。選擇性啟用 SSL 並配置 SSL 證書。選擇性設置防火牆允許 80 和 443 端口流量。

在雲服務器上配置 Nginx 域名的方法:創建 A 記錄,指向雲服務器的公共 IP 地址。在 Nginx 配置文件中添加虛擬主機塊,指定偵聽端口、域名和網站根目錄。重啟 Nginx 以應用更改。訪問域名測試配置。其他注意事項:安裝 SSL 證書啟用 HTTPS、確保防火牆允許 80 端口流量、等待 DNS 解析生效。

確認 Nginx 是否啟動的方法:1. 使用命令行:systemctl status nginx(Linux/Unix)、netstat -ano | findstr 80(Windows);2. 檢查端口 80 是否開放;3. 查看系統日誌中 Nginx 啟動消息;4. 使用第三方工具,如 Nagios、Zabbix、Icinga。

可以查詢 Nginx 版本的方法有:使用 nginx -v 命令;查看 nginx.conf 文件中的 version 指令;打開 Nginx 錯誤頁,查看頁面的標題。

在 Docker 中創建容器: 1. 拉取鏡像: docker pull [鏡像名] 2. 創建容器: docker run [選項] [鏡像名] [命令] 3. 啟動容器: docker start [容器名]

Docker 容器啟動步驟:拉取容器鏡像:運行 "docker pull [鏡像名稱]"。創建容器:使用 "docker create [選項] [鏡像名稱] [命令和參數]"。啟動容器:執行 "docker start [容器名稱或 ID]"。檢查容器狀態:通過 "docker ps" 驗證容器是否正在運行。

啟動 Nginx 服務器需要按照不同操作系統採取不同的步驟:Linux/Unix 系統:安裝 Nginx 軟件包(例如使用 apt-get 或 yum)。使用 systemctl 啟動 Nginx 服務(例如 sudo systemctl start nginx)。 Windows 系統:下載並安裝 Windows 二進製文件。使用 nginx.exe 可執行文件啟動 Nginx(例如 nginx.exe -c conf\nginx.conf)。無論使用哪種操作系統,您都可以通過訪問服務器 IP
