nginx正则匹配、全局常量

本文深入解析Nginx的location规则匹配、正则表达式应用、缓存设置、条件判断及变量使用,涵盖精准匹配、通配符使用、过期缓存管理、浏览器识别、文件与目录判断等多个方面。

1:Nginx location 规则匹配

^~          标识符匹配后面跟一个字符串。匹配字符串后将停止对后续的正则表达式进行匹配。

     		如:location ^~ /images/,  在匹配了/images、这个字符串后就停止对后续的匹配

=           精准匹配,如:location=/,只会匹配urrl为/的请求

~           区分大小写的匹配

~*          不区分大小写的匹配

!~          对区分大小写的匹配取非

!~*         对区分大小写的匹配取非

/           通用匹配,如果没有其他匹配,任何匹配请求都会被匹配到

2:正则表达式

*           重复前面的字符0次或多次

?           重复前面的字符0次或1+           重复前面的字符1次或多次

.           匹配除换行符以外的任意一个字符

(a | b)     匹配a或b

^.....开头

$           以.....结尾

{n}         重复前面的字符n次

{n,}        重复前面的字符n次或更多次

{n,m}       重复前面的字符n次到m次

*?          重复前面的字符0次或多次 ,但尽可能的少重复

+?          重复前面的字符1次或更多次 ,但尽可能的少重复

??          重复前面的字符0次或1,但尽可能的少重复

{n,m} ?     重复前面的字符n次或m次 ,但尽可能的少重复

{n,} ?      重复前面的字符n次以上 ,但尽可能的少重复

3:正则补充

\w          匹配任意不是字母,数字,下划线,汉子的字符

\s          匹配任意不是空白字符串的字符

\D          匹配任意非数字的字符

\B          匹配不是单词开头或结束的位置

[a]         匹配a-z小写字母的任意一个

[^a]        匹配除a以外的任意字符

4:过期缓存

expires      30d;

5:设置某些类型文件的浏览器缓存时间

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
    expires 30d;
}
location ~ .*\.(js|css)$
{
    expires 1h;
}

6:针对浏览器

location / {
    if ($http_user_agent ~* chrome) {
        return 503;
    }
}

7:判断文件,文件夹

-f和!-f用来判断是否存在文件
-d和!-d用来判断是否存在目录
-e和!-e用来判断是否存在文件或目录
-x和!-x用来判断文件是否可执行

8:全局变量

$args                  请求中的参数,如www.abc.com/test/hello?a=1&b=2的$args就是a=1&b=2
$document_root         Nginx虚拟主机配置文件中的root参数对应的值
$document_uri          当前请求中不包含指令的URI,如www.abc.com/test/hello?a=1&b=2的document_uri就是/test/hello,不包含后面的参数
$host                  主机头,也就是域名
$http_user_agent       客户端的详细信息,也就是浏览器的标识,用curl -A可以指定
$http_cookie           cookie信息
$limit_rate            如果Nginx服务器使用limit_rate配置了显示网络速率,则会显示,如果没有设置,则显示0
$remote_addr           客户端的公网IP
$remote_port           客户端的端口
$request_method        请求资源的方式,GET/PUT/DELETE等
$request_filename      当前请求的资源文件的路径名称,相当于是$document_root/$document_uri的组合
$request_uri           请求的链接,包括$document_uri和$args
$scheme                请求的协议,如ftp、http、https
$server_protocol       客户端请求资源使用的协议的版本,如HTTP/1.0,HTTP/1.1,HTTP/2.0等
$server_addr           服务器IP地址
$server_name           服务器的主机名           
$server_port           服务器的端口号
$uri                   和$document_uri相同
$http_referer          客户端请求时的referer,通俗讲就是该请求是通过哪个链接跳过来的

常用:$http_referer    
    $request_uri  
    $http_user_agent  

9:案例

args:name=zhangsan&age=15
document_root:/home/wwwroot/default/wounion/dragonfly/public
document_uri:/test/hello
host:jiqing.wounion.com
http_user_agent:Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/71.0.3578.80 Safari/537.36
http_cookie:PHPSESSID=3ire1fr9bl3qdpd787pv0qb7a5
limit_rate:0
remote_addr:127.0.0.1
remote_port:43180
request_method:GET
request_filename:/home/wwwroot/default/wounion/dragonfly/public/test/hello
request_uri:/test/hello?name=zhangsan&age=15
scheme:http
server_protocol:HTTP/1.1
server_addr:127.0.0.1
server_name:jiqing.wounion.com
server_port:80
uri:/test/hello
http_referer:
const path = require("path"); const productionGzipExtensions = ["js", "css"]; const CompressionWebpackPlugin = require("compression-webpack-plugin"); // 开启压缩 const TerserPlugin = require("terser-webpack-plugin"); // 代码压缩和混淆 module.exports = { configureWebpack: (config) => { const isProduction = process.env.NODE_ENV === "production"; const isMiniProgram = process.env.UNI_PLATFORM?.startsWith("mp-"); // 生产环境 + 小程序 启用增强混淆 if (isProduction && isMiniProgram) { config.optimization = config.optimization || {}; config.optimization.minimizer = [ new TerserPlugin({ terserOptions: { compress: { drop_console: false, // 小程序开发可能需要保留 console,上线时可改为 true drop_debugger: true, // 移除 debugger pure_funcs: ["console.log", "console.debug"], // 移除指定的函数调用(不影响 console.error 和 console.warn) passes: 3, // 多次压缩以获得更好的压缩效果 unsafe: true, // 启用不安全的优化 unsafe_comps: true, // 压缩比较表达式 unsafe_math: true, // 优化数学表达式 unsafe_proto: true, // 优化原型链 unsafe_regexp: true, // 优化正则表达式 dead_code: true, // 移除死代码 unused: true, // 移除未使用的变量 collapse_vars: true, // 内联变量 reduce_vars: true, // 减少变量使用 evaluate: true, // 计算常量表达式 side_effects: false, // 保留副作用(小程序环境需要) }, mangle: { // 混淆变量名和函数名 toplevel: false, // 小程序环境建议设为 false,避免影响全局变量和 uni-app 框架 properties: false, // 小程序环境必须关闭属性混淆,避免影响组件属性绑定 safari10: true, // 兼容 Safari 10 }, format: { comments: false, // 移除所有注释 ascii_only: true, // 转义 Unicode 字符为 ASCII,避免小程序编码问题 beautify: false, // 不美化输出,保持压缩格式 }, keep_classnames: false, // 混淆类名 keep_fnames: false, // 混淆函数名 ecma: 2015, // 指定 ECMAScript 版本,兼容小程序环境 }, extractComments: false, // 不提取注释到单独文件 parallel: true, // 使用多进程并行运行,加快构建速度 minify: TerserPlugin.terserMinify, // 使用 terser 压缩 }), ]; } // 添加 Gzip 压缩插件 config.plugins = config.plugins || []; config.plugins.push( new CompressionWebpackPlugin({ // 生成的压缩文件名格式,保留原路径和查询参数,例如 app.js → app.js.gz filename: "[path].gz[query]", //使用 gzip 压缩算法 algorithm: "gzip", // 正则匹配需要压缩的文件,匹配 .js 和 .css test: new RegExp("\\.(" + productionGzipExtensions.join("|") + ")$"), // 只压缩大于 100KB(102400 字节)的文件 threshold: 102400, // 压缩后体积小于原体积 80% 才生成压缩文件 minRatio: 0.8, // 保留原始文件,不删除 deleteOriginalAssets: false, //是否删除源文件 }) ); return config; }, };
最新发布
11-07
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值