龙空技术网

springboot+thymeleaf+nginx实现页面静态化

独行者pxl 6255

前言:

目前咱们对“nginx配置静态文件访问”大致比较重视,我们都需要知道一些“nginx配置静态文件访问”的相关知识。那么小编在网摘上汇集了一些有关“nginx配置静态文件访问””的相关内容,希望大家能喜欢,朋友们一起来了解一下吧!

适用场景在高并发的情况下,为了缓解服务器动态解析的压力,利用nginx处理静态文件的优点,可将系统中修改次数较少的页面进行静态化处理。自定义工具类

import org.thymeleaf.TemplateEngine;import org.thymeleaf.context.Context;import java.io.File;import java.io.IOException;import java.io.PrintWriter;import java.util.HashMap;public class ThymelafUtils {    /**     * 生成页面的方法     * @param variables 传入参数     * @param dirPath   文件目录地址     * @param filePath  文件地址路径     * @param templatePage 模板页面     * @param templateEngine 模板引擎     */    public static void createHtmlPage(HashMap variables, String dirPath, String filePath, String templatePage,TemplateEngine templateEngine){        // 创建上下文,        Context context = new Context();        // 把数据加入上下文        context.setVariables(variables);        if (!new File(dirPath).exists()){            new File(dirPath).mkdirs();        }        // 创建输出流,关联到一个临时文件        File temp = new File(filePath);        try (PrintWriter writer = new PrintWriter(temp, "UTF-8")) {            // 利用thymeleaf模板引擎生成 静态页面            templateEngine.process(templatePage, context, writer);        } catch (IOException e) {            System.out.println("页面静态化出错:{}"+e.getMessage());        }    }}
nginx环境配置
server {        listen       80;        server_name  location;		#区分大小写匹配.html结尾的请求		location ~ \.html{			root html;   #本人将静态化的页面放入nginx的html目录下,可根据需求自行修改			if (!-f $request_filename) { #请求的文件不存在,就反向代理				proxy_pass ;    #地址路径为要生成页面的请求路径(自行修改)				break;			}		}	}
配置文件(application.properties)
#为nginx安装目录中html下htmlPath=E:/nginx/nginx-1.16.0/nginx-1.16.0/html/   
调用方法
    @Autowired    private TemplateEngine templateEngine;//模板引擎    @Value("${htmlPath}")    String htmlPath;  //生成文件路径的地址    @RequestMapping(value = "/{skuId}.html",method = RequestMethod.GET)    public String getItemInfo(@PathVariable("skuId") String skuId, Model model){        //配置传入参数        HashMap<String,Object> variables=new HashMap();      //自行根据业务需求将数据以kv键值对的形式将参数进行传入        //variables.put("skuInfo",skuInfo);        //设置路径        String filePath=htmlPath+skuId+".html";        //生成页面的模板页面地址        String templatePage="item";        //本人自己新增静态化页面的功能        ThymelafUtils.createHtmlPage(variables,htmlPath,filePath,templatePage,templateEngine);        return "redirect:"+skuId+".html";  //将服务重定向,若存在静态页面,就直接有nginx转发    }
实现思路利用thymeleaf模板引擎进行页面静态化,将生成的页面放入nginx安装目录的html文件夹下。页面生成后请求重定向给nginx进行转发。用户访问时,先有nginx判断是否有该页面,若无,则将请求发送给controller层进行页面的创建。

标签: #nginx配置静态文件访问