> 백엔드 개발 > PHP 튜토리얼 > nginx rewrite规则的一些问题,关于last和break的差异

nginx rewrite规则的一些问题,关于last和break的差异

WBOY
풀어 주다: 2016-06-06 20:24:36
원래의
1310명이 탐색했습니다.

是这样的,我想实现一个url:example.com/test.php/a/b/c ,web目录下有test.php文件,想接收/a/b/c作为路由参数实现路由功能。
如果不设置rewite规则的话,打开example.com/test.php是可以的,但是打开example.com/test.php/a/b/c会报404。然后我就想自己rewrite规则。
尝试了很多次之后,发现

<code>location /test.php {
    rewrite . /test.php last;                                                                                                                                                                                 
}</code>
로그인 후 복사
로그인 후 복사

这样可以使页面正常访问,而且php的$_SERVER['REQUEST_URI']是test.php/a/b/c,能够达到我的需求。但是把last改到break就不对了。

我想知道为什么last会可以成功rewrite,已经把url rewrite到/test.php了,为什么后面的/a/b/c/还是能够保留?而且为什么用了break就不行。
而且last这个flag,不会停止location的匹配啊,test.php被rewrite到test.php应该还是会进入这个location并且无限循环返回500才是。为什么这样反而能够正常运行了。
虽然已经实现了我想要的功能,但是实在想不通这是什么原因。

回复内容:

是这样的,我想实现一个url:example.com/test.php/a/b/c ,web目录下有test.php文件,想接收/a/b/c作为路由参数实现路由功能。
如果不设置rewite规则的话,打开example.com/test.php是可以的,但是打开example.com/test.php/a/b/c会报404。然后我就想自己rewrite规则。
尝试了很多次之后,发现

<code>location /test.php {
    rewrite . /test.php last;                                                                                                                                                                                 
}</code>
로그인 후 복사
로그인 후 복사

这样可以使页面正常访问,而且php的$_SERVER['REQUEST_URI']是test.php/a/b/c,能够达到我的需求。但是把last改到break就不对了。

我想知道为什么last会可以成功rewrite,已经把url rewrite到/test.php了,为什么后面的/a/b/c/还是能够保留?而且为什么用了break就不行。
而且last这个flag,不会停止location的匹配啊,test.php被rewrite到test.php应该还是会进入这个location并且无限循环返回500才是。为什么这样反而能够正常运行了。
虽然已经实现了我想要的功能,但是实在想不通这是什么原因。

last在匹配到规则后,会跳转到这条规则里面进去。
break在匹配到规则后则不会。
这就是两者的区别

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿