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; } } }
Agent는 확대된 사진을 출력합니다
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(); } } }
사진 확대 작업
package com.document.tool; import java.io.ioexception; import javax.swing.imageicon; import org.apache.commons.exec.commandline; import org.apache.commons.exec.defaultexecuteresulthandler; import org.apache.commons.exec.defaultexecutor; import org.apache.commons.exec.executeexception; import org.apache.commons.exec.executewatchdog; import org.apache.commons.exec.executor; import org.slf4j.logger; import org.slf4j.loggerfactory; /** * 使用imagemagick对图片文件进行处理的工具类。 * @author xingning ou */ public abstract class imagemagickutils { private static final string executable_convert = "/usr/bin/convert"; // convert命令 private static final string executable_composite = "/usr/bin/composite"; // composite命令 private static final long execute_timeout = 30 * 60 * 1000l; // 30 minutes private static final logger log = loggerfactory.getlogger(imagemagickutils.class); /** * 执行图片处理的命令。 * @param cmdline 待执行的命令 * @return exitvalue,一般等于0时表示正常运行结束 * @throws executeexception 命令执行失败时抛出此异常 * @throws ioexception 当发生io错误时抛出此异常 * @throws interruptedexception 当等待异步返回结果被中断时抛出此异常 */ public static int executecommandline(commandline cmdline) throws executeexception, ioexception, interruptedexception { executor executor = new defaultexecutor(); executor.setexitvalue(0); // kill a run-away process after execute_time milliseconds. executewatchdog watchdog = new executewatchdog(execute_timeout); executor.setwatchdog(watchdog); // execute the print job asynchronously. defaultexecuteresulthandler resulthandler = new defaultexecuteresulthandler(); executor.execute(cmdline, resulthandler); // some time later the result handler callback was invoked. resulthandler.waitfor(); // so we can safely request the exit value. return resulthandler.getexitvalue(); } /** * 按照高宽比例缩小图片。 * @param src 源图片 * @param dst 目标图片 * @param width 图片图片的宽度 * @param height 目标图片的高度 * @return 是否处理成功 */ public static boolean scale(string src, string dst, int width, int height) { // 构建命令 commandline cmdline = new commandline(executable_convert); cmdline.addargument(src); cmdline.addargument("-scale"); cmdline.addargument(width + "x" + height); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("缩略图片时发生异常,cause: ", e); return false; } } /** * 按照高宽比例缩小图片。 * @param src 源图片 * @param dst 目标图片 * @param width 图片图片的宽度 * @param height 目标图片的高度 * @return 是否处理成功 */ public static boolean thumbnail(string src, string dst, int width, int height) { // 构建命令 commandline cmdline = new commandline(executable_convert); cmdline.addargument(src); cmdline.addargument("-thumbnail"); cmdline.addargument(width + "x" + height); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("缩略图片时发生异常,cause: ", e); return false; } } /** * 添加图片水印。 * @param src 源图片 * @param dst 目标图片 * @param logofile 水印图片 * @param dissolve 和水印的融合度,0-100的数字 * @param gravity 叠放方向,east,west,north,south,northeast,northwest,southeast,southwest * @return 是否处理成功 */ public static boolean drawlogo(string src, string dst, string logofile, int dissolve, string gravity) { // 构建命令 commandline cmdline = new commandline(executable_composite); cmdline.addargument("-dissolve"); cmdline.addargument(dissolve + "%"); cmdline.addargument("-gravity"); cmdline.addargument(gravity); cmdline.addargument(logofile); cmdline.addargument(src); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("添加图片水印时发生异常,cause: ", e); return false; } } /** * 添加图片水印。 * @param src 源图片 * @param dst 目标图片 * @param logofile 水印图片 * @param dissolve 和水印的融合度,0-100的数字 * @param x 水印距离左下角的距离 * @param y 水印距离右下角的距离 * @return 是否处理成功 */ public static boolean drawlogo(string src, string dst, string logofile, int dissolve, int x, int y) { imageicon icon = new imageicon(src); int width = icon.geticonwidth(); // 源图的宽 int height = icon.geticonheight(); // 源图的高 string _x = string.valueof(width - x); // 在x轴上水印图片的左上顶点距离图片左上角的距离 string _y = string.valueof(height - y); // 在y轴上水印图片的左上顶点距离图片左上角的距离 // 构建命令 commandline cmdline = new commandline(executable_composite); cmdline.addargument("-dissolve"); cmdline.addargument(dissolve + "%"); cmdline.addargument("-geometry"); cmdline.addargument(_x + "+" + _y); cmdline.addargument(logofile); cmdline.addargument(src); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("添加图片水印时发生异常,cause: ", e); return false; } } /** * 裁剪图片。 * @param src 源图片 * @param dst 目标图片 * @param width 目标宽度 * @param height 目标高度 * @param left 裁剪位置:距离左边的像素 * @param top 裁剪位置:距离上边的像素 * @return 是否处理成功 */ public static boolean crop(string src, string dst, int width, int height, int left, int top) { // 构建命令 commandline cmdline = new commandline(executable_convert); cmdline.addargument(src); cmdline.addargument("-crop"); cmdline.addargument(width + "x" + height + "+" + left + "+" + top); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("裁剪图片时发生异常,cause: ", e); return false; } } /** * 获取矩形的小图。 * @param src 源图片 * @param dst 目标图片 * @param width 目标宽度 * @param height 目标高度 * @param left 裁剪位置:距离左边的像素 * @param top 裁剪位置:距离上边的像素 * @return 是否处理成功 */ public static boolean croprect(string src, string dst, int width, int height, int left, int top) { imageicon icon = new imageicon(src); int origwidth = icon.geticonwidth(); int origheight = icon.geticonheight(); int[] s = new int[2]; if (origwidth < origheight) { // 以宽为标准 s = getsize(origwidth, origheight, width, height, 1); } else {// 以高为标准 s = getsize(origwidth, origheight, width, height, 2); } if (thumbnail(src, dst, s[0], s[1])) { return crop(src, dst, width, height, left, top); } return false; } /** * 加边框。 * @param src 源图片 * @param dst 目标图片 * @param borderwidth 边框的宽度 * @param borderheight 边框的高度 * @param bordercolor 边框的颜色 * @return 是否处理成功 */ public static boolean border(string src, string dst, int borderwidth, int borderheight, string bordercolor) { // 构建命令 commandline cmdline = new commandline(executable_convert); cmdline.addargument("-bordercolor"); cmdline.addargument(bordercolor); cmdline.addargument("-border"); cmdline.addargument(borderwidth + "x" + borderheight); cmdline.addargument(src); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("加图片边框时发生异常,cause: ", e); return false; } } /** * 转换图片格式。 * @param src 源图片 * @param dst 目标图片 * @param format 转换的格式 * @return 是否处理成功 */ public static boolean format(string src, string dst, string format) { // 构建命令 commandline cmdline = new commandline(executable_convert); cmdline.addargument(src); cmdline.addargument("-format"); cmdline.addargument("'" + format + "'"); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("转换图片格式时发生异常,cause: ", e); return false; } } /** * 转换无限极的tiff图片。 */ public static boolean converttiff(string src, string dst) { // 构建命令 commandline cmdline = new commandline(executable_convert); cmdline.addargument(src); cmdline.addargument("-colorspace"); cmdline.addargument("rgb"); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("转换图片格式时发生异常,cause: ", e); return false; } } /** * 获得要压缩图片的大小。 * @param w 图片的原宽度 * @param h 图片的原高度 * @param width 标准宽 * @param height 标准高 * @param type 类型 1-以宽为标准压缩 2-以高为标准压缩 3-以比例大小压缩 * @return size[0]-要压缩的宽度, size[1]-要压缩的高度 */ public static int[] getsize(double w, double h, double width, double height, int type) { if (w < width) {// 如果原宽度比标准宽度小 width = w; } if (h < height) {// 如果原高度比标准高度小 height = h; } double scale = w / h; switch (type) { case 1: height = width / scale; break; case 2: width = height * scale; break; case 3: if (width / height > scale) { width = height * scale; } else if ((width / height) < scale) { height = width / scale; } break; } int[] size = new int[2]; size[0] = (int) width; size[1] = (int) height; return size; } /** * 指定宽度。 * @param src * @param width * @param dst */ public static boolean resize(string src, int width, string dst) { // 构建命令 commandline cmdline = new commandline(executable_convert); cmdline.addargument(src); cmdline.addargument("-resize"); cmdline.addargument(width + ""); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("缩略图片时发生异常,cause: ", e); return false; } } /** * 指定宽度、高度。 * @param src * @param width * @param dst */ public static boolean resizewh(string src,string dst, int width, int height ) { // 构建命令 commandline cmdline = new commandline(executable_convert); cmdline.addargument(src); cmdline.addargument("-resize"); cmdline.addargument(width + "x" + height +"!"); cmdline.addargument(dst); try { executecommandline(cmdline); return true; } catch (exception e) { log.error("缩略图片时发生异常,cause: ", e); return false; } } }
imagemagick을 서버에 설치해야 합니다.
위 내용은 Nginx 프록시 출력 확대/축소 이미지 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











클라우드 서버에서 nginx 도메인 이름을 구성하는 방법 : 클라우드 서버의 공개 IP 주소를 가리키는 레코드를 만듭니다. Nginx 구성 파일에 가상 호스트 블록을 추가하여 청취 포트, 도메인 이름 및 웹 사이트 루트 디렉토리를 지정합니다. Nginx를 다시 시작하여 변경 사항을 적용하십시오. 도메인 이름 테스트 구성에 액세스하십시오. 기타 참고 : HTTPS를 활성화하려면 SSL 인증서를 설치하고 방화벽에서 포트 80 트래픽을 허용하고 DNS 해상도가 적용되기를 기다립니다.

nginx 버전을 쿼리 할 수있는 메소드는 다음과 같습니다. nginx -v 명령을 사용하십시오. nginx.conf 파일에서 버전 지시문을 봅니다. nginx 오류 페이지를 열고 페이지 제목을 봅니다.

Nginx 서버를 시작하려면 다른 운영 체제에 따라 다른 단계가 필요합니다. Linux/Unix System : Nginx 패키지 설치 (예 : APT-Get 또는 Yum 사용). SystemCTL을 사용하여 nginx 서비스를 시작하십시오 (예 : Sudo SystemCtl start nginx). Windows 시스템 : Windows 바이너리 파일을 다운로드하여 설치합니다. nginx.exe 실행 파일을 사용하여 nginx를 시작하십시오 (예 : nginx.exe -c conf \ nginx.conf). 어떤 운영 체제를 사용하든 서버 IP에 액세스 할 수 있습니다.

단계를 따르면 Docker 컨테이너 이름을 쿼리 할 수 있습니다. 모든 컨테이너 (Docker PS)를 나열하십시오. 컨테이너 목록을 필터링합니다 (GREP 명령 사용). 컨테이너 이름 ( "이름"열에 위치)을 가져옵니다.

Windows에서 Nginx를 구성하는 방법은 무엇입니까? nginx를 설치하고 가상 호스트 구성을 만듭니다. 기본 구성 파일을 수정하고 가상 호스트 구성을 포함하십시오. 시작 또는 새로 고침 Nginx. 구성을 테스트하고 웹 사이트를보십시오. SSL을 선택적으로 활성화하고 SSL 인증서를 구성하십시오. 포트 80 및 443 트래픽을 허용하도록 방화벽을 선택적으로 설정하십시오.

nginx가 시작되었는지 확인하는 방법 : 1. 명령 줄을 사용하십시오 : SystemCTL 상태 nginx (linux/unix), netstat -ano | Findstr 80 (Windows); 2. 포트 80이 열려 있는지 확인하십시오. 3. 시스템 로그에서 nginx 시작 메시지를 확인하십시오. 4. Nagios, Zabbix 및 Icinga와 같은 타사 도구를 사용하십시오.

Docker Container Startup 단계 : 컨테이너 이미지를 당기기 : "Docker Pull [Mirror Name]"을 실행하십시오. 컨테이너 생성 : "docker"[옵션] [미러 이름] [명령 및 매개 변수]를 사용하십시오. 컨테이너를 시작하십시오 : "Docker start [컨테이너 이름 또는 ID]"를 실행하십시오. 컨테이너 상태 확인 : 컨테이너가 "Docker PS"로 실행 중인지 확인하십시오.

Nginx가 Apache를 실행하려면 다음을 수행해야합니다. 1. Nginx 및 Apache를 설치하십시오. 2. NGINX 에이전트를 구성합니다. 3. nginx와 apache를 시작하십시오. 4. 구성을 테스트하여 도메인 이름에 액세스 한 후 Apache 컨텐츠를 볼 수 있는지 확인하십시오. 또한 포트 번호 매칭, 가상 호스트 구성 및 SSL/TLS 설정과 같은 다른 문제에주의를 기울여야합니다.
