-
nginx的location配置详解
2016-03-15 17:04:03语法规则:location [=|~|~*|^~] /uri/ { … } =开头表示精确匹配 ^~开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配...语法规则: location [=|~|~*|^~] /uri/ { … }= 开头表示精确匹配^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)。~ 开头表示区分大小写的正则匹配~* 开头表示不区分大小写的正则匹配!~和!~*分别为区分大小写不匹配及不区分大小写不匹配 的正则/ 通用匹配,任何请求都会匹配到。多个location配置的情况下匹配顺序为(参考资料而来,还未实际验证,试试就知道了,不必拘泥,仅供参考):首先匹配 =,其次匹配^~, 其次是按文件中顺序的正则匹配,最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。例子,有如下匹配规则:
location = / { #规则A } location = /login { #规则B } location ^~ /static/ { #规则C } location ~ \.(gif|jpg|png|js|css)$ { #规则D } location ~* \.png$ { #规则E } location !~ \.xhtml$ { #规则F } location !~* \.xhtml$ { #规则G } location / { #规则H }
那么产生的效果如下:访问根目录/, 比如http://localhost/ 将匹配规则A访问 http://localhost/login 将匹配规则B,http://localhost/register 则匹配规则H访问 http://localhost/static/a.html 将匹配规则C访问 http://localhost/a.gif, http://localhost/b.jpg 将匹配规则D和规则E,但是规则D顺序优先,规则E不起作用,而 http://localhost/static/c.png 则优先匹配到 规则C访问 http://localhost/a.PNG 则匹配规则E, 而不会匹配规则D,因为规则E不区分大小写。访问 http://localhost/a.xhtml 不会匹配规则F和规则G,http://localhost/a.XHTML不会匹配规则G,因为不区分大小写。规则F,规则G属于排除法,符合匹配规则但是不会匹配到,所以想想看实际应用中哪里会用到。访问 http://localhost/category/id/1111 则最终匹配到规则H,因为以上规则都不匹配,这个时候应该是nginx转发请求给后端应用服务器,比如FastCGI(php),tomcat(jsp),nginx作为方向代理服务器存在。所以实际使用中,通常至少有三个匹配规则定义,如下:#直接匹配网站根,通过域名访问网站首页比较频繁,使用这个会加速处理,官网如是说。 #这里是直接转发给后端应用服务器了,也可以是一个静态首页 # 第一个必选规则 location = / { proxy_pass http://tomcat:8080/index } # 第二个必选规则是处理静态文件请求,这是nginx作为http服务器的强项 # 有两种配置模式,目录匹配或后缀匹配,任选其一或搭配使用 location ^~ /static/ { root /webroot/static/; } location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ { root /webroot/res/; } #第三个规则就是通用规则,用来转发动态请求到后端应用服务器 #非静态文件请求就默认是动态请求,自己根据实际把握 #毕竟目前的一些框架的流行,带.php,.jsp后缀的情况很少了 location / { proxy_pass http://tomcat:8080/ }
以下部分直接copy过来的,有点乱,可以作为参考
三、ReWrite语法
last – 基本上都用这个Flag。
break – 中止Rewirte,不在继续匹配
redirect – 返回临时重定向的HTTP状态302
permanent – 返回永久重定向的HTTP状态301注:last和break最大的不同在于- break是终止当前location的rewrite检测,而且不再进行location匹配 - last是终止当前location的rewrite检测,但会继续重试location匹配并处理区块中的rewrite规则
1、下面是可以用来判断的表达式:
-f和!-f用来判断是否存在文件
-d和!-d用来判断是否存在目录
-e和!-e用来判断是否存在文件或目录
-x和!-x用来判断文件是否可执行
2、下面是可以用作判断的全局变量
$args #这个变量等于请求行中的参数。$content_length #请求头中的Content-length字段。$content_type #请求头中的Content-Type字段。$document_root #当前请求在root指令中指定的值。$host #请求主机头字段,否则为服务器名称。$http_user_agent #客户端agent信息$http_cookie #客户端cookie信息$limit_rate #这个变量可以限制连接速率。$request_body_file #客户端请求主体信息的临时文件名。$request_method #客户端请求的动作,通常为GET或POST。$remote_addr #客户端的IP地址。$remote_port #客户端的端口。$remote_user #已经经过Auth Basic Module验证的用户名。$request_filename #当前请求的文件路径,由root或alias指令与URI请求生成。$query_string #与$args相同。$scheme #HTTP方法(如http,https)。$server_protocol #请求使用的协议,通常是HTTP/1.0或HTTP/1.1。$server_addr #服务器地址,在完成一次系统调用后可以确定这个值。$server_name #服务器名称。$server_port #请求到达服务器的端口号。$request_uri #包含请求参数的原始URI,不包含主机名,如:”/foo/bar.php?arg=baz”。$uri #不带请求参数的当前URI,$uri不包含主机名,如”/foo/bar.html”。$document_uri #与$uri相同。例:http://localhost:88/test1/test2/test.php
$host:localhost
$server_port:88
$request_uri:http://localhost:88/test1/test2/test.php
$document_uri:/test1/test2/test.php
$document_root:D:\nginx/html
$request_filename:D:\nginx/html/test1/test2/test.php
四、Redirect语法
多目录转成参数
abc.domian.com/sort/2 => abc.domian.com/index.php?act=sort&name=abc&id=21. if ($host ~* (.*)\.domain\.com) {2. set $sub_name $1;3. rewrite ^/sort\/(\d+)\/?$ /index.php?act=sort&cid=$sub_name&id=$1 last;4. }目录对换
/123456/xxxx -> /xxxx?id=1234561. rewrite ^/(\d+)/(.+)/ /$2?id=$1 last;例如下面设定nginx在用户使用ie的使用重定向到/nginx-ie目录下:1. if ($http_user_agent ~ MSIE) {2. rewrite ^(.*)$ /nginx-ie/$1 break;3. }目录自动加“/”1. if (-d $request_filename){2. rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;3. }禁止htaccess1. location ~/\.ht {2. deny all;3. }禁止多个目录1. location ~ ^/(cron|templates)/ {2. deny all;3. break;4. }禁止以/data开头的文件
可以禁止/data/下多级目录下.log.txt等请求;1. location ~ ^/data {2. deny all;3. }禁止单个目录
不能禁止.log.txt能请求1. location /searchword/cron/ {2. deny all;3. }禁止单个文件1. location ~ /data/sql/data.sql {2. deny all;3. }给favicon.ico和robots.txt设置过期时间;
这里为favicon.ico为99 天,robots.txt为7天并不记录404错误日志1. location ~(favicon.ico) {2. log_not_found off;3. expires 99d;4. break;5. }6.7. location ~(robots.txt) {8. log_not_found off;9. expires 7d;10. break;11. }设定某个文件的过期时间;这里为600秒,并不记录访问日志1. location ^~ /html/scripts/loadhead_1.js {2. access_log off;3. root /opt/lampp/htdocs/web;4. expires 600;5. break;6. }文件反盗链并设置过期时间
这里的return 412 为自定义的http状态码,默认为403,方便找出正确的盗链的请求
“rewrite ^/ http://leech.c1gstudio.com/leech.gif;”显示一张防盗链图片
“access_log off;”不记录访问日志,减轻压力
“expires 3d”所有文件3天的浏览器缓存1. location ~* ^.+\.(jpg|jpeg|gif|png|swf|rar|zip|css|js)$ {2. valid_referers none blocked *.c1gstudio.com *.c1gstudio.net localhost 208.97.167.194;3. if ($invalid_referer) {4. rewrite ^/ http://leech.c1gstudio.com/leech.gif;5. return 412;6. break;7. }8. access_log off;9. root /opt/lampp/htdocs/web;10. expires 3d;11. break;12. }只充许固定ip访问网站,并加上密码1. root /opt/htdocs/www;2. allow 208.97.167.194;3. allow 222.33.1.2;4. allow 231.152.49.4;5. deny all;6. auth_basic "C1G_ADMIN";7. auth_basic_user_file htpasswd;将多级目录下的文件转成一个文件,增强seo效果
/job-123-456-789.html 指向/job/123/456/789.html1. rewrite ^/job-([0-9]+)-([0-9]+)-([0-9]+)\.html$ /job/$1/$2/jobshow_$3.html last;将根目录下某个文件夹指向2级目录
如/shanghaijob/ 指向 /area/shanghai/
如果你将last改成permanent,那么浏览器地址栏显是 /location/shanghai/1. rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last;上面例子有个问题是访问/shanghai 时将不会匹配1. rewrite ^/([0-9a-z]+)job$ /area/$1/ last;2. rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last;这样/shanghai 也可以访问了,但页面中的相对链接无法使用,
如./list_1.html真实地址是/area /shanghia/list_1.html会变成/list_1.html,导至无法访问。那我加上自动跳转也是不行咯
(-d $request_filename)它有个条件是必需为真实目录,而我的rewrite不是的,所以没有效果1. if (-d $request_filename){2. rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;3. }知道原因后就好办了,让我手动跳转吧1. rewrite ^/([0-9a-z]+)job$ /$1job/ permanent;2. rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last;文件和目录不存在的时候重定向:1. if (!-e $request_filename) {2. proxy_pass http://127.0.0.1;3. }域名跳转1. server2. {3. listen 80;4. server_name jump.c1gstudio.com;5. index index.html index.htm index.php;6. root /opt/lampp/htdocs/www;7. rewrite ^/ http://www.c1gstudio.com/;8. access_log off;9. }多域名转向1. server_name www.c1gstudio.com www.c1gstudio.net;2. index index.html index.htm index.php;3. root /opt/lampp/htdocs;4. if ($host ~ "c1gstudio\.net") {5. rewrite ^(.*) http://www.c1gstudio.com$1 permanent;6. }三级域名跳转1. if ($http_host ~* "^(.*)\.i\.c1gstudio\.com$") {2. rewrite ^(.*) http://top.yingjiesheng.com$1;3. break;4. }域名镜向1. server2. {3. listen 80;4. server_name mirror.c1gstudio.com;5. index index.html index.htm index.php;6. root /opt/lampp/htdocs/www;7. rewrite ^/(.*) http://www.c1gstudio.com/$1 last;8. access_log off;9. } -
关于VUE项目中报Error: Avoided redundant navigation to current location: 的错
2020-06-05 10:41:43在VUE中路由遇到Error: Avoided redundant navigation to current location:报错显示是路由重复, 虽然对项目无影响,但是看到有红的还是不舒服。 于是查了一下发现可以这样解决 在你引入VueRouter的时候再加上一句...在VUE中路由遇到
Error: Avoided redundant navigation to current location:
报错显示是路由重复,
虽然我项目中引入的是vant,
但是不管你引入的是什么ui框架,报错本质不变,
虽然对项目无影响,但是看到有红的还是不舒服。
于是查了一下发现可以这样解决
在你引入VueRouter的时候再加上一句话(我是在mainJs里面,你们可根据自身情况添加):
const originalPush = VueRouter.prototype.push VueRouter.prototype.push = function push(location) { return originalPush.call(this, location).catch(err => err) }
这样就可以解决此报错。
觉得有用的可以用你们即将年薪上50w的双手给博主点个赞吗~~ 爱你们哟
有你们的支持是我最大的动力~
后续会常更新一些项目问题,以及一些技术问题
-
Location IOS12.3驱动
2019-05-07 09:04:06Location你们懂的,谢谢那些大佬的分享。前段时间把手机系统升级成测试版IOS12.3了,导致一直找不到驱动,今天有幸在@_小呵呵 的博客里找到DeviceSupport 12.3。修改了一下名字验证能用。 查看博客!有链接 -
详解location对象
2020-06-15 16:31:28Location 接口表示其链接到的对象的位置(URL)。所做的修改反映在与之相关的对象上。 Document 和 Window 接口都有这样一个链接的Location,分别通过 Document.location和Window.location 访问。首先控制打印看一下
1. location属性
console.log(location)
location是挂在window的对象也是document下的对象
window.location document.location location // 指的是同一个
以下方的url地址为例测试location
http://127.0.0.1:8848/testshare/location.html?lang=en&name=zhangsan#test/most
- Location.href
包含整个URL地址返回
href: "http://127.0.0.1:8848/testshare/location.html?lang=en&name=zhangsan#test/most"
当location.href赋值时会跳转
location.href = 'http://www.baidu.com' // 跳转
- Location.protocol
包含URL对应协议 http 或者https,最后有一个":"。
protocol: "http:"
- Location.host
包含了域名,可能在该串最后带有一个":"并跟上URL的端口号。
host: "127.0.0.1:8848"
- Location.hostname
包含URL域名
hostname: "127.0.0.1"
- Location.port
包含端口号。
port: "8848"
- Location.pathname
包含URL中路径部分,开头有一个“/"。
pathname: "/testshare/location.html"
- Location.search
包含URL参数,开头有一个“?”。
search: "?lang=en&name=zhangsan"
- Location.hash
包含块标识符,开头有一个“#”。 哈希值 vue-router中的哈希模式就是用这个。
hash: "#test/most"
- Location.origin 只读
包含页面来源的域名,也是从哪个页面跳转来的
origin: "http://127.0.0.1:8848"
全部打印结果为
2. location的方法
- Location.reload()
Location.reload()
方法用来刷新当前页面。该方法只有一个参数,当值为true
时,将强制浏览器从服务器加载页面资源,当值为false
或者未传参时,浏览器则可能从缓存中读取页面。location.reload(true); // 无缓存刷新页面(但页面引用的资源还是可能使用缓存, // 大多数浏览器可以通过设置在打开开发者工具时禁用缓存实现无缓存需求)
Location.assign()
Location.assign()方法会触发窗口加载并显示指定的URL的内容
document.location.assign('https://www.baidu.com');
Location
.replace()
Location
.replace()
方法以给定的URL来替换当前的资源。 与assign()
方法 不同的是,调用replace()
方法后,当前页面不会保存到会话历史中(sessionHistory
),这样,用户点击回退按钮时,将不会再跳转到该页面。document.location.replace('https://www.baidu.com');
-
Nginx一个server配置多个location
2019-05-28 14:55:33在配置文件中增加多个location,每个location对应一个项目 比如使用80端口,location / 访问官网; location /train 访问培训管理系统 配置多个站点 我选择了配置多个location。 location / { root /data/html/; ...公司测试环境使用nginx部署多个前端项目。网上查到了两个办法:
- 在配置文件中增加多个location,每个location对应一个项目
比如使用80端口,location / 访问官网; location /train 访问培训管理系统 - 配置多个站点
我选择了配置多个location。
location / { root /data/html/; index index.html index.html; } location /train { root /data/trainning/; index index.html index.html; }
配置完以后访问。http://xxxx/train 提示404
找了好久才搞明白, location如果一个特定的url 要使用别名,不能用root,alias指定的目录是准确的,root是指定目录的上级目录,改动后即可以使用了location /train { alias /data/trainning/; index index.html index.html; }
==========================================
补充
==========================================
留言中有小伙伴问及alias和root区别,个人理解:
root与alias主要区别在于nginx如何解释location后面的uri,这会使两者分别以不同的方式将请求映射到服务器文件上。 root的处理结果是:root路径+location路径 alias的处理结果是:使用alias路径替换location路径 alias是一个目录别名的定义,root则是最上层目录的定义。 还有一个重要的区别是alias后面必须要用“/”结束,否则会找不到文件的。。。而root则可有可无~~ - 在配置文件中增加多个location,每个location对应一个项目
-
window location跳转
2019-06-20 10:38:56"top.location.href"是最外层的页面跳转 "window.location.href"、"location.href"是本页面跳转 "parent.location.href"是上一层页面跳转. location是window对象的属性,而所有的网页下的对象都是属于window作用域... -
location用法
2018-11-03 13:20:17location.replace 跳转地址但不会生成后退按钮 location.reload 重新加载此页面 location.host获取主机地址 location.pathname 获取项目目录 loaction.port 获取端口号 location.search 获取url后带的参数 ... -
location对象
2019-04-25 14:37:18location对象是window对象中的一个属性值,可以通过window.location访问。罗列下location的一些属性和方法: location对象的属性有: 属性 描述 返回值举例 hash 设置或返回从井号 (#) 开始的 URL(锚... -
top.location与this.location
2018-04-23 11:51:19top.location != this.location 就是说当前窗体的url和父窗体的 url不相同(url主要是指是否为同一个域)通常情况下的用法为:if(top.location != this.location){ top.location=this.location;}这个主要是为了防止别... -
location.href与location.hash的区别
2019-08-02 11:33:13综:window.location.href表示重定向,后面跟着的是完整的url地址,与其相似的还有window.location.hash, 下面来比较window.location.href和window.locaiton.hash的区别。 (1)window.location.href 得到和使用... -
location.href/location.search/location.pathname区别及用法
2016-05-20 15:47:53location.href/location.search/location.pathname区别及用法 -
修改手机定位 之 Fake Location 软件使用教程
2019-07-25 20:28:39Fake Location是一款可以修改手机定位的app软件,使用起来也非常简单 ~ 用处: 上班公司打卡永不缺勤迟到 微信、陌陌、探探等社交软件搜索更多附近人 隐藏真实位置信息 可参考官方使用技巧文档:... -
location.host 与 location.hostname 的区别
2018-10-25 17:07:50location.host 与 location.hostname 的区别 location.host 包含端口(端口是80的话,就不显示) location.hostname 不包含端口 // http://localhost:8888/#/ location.host //"localhost:8888" ... -
$location 和 window.location的区别
2017-04-06 19:00:28$location和window.location的利弊 -
location.href和location.search区别
2017-07-31 09:38:03location.href和location.search区别:location.href返回完整的 URL,如:var url = location.href; //url=http://write.blog.csdn.net/postedit?ref=toolbar&ticket=ST-238906-YIVrWAhpAUsswkCIvYkb-... -
nginx配置location项的URL匹配规则
2018-05-28 00:55:25Localtion URL的正则匹配规则 示例 location / { try_files $uri @apache; } #所有的路径都是/开头,表示匹配所有 location @apache { inter... -
Nginx 之 Location 模块: location ~ \.php$
2020-04-27 23:00:49location ~ .php$ location ~ \.php$ { root html; fastcgi_pass 127.0.0.1:9000; #将请求转发给本机9000端口,PHP解释器 fastcgi_index index.php; #fast... -
Android开发者接口mock location demo
2018-08-21 15:46:06更新 【2019.11.14】 ...Android 开发者接口【mock location】demo: 项目放到GitHub啦: https://github.com/Hilaver/MockGPS 签名 安装包 也传到上面了 -
使用window location href
2019-03-25 14:50:53javascript中的location.href有很多种用法,主要如下。 self.location.href="/url" 当前页面打开URL页面 location.href="/url" 当前页面打开URL页面 windows.location.href="/url" 当前页面打开URL页面,前面三个... -
LocationProvider
2014-03-15 00:09:03相关配置: framework/base/core/res/res/values/config.xml <!-- Whether to enable network location overlay which allows network location provider to be replaced by an app at run-time. When dis -
window。location 和 location 的区别和联系
2018-10-17 23:58:16location. href ; 今天看到另外一种写法: location. href ; 一般人看到这两种写法的反应: 第一种,居然可以这么写,这样写真的可以么 ? 第二种,这两种写法我都知道啊,没什么么嘛 ? ... -
Nginx的Location介绍
2020-01-14 09:48:32Nginx的Location介绍 语法规则: location [=|~|~*|^~] /uri/ { … } = 开头表示精确匹配 ^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以... -
location href、parent location href、top location href、window open实现页面跳转
2015-11-06 13:37:34"window.location.href"、"location.href"是本页面跳转 "parent.location.href"是上一层页面跳转 "top.location.href"是最外层的页面跳转 //举个例子:如果A,B,C,D都是html,D是C的iframe,C是B的iframe,B是A的... -
js中window。location.search的用法和作用。
2016-02-24 15:21:21window.location 对象所包含的属性 属性 描述 hash 从井号 (#) 开始的 URL(锚) host 主机名和当前 URL 的端口号 hostname 当前 URL 的主机名 href 完整的 URL pathname 当前 URL 的... -
location对象的属性与方法
2020-12-29 16:54:24location对象详解Location 对象Location 对象属性Location 对象方法location.assign()location.replace()location.reload()location.href 兼容性问题 最近在项目开发中遇到了一个问题,客户的需求是要根据URL中传入... -
nginx配置出错duplicate location “/”nginx: [emerg] duplicate location “/”
2020-03-04 22:20:46将nginx配置文件中的两个location合并成一个 就好了。 server { listen ******; listen *****; server_name ****; root /*****; location / { index index.php index.html in... -
Location语法规则
2019-04-24 18:34:09Location规则 语法规则: location [=||*|^~] /uri/ {… } 首先匹配 =,其次匹配^~,其次是按文件中顺序的正则匹配,最后是交给 /通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。 符号 含义 ... -
document.location和window.location区别
2015-06-30 17:32:47document.location和window.location有什么区别就是 document你可以理解为文档,就是你的网页 window理解为窗口,就是你的ie浏览器包含的无框架:简单的说,没有框架的情况下,是等同的 有框架:在有框架的情况下... -
Nginx之Location配置详解(Location匹配顺序)
2017-04-19 23:39:26location 有”定位”的意思, 主要是根据Uri来进行不同的定位.在虚拟主机的配置中,是必不可少的,location可以把网站的不同部分,定位到不同的处理方式上.1.location的基础语法location [=|~|~*|^~] patt {}=:严格匹配...
-
TFS安装与管理
-
mac安装docker图形界面
-
SRE:在SRE团队中工作-源码
-
2021-02-26
-
NFS 网络文件系统
-
基于Flink+Hudi构建企业亿级云上实时数据湖教程(PC、移动、小
-
最新多聚焦图像融合源图像
-
井字游戏-源码
-
Redis主从与哨兵
-
点-源码
-
Java网络编程之SocketChannel和ServerSocketChannel
-
LVS + Keepalived 实现 MySQL 负载均衡与高可用
-
ansible-k8s-dev-源码
-
为何Spark更高效?
-
2021年 系统架构设计师 系列课
-
2021 年该学的 CSS 框架 Tailwind CSS 实战视频
-
psnuffle嗅探
-
Python--公共方法
-
朱老师C++课程第3部分-3.6智能指针与STL查漏补缺
-
中国电子商务法 - 中英文对照版(2019.1.1实施)-完整中文版(23页)