웹 애플리케이션의 완전한 URL 관리에는 두 가지 측면이 포함됩니다. 첫째, 사용자가 동의한 URL을 요청하면 애플리케이션은 이를 이해할 수 있는 매개변수로 구문 분석해야 합니다. 둘째, 애플리케이션은 생성된 URL을 애플리케이션에서 이해할 수 있도록 URL을 생성하는 방법을 제공해야 합니다. Yii 애플리케이션의 경우 CUrlManager를 사용하여 이 작업을 수행합니다.
1. URL 생성
URL은 컨트롤러의 뷰 파일에 하드 코딩될 수 있지만 종종 유연성이 뛰어나 동적으로 생성될 수 있습니다.
$url=$this->createUrl($route,$params);
$this는 컨트롤러 인스턴스를 나타냅니다. $route는 요청된 경로 요구 사항을 지정합니다. $params는 . GET
/index.php?r=post/read&id=100매개변수는 일련의 이름으로 연결됩니다. =값 기호 요청 문자열에 나타나는 r 매개변수는 요청된 경로를 나타냅니다. 이 URL 형식은 단어가 아닌 문자가 필요하기 때문에 사용자에게 친숙하지 않습니다. 소위 '경로 형식'을 사용하여 쿼리 문자열을 생략하고 GET 매개변수를 URL의 일부로 경로 정보에 추가하면 위의 URL을 더 깔끔하고 설명이 더 쉽게 만들 수 있습니다.
/index.php/post/read/id/100URL 형식을 변경하려면 createUrl이 자동으로 새 형식으로 전환되고 애플리케이션이 새 URL을 올바르게 이해할 수 있도록 urlManager 애플리케이션 요소를 구성해야 합니다.
array( ...... 'components'=>array( ...... 'urlManager'=>array( 'urlFormat'=>'path', ), ), );urlManager 요소의 클래스는 CWebApplication에서 CUrlManager로 미리 선언되어 있으므로 이를 지정할 필요가 없습니다.
createurl 메소드는 상대 주소를 생성합니다. 절대 URL을 얻으려면 yii">2. 사용자 친화적인 URL(사용자 친화적인 URL) 경로 형식 URL을 사용할 때 특정 URL 규칙을 지정하면 URL을 더욱 사용자 친화적으로 만들 수 있습니다. 예를 들어 긴 /index.php/post/read/id/100 URL 생성 및 CUrlManager를 통한 구문 분석 대신 짧은 URL /post/100을 생성할 수 있습니다. URL 규칙을 지정하려면 urlManager 애플리케이션 요소의 속성 규칙을 설정해야 합니다.접두사를 사용할 수 있습니다. 팁: 이 URL은 createurl 메소드에 의해 생성된 상대 주소입니다. 절대 URL을 얻으려면 yii 접두사를 사용할 수 있습니다.: app()->hostInfo 또는 createAbsoluteUrl을 호출합니다.
array( ...... 'components'=>array( ...... 'urlManager'=>array( 'urlFormat'=>'path', 'rules'=>array( 'pattern1'=>'route1', 'pattern2'=>'route2', 'pattern3'=>'route3', ), ), ), );
이러한 규칙은 경로 형식 쌍의 배열로 지정되며, 각 쌍은 단일 규칙에 해당합니다. 경로(경로) 형식은 일치하는 URL의 경로 정보 부분에 대해 구분 기호 및 수정자가 없는 유효한 정규식이어야 합니다. 규칙은 소수의 GET 매개변수를 특수 토큰에 바인딩할 수 있습니다. 형식은
'pattern1'=>array('route1', 'urlSuffix'=>'.xml', 'caseSensitive'=>false)
위 배열에는 일련의 사용자 정의 옵션 설정이 포함되어 있으며 버전 1.1.0에서는 다음 옵션이 유효합니다.
- urlSuffix: URL에서 사용되는 접미사 설정 규칙 기본값은 null이며 CUrlManager::urlSuffix 설정이 사용됩니다.
- caseSensitive: 규칙이 크고 작은 학교에 민감한지 여부, 기본값은 null이며 CUrlManager::caseSensitive의 기본값이 사용됩니다.
- defaultParams: 규칙에서 제공하는 GET 매개변수의 기본값(name=>value)을 사용하는 경우. 들어오는 요청을 구문 분석하면 이 속성에 선언된 값이 $_GET에 주입됩니다.
- matchValue: 생성 시 URL의 GET 매개변수 값이 해당 하위 패턴과 일치하는지 여부 기본값은 null입니다. 이는 CUrlManager::matchValue의 값이 사용됨을 의미합니다. 속성 값이 false이면 경로와 매개변수 이름이 지정된 일치 항목과 일치하면 규칙이 사용된다는 의미입니다. URL. 이 속성이 true로 설정되면 지정된 매개변수 값은 해당 하위 패턴 매개변수 값과도 일치해야 합니다. 이 속성의 값이 true로 설정되면 성능이 저하됩니다.
- 명명된 매개변수 사용
규칙은 일부 GET 매개변수를 연결할 수 있습니다. 이러한 GET 매개변수는 다음과 같이 규칙 패턴에서 특수 토큰으로 나타납니다.
<parampattern>;</parampattern>는 GET 매개변수 이름을 나타내고, 선택 사항인
는 일치하는 데 사용될 정규식을 나타냅니다. GET 매개변수 값. 웹 주소(URL)가 생성되면 이러한 매개변수 토큰은 해당 매개변수 값으로 대체됩니다. URL이 구문 분석되면 해당 GET 매개변수가 구문 분석된 결과에서 생성됩니다. ParamName
ParamPattern
몇 가지 예를 사용하여 URL의 작동 방식을 설명합니다. 규칙에는 다음 세 가지가 포함되어 있다고 가정합니다.
array( 'posts'=>'post/list', 'post/<id:>'=>'post/read', 'post/<year:>/<title>'=>'post/read', )</title></year:></id:>
- 전화
- 생성
. 첫 번째 규칙이 적용됩니다.
$this->createUrl('post/list')
/index.php/posts
은 - 을 호출하여
을 생성합니다. 두 번째 규칙이 적용됩니다.
$this->createUrl('post/read',array('id'=>100))
调用
$this->createUrl('post/read',array('year'=>2008,'title'=>'a sample post'))
生成/index.php/post/2008/a%20sample%20post
。第三个规则适用。调用
$this->createUrl('post/read')
产生/index.php/post/read
。请注意,没有规则适用。
总之,当使用createUrl生成网址,路线和传递给该方法的GET参数被用来决定哪些网址规则适用。如果关联规则中的每个参数可以在GET参数找到的,将被传递给createUrl ,如果路线的规则也匹配路线参数,规则将用来生成网址。
如果GET参数传递到createUrl是以上所要求的一项规则,其他参数将出现在查询字符串。例如,如果我们调用$this->createUrl('post/read',array('id'=>100,'year'=>2008))
,我们将获得/index.php/post/100?year=2008
。为了使这些额外参数出现在路径信息的一部分,我们应该给规则附加/*
。 因此,该规则post/<id:>/*</id:>
,我们可以获取网址/index.php/post/100/year/2008
。
正如我们提到的,URL规则的其他用途是解析请求网址。当然,这是URL生成的一个逆过程。例如, 当用户请求/index.php/post/100
,上面例子的第二个规则将适用来解析路线post/read
和GET参数array('id'=>100)
(可通过$_GET
获得) 。
createurl方法所产生的是一个相对地址。为了得到一个绝对的url ,我们可以用前缀
<code>yii">
注:使用的URL规则将降低应用的性能。这是因为当解析请求的URL ,[ CUrlManager ]尝试使用每个规则来匹配它,直到某个规则可以适用。因此,高流量网站应用应尽量减少其使用的URL规则。
参数化路由
从版本1.0.5开始, 我们可能会用到命名参数作为路由规则的一部分. 这就允许一个规则可以基于匹配规范被用来匹配多个路由,这也许还会帮助减少应用所需的规则的数目,从而提高整体的性能.
我们使用如下示例规则来说明如何通过命名参数来参数化路由:
array( '<_c:>/<id:>/<_a:>' => '<_c>/<_a>', '<_c:>/<id:>' => '<_c>/read', '<_c:>s' => '<_c>/list', )</_c></_c:></_c></id:></_c:></_a></_c></_a:></id:></_c:>
在上面的示例中, 我们在路由规则中使用了两个命名参数: _c
和_a
. The former matches a controller ID to be either post
or comment
, while the latter matches an action ID to be create
, update
or delete
. You may name the parameters differently as long as they do not conflict with GET parameters that may appear in URLs.
使用上面的规则, URL /index.php/post/123/create
将会被解析为 post/create
使用GET参数 id=123
. And given the route comment/list
and GET parameter page=2
, we can create a URL /index.php/comments?page=2
.
参数化主机名
从版本1.0.11开始, it is also possible to include hostname into the rules for parsing and creating URLs. One may extract part of the hostname to be a GET parameter. For example, the URL http://www.php.cn/
may be parsed into GET parameters user=admin
and lang=en
. On the other hand, rules with hostname may also be used to create URLs with paratermized hostnames.
In order to use parameterized hostnames, simply declare URL rules with host info, e.g.:
array( 'http://<user:>.example.com/<lang:>/profile' => 'user/profile', )</lang:></user:>
The above example says that the first segment in the hostname should be treated as user
parameter while the first segment in the path info should be lang
parameter. The rule corresponds to the user/profile
route.
Note that CUrlManager::showScriptName will not take effect when a URL is being created using a rule with parameterized hostname.
Also note that the rule with parameterized hostname should NOT contain the sub-folder if the application is under a sub-folder of the Web root. For example, if the application is under http://www.php.cn/
, then we should still use the same URL rule as described above without the sub-folder sandbox/blog
.
隐藏 index.php
还有一点,我们可以做进一步清理我们的网址,即在URL中藏匿index.php
入口脚本。这就要求我们配置Web服务器,以及urlManager应用程序元件。
我们首先需要配置Web服务器,这样一个URL没有入口脚本仍然可以处理入口脚本。如果是Apache HTTP server,可以通过打开网址重写引擎和指定一些重写规则。这两个操作可以在包含入口脚本的目录下的.htaccess
文件里实现。下面是一个示例:
Options +FollowSymLinks IndexIgnore */* RewriteEngine on # if a directory or a file exists, use it directly RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d # otherwise forward it to index.php RewriteRule . index.php
然后,我们设定urlManager元件的showScriptName属性为 false
。
注意在正式测试之前确保apache开启了rewrite模块,在ubuntu中开启的方式如下:
cd /etc/apache2/mods-enabled
sudo ln -s ../mods-available/rewrite.load rewrite.load
sudo service apache2 restart
现在,如果我们调用$this->createUrl('post/read',array('id'=>100))
,我们将获取网址/post/100
。更重要的是,这个URL可以被我们的Web应用程序正确解析。
Faking URL Suffix(伪造URL后缀)
我们还可以添加一些网址的后缀。例如,我们可以用/post/100.html
来替代/post/100
。这使得它看起来更像一个静态网页URL。为了做到这一点,只需配置urlManager元件的urlSuffix属性为你所喜欢的后缀。
3. 使用自定义URL规则设置类
注意: Yii从1.1.8版本起支持自定义URL规则类
默认情况下,每个URL规则都通过CUrlManager来声明为一个CUrlRule对象,这个对象会解析当前请求并根据具体的规则来生成URL。 虽然CUrlRule可以处理大部分URL格式,但在某些特殊情况下仍旧有改进余地。
比如,在一个汽车销售网站上,可能会需要支持类似/Manufacturer/Model
这样的URL格式, 其中Manufacturer
和 Model
都各自对应数据库中的一个表。此时CUrlRule就无能为力了。
我们可以通过继承CUrlRule的方式来创造一个新的URL规则类。并且使用这个类解析一个或者多个规则。 以上面提到的汽车销售网站为例,我们可以声明下面的URL规则。
array( // 一个标准的URL规则,将 '/' 对应到 'site/index' '' => 'site/index', // 一个标准的URL规则,将 '/login' 对应到 'site/login', 等等 '<action:>' => 'site/<action>', // 一个自定义URL规则,用来处理 '/Manufacturer/Model' array( 'class' => 'application.components.CarUrlRule', 'connectionID' => 'db', ), // 一个标准的URL规则,用来处理 'post/update' 等 '<controller:>/<action:>' => '<controller>/<action>', ),</action></controller></action:></controller:></action></action:>
从以上可以看到,我们自定义了一个URL规则类CarUrlRule
来处理类似/Manufacturer/Model
这样的URL规则。 这个类可以这么写:
class CarUrlRule extends CBaseUrlRule { public $connectionID = 'db'; public function createUrl($manager,$route,$params,$ampersand) { if ($route==='car/index') { if (isset($params['manufacturer'], $params['model'])) return $params['manufacturer'] . '/' . $params['model']; else if (isset($params['manufacturer'])) return $params['manufacturer']; } return false; // this rule does not apply } public function parseUrl($manager,$request,$pathInfo,$rawPathInfo) { if (preg_match('%^(\w+)(/(\w+))?$%', $pathInfo, $matches)) { // check $matches[1] and $matches[3] to see // if they match a manufacturer and a model in the database // If so, set $_GET['manufacturer'] and/or $_GET['model'] // and return 'car/index' } return false; // this rule does not apply } }
自定义URL规则类必须实现在CBaseUrlRule中定义的两个接口。
[CBaseUrlRule::createUrl()|createUrl()]
[CBaseUrlRule::parseUrl()|parseUrl()]
除了这种典型用法,自定义URL规则类还可以有其他的用途。比如,我们可以写一个规则类来记录有关URL解析和UEL创建的请求。 这对于正在开发中的网站来说很有用。我们还可以写一个规则类来在其他URL规则都匹配失败的时候显示一个自定义404页面。 注意,这种用法要求规则类在所有其他规则的最后声明。
以上就是Yii框架官方指南系列43——专题:URL(创建、路由、美化及自定义)的内容,更多相关内容请关注PHP中文网(www.php.cn)!

여전히 인기있는 것은 사용 편의성, 유연성 및 강력한 생태계입니다. 1) 사용 편의성과 간단한 구문은 초보자에게 첫 번째 선택입니다. 2) 웹 개발, HTTP 요청 및 데이터베이스와의 우수한 상호 작용과 밀접하게 통합되었습니다. 3) 거대한 생태계는 풍부한 도구와 라이브러리를 제공합니다. 4) 활성 커뮤니티와 오픈 소스 자연은 새로운 요구와 기술 동향에 맞게 조정됩니다.

PHP와 Python은 웹 개발, 데이터 처리 및 자동화 작업에 널리 사용되는 고급 프로그래밍 언어입니다. 1.PHP는 종종 동적 웹 사이트 및 컨텐츠 관리 시스템을 구축하는 데 사용되며 Python은 종종 웹 프레임 워크 및 데이터 과학을 구축하는 데 사용됩니다. 2.PHP는 Echo를 사용하여 콘텐츠를 출력하고 Python은 인쇄를 사용합니다. 3. 객체 지향 프로그래밍을 지원하지만 구문과 키워드는 다릅니다. 4. PHP는 약한 유형 변환을 지원하는 반면, 파이썬은 더 엄격합니다. 5. PHP 성능 최적화에는 Opcache 및 비동기 프로그래밍 사용이 포함되며 Python은 Cprofile 및 비동기 프로그래밍을 사용합니다.

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

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

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
