定制 terminal42/contao-url-rewrite 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

terminal42/contao-url-rewrite

最新稳定版本:1.8.4

Composer 安装命令:

composer require terminal42/contao-url-rewrite

包简介

URL Rewrite bundle for Contao Open Source CMS

README 文档

README

The extension provides a new way for Contao to set various URL rewrites. The available config providers are:

  • Bundle config provider – the entries are taken from config.yml file
  • Database provider – the entries are taken from backend module

Behind the scenes, the rules are added as routes to the internal application router which allows to use all the features provided by the Symfony Routing component.

Installation

Install the bundle via Composer:

composer require terminal42/contao-url-rewrite 

Migration of short URLs

Since the extension fritzmg/contao-short-urls has been abandoned, you can migrate short URLs to URL rewrites with the extension bwein-net/contao-migrate-short-urls.

Configuration

Bundle configuration

The bundle configuration is optional. Here you can define the entries and disable the backend management module.

Note: if you want to use the % character, make sure it is properly escaped by doubling it %%.

# config/config.yml terminal42_url_rewrite: backend_management: false # Disable backend management of entries (true by default) entries: # Optional entries - request: { path: 'find/{address}' } response: { code: 303, uri: 'https://www.google.com/maps?q={address}' } - request: path: 'news/{news}' requirements: {news: '\d+'} response: code: 301 uri: '{{news_url::{news}|absolute}}' - request: path: 'home.php' hosts: ['localhost'] condition: "context.getMethod() == 'GET' and request.query.has('page')" response: uri: '{{link_url::{page}|absolute}}'

Running under non Contao managed edition

If you are running the Contao Managed Edition then the extension should work out of the box. For all the other systems you have to additionally register the routing configuration in the config files:

# config/routing.yml imports: - { resource: '@Terminal42UrlRewriteBundle/Resources/config/routing.yml' }

Examples

  1. Find address on Google Maps:
Path restriction: find/{address} Response code: 303 See Other Response URI: https://www.google.com/maps?q={address} --- Result: domain.tld/find/Switzerland → https://www.google.com/maps?q=Switzerland 
  1. Redirect to a specific news entry:
Path restriction: news/{news} Requirements: [news => \d+] Response code: 301 Moved Permanently Response URI: {{news_url::{news}|absolute}} --- Result: domain.tld/news/123 → domain.tld/news-reader/foobar-123.html Result: domain.tld/news/foobar → 404 Page Not Found 
  1. Rewrite legacy URLs with query string:
Path restriction: home.php Request condition: context.getMethod() == 'GET' and request.query.has('page') Response code: 301 Moved Permanently Response URI: {{link_url::{page}|absolute}} --- Result: domain.tld/home.php?page=123 → domain.tld/foobar-123.html 
  1. Rewrite URLs including slashes (without query string) to new domain:
Hosts restriction: [domain.com] Path restriction: /{wildcard} Requirements: [wildcard => .*] Response code: 301 Moved Permanently Response redirect URL: https://domain.tld/{wildcard} --- Result: domain.com/blog/test → https://domain.tld/blog/test 

Create a custom config provider

In addition to the existing providers you can create your own class that provides the rewrite configurations. The new service must implement the Terminal42\UrlRewriteBundle\ConfigProvider\ConfigProviderInterface interface and be registered with the appropriate tag:

services: app.my_rewrite_provider: class: AppBundle\RewriteProvider\MyRewriteProvider public: false tags: - { name: terminal42_url_rewrite.provider, priority: 128 }

Resources

  1. Symfony Routing
  2. Symfony Routing Component
  3. How to Restrict Route Matching through Conditions
  4. How to Define Route Requirements

统计信息

  • 总下载量: 89.62k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 17
  • 点击次数: 0
  • 依赖项目数: 3
  • 推荐数: 1

GitHub 信息

  • Stars: 15
  • Watchers: 5
  • Forks: 7
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04