TYPO3 Routing erklärt: Erweiterungen & Aspekte

TYPO3 Routing war eines der am meisten erwarteten Features in der Geschichte von TYPO3. Schließlich entwickelte und veröffentlichte die TYPO3-Community TYPO3 v9. In diesem Artikel möchte ich Sie (Anfänger bis Fortgeschrittene) über TYPO3-Routing informieren.

TYPO3 Routing erklärt: Erweiterungen & Aspekte

FYI. This blog is translated by machine. Please ignore any spelling and grammar errors; sorry for such inconvenience. We appreciate your understanding and support.

TYPO3 Routing war eines der am meisten erwarteten Features in der Geschichte von TYPO3. Schließlich entwickelte und veröffentlichte die TYPO3-Community TYPO3 v9. In diesem Artikel möchte ich Sie (Anfänger bis Fortgeschrittene) über TYPO3-Routing informieren.

Seit über 20 Jahren fehlte in TYPO3 die eingebaute TYPO3-Routing-Funktion für Human/SEO-freundliche URLs. In der Vergangenheit war die TYPO3-Gemeinschaft auf Erweiterungen zur Verwaltung von TYPO3-URLs wie EXT:realurl angewiesen. Für ein so wichtiges Feature war es für jeden sehr schwierig, sich auf andere Erweiterungen zu verlassen. Wie dem auch sei, jetzt haben wir ein fantastisches TYPO3-Routing-Feature innerhalb des TYPO3-Kerns, also lassen Sie uns untersuchen, wie es funktioniert.

Wussten Sie davon?
Das Routing in TYPO3 ist auf Basis der Symfony-Routing-Komponenten implementiert.

Was ist TYPO3-Routing und deren Terminologien?

Der menschenfreundliche Name des Routing ist "Sprechende URL", TYPO3 ist ein bisschen berühmt dafür, "entwicklerfreundliche" Namen für CMS-Funktionen zu vergeben ;)

Vor: https://t3planet.com/index.php?id=10
Nach: t3planet.com/news

Vor: https://t3planet.com/profiles?user=magdalena
Nach: t3planet.com/profiles/magdalena

Die Route

Die sprechende URL als Ganzes (ohne den Domain-Teil); zum Beispiel /blog/post/typo3-routing

Schnecke

Eindeutiger Name für eine Ressource, der bei der Erstellung von URLs verwendet werden soll; zum Beispiel könnte der Slug der Blog-Post-Seite /blog/post und der Slug eines Blog-Eintrags "typo3-routing" lauten.

Was ist eine Voraussetzung beim TYPO3-Routing?

Um das TYPO3-Routing zu aktivieren und gut zu konfigurieren, sollten Sie die folgenden Einstellungen für Ihren speziellen Web-Server konfigurieren.

Apache

 

Enable mod_rewrite Apache modules. The following modules are used by the default .htaccess
# .Htaccess
RewriteEngine on
RewriteRule ^(typo3/|fileadmin/|typo3conf/|typo3temp/|uploads/|) - [L]
RewriteRule ^typo3$ [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-l
RewriteRule .* index.php [L]

 

Microsoft Internet Information Services (IIS)

Stellen Sie sicher, dass das URL-Rewrite-Plugin auf Ihrem System installiert ist.
https://www.iis.net/downloads/microsoft/url-rewrite 

NGINX

 

NGINX web server does not support any static file like htaccess in the document root by default.
The NGINX configuration has to be set up manually.

location / {
    try_files $uri $uri/ /index.php$is_args$args;
}

TYPO3 Seitenbasiertes Routing

Um das seitenbasierte Routing zu aktivieren, müssen Sie die folgenden Schritte konfigurieren.

Schritt 1. Erstellen einer Website-Konfiguration

Gehen Sie zu Site Management > Sites > "Neue Site-Konfiguration für diese Site hinzufügen".

Schritt 2. Website konfigurieren

Konfigurieren Sie alle Felder wie Einstiegspunkt, Site-Identifier, Sprachen, etc.

Schritt drei. URL-Segment auf Ihre Seiten setzen

Gehen Sie zu Web > Seite > Seite auswählen > Seiteneigenschaften bearbeiten > URL-Segment hinzufügen

Schritt 4. Testlauf-Frontend-URL

Um mehr über die Verwaltung von TYPO3-Websites zu erfahren, können Sie meinen Artikel lesen
How to Manage TYPO3 Site Configuration?

Einführung in config.yaml

Sobald Sie die Site-Konfiguration erstellt haben, generiert TYPO3 automatisch die Datei config.yaml an der unten angegebenen Stelle.

 

Für Composer-basierte TYPO3-Installation
/project-root/config/sites/your-site-name/

Für Nicht-Composer-basierte TYPO3-Installationen
/project-root/typo3conf/sites/your-site-name/

 

Beispiel für config.yaml

 

base: yourtypo3site.com
errorHandling:
  -
    errorCode: '404'
    errorHandler: Page
    errorContentSource: 't3://page?uid=1'
languages:
  -
    title: English
    enabled: true
    languageId: '0'
    base: /
    typo3Language: default
    locale: en_US.UTF-8
    iso-639-1: en
    navigationTitle: English
    hreflang: en-US
    direction: ''
    flag: gb
rootPageId: 1

Verbesserer: TYPO3-Routing für Erweiterungen

TYPO3 kümmert sich um das Routing von CMS-Seiten mit coolen Backend-Funktionen menschenfreundlicher URLs. Aber was ist mit Ihren eigenen oder TER TYPO3-Erweiterungen?

Beispiel für Ihre Extension-URL t3planet.com/path-to/my-page/products/index.php. sollte sein wie t3planet.com/path-to/my-page/products/{product-name}

1. Einfacher Enhancer (Typ: Einfach)

Der Simple Enhancer arbeitet mit verschiedenen Routenargumenten, um sie einem Argument zuzuordnen, das später verwendet werden kann.

# Vor
https://t3planet.com/index.php?id=13&category=241&tag=T3Planet

# Nach
https://t3planet.com/path-to/my-page/show-by-category/241/T3Planet

 

# Config.yaml
routeEnhancers:
# Eindeutiger Name für die Enhancer, der intern zur Referenzierung verwendet wird
  CategoryListing:
    type: Simple
    limitToPages: [13]
    routePath: '/show-by-category/{category_id}/{tag}'
    defaults:
      tag: ''
    requirements:
      category_id: '[0-9]{1,3}'
      tag: '[a-zA-Z0-9].*'
    _arguments:
      category_id: 'category'

 

2. Plugin Enhancer (type: Plugin)

Der Plugin Enhancer arbeitet mit Plugins auf einer Seite, die allgemein als Pi-basierte Plugins bekannt sind, wo früher die folgenden GET/POST-Variablen verwendet wurden:

# Vor
https://t3planet.com/index.php?id=13&tx_felogin_pi1[forgot]=1&&tx_felogin_pi1[user]=82&tx_felogin_pi1[hash]=ABC

# Nach
t3planet.com/path-to/my-page/forgot-password/82/ABCDEFGHIJKLMNOPQRSTUVWXYZ012345

 

# Config.yaml
routeEnhancers:
  ForgotPassword:
    type: Plugin
    limitToPages: [13]
    routePath: '/forgot-password/{user}/{hash}'
    namespace: 'tx_felogin_pi1'
    defaults:
      forgot: "1"
    requirements:
      user: '[0-9]{1..3}'
      hash: '^[a-zA-Z0-9]{32}$'

 

3. Extbase Plugin Enhancer (type: Extbase)

Bei der Erstellung von Extbase-Plugins ist es sehr üblich, mehrere Controller/Action-Kombinationen zu haben. Der Extbase Plugin Enhancer ist daher eine Erweiterung des regulären Plugin Enhancers und bietet die Funktionalität, dass mehrere Varianten generiert werden, die typischerweise auf der Anzahl der Controller/Action-Paare aufbauen.

# Vor
https://t3planet.com/index.php?id=13&tx_news_pi1[controller]=News&tx_news_pi1[action]=list&tx_news_pi1[page]=5

# Nach
t3planet.com/path-to/my-page/list/5

 

# Config.yaml
routeEnhancers:
  NewsPlugin:
    type: Extbase
    limitToPages: [13]
    extension: News
    plugin: Pi1
    routes:
      - { routePath: '/list/{page}', _controller: 'News::list', _arguments: {'page': '@widget_0/currentPage'} }
      - { routePath: '/tag/{tag_name}', _controller: 'News::list', _arguments: {'tag_name': 'overwriteDemand/tags'}}
      - { routePath: '/blog/{news_title}', _controller: 'News::detail', _arguments: {'news_title': 'news'} }
      - { routePath: '/archive/{year}/{month}', _controller: 'News::archive' }
    defaultController: 'News::list'
    defaults:
      page: '0'
    requirements:
      page: '\d+'

 

4. Seitentyp-Dekorator (Typ: PageType)

Der PageType Enhancer (Decorator) ermöglicht das Hinzufügen eines Suffixes zu der vorhandenen Route (einschließlich vorhandener anderer Enhancer), um einen Seitentyp (GET-Parameter &type=) auf ein Suffix abzubilden.

# Vor
https://t3planet.com/?type=13

# Nach
t3planet.com/rss.feed.json

 

# Setup.typoscript
rssfeed = PAGE
rssfeed.typeNum = 13
rssfeed.10 < plugin.tx_myplugin
rssfeed.config.disableAllHeaderCode = 1
rssfeed.config.additionalHeaders.10.header = Content-Type: xml/rss

 

 

# Config.yaml
routeEnhancers:
   PageTypeSuffix:
      type: PageType
      default: '.json'
      index: 'index'
      map:
         'rss.feed': 13
         '.json': 26

 

5. Kundenspezifische TYPO3-Erweiterungen entwickeln

 

Für den Fall, dass Sie Ihre eigene Geschäftslogik in Ihrer Erweiterung erstellen möchten, ist TYPO3 flexibel, um eigene TYPO3 Enhancer zu konfigurieren, indem Sie eine eigene Enhancer-Klasse registrieren

# ext_localconf.php
$GLOBALS['TYPO3_CONF_VARS']['SYS']['routing']['enhancers']['MyCustomEnhancerAsUsedInYaml'] = \MyVendor\MyExtension\Routing\Enhancer\MyCustomEnhancer::class;

TYPO3-Aspekte: Routing für Erweiterungen

Die TYPO3 Aspects-Konfiguration ist hilfreich, um einen Parameter {blog}, der eine UID innerhalb von TYPO3 ist, auf den eigentlichen Blog-Slug abzubilden, d.h. ein Feld innerhalb der Datenbanktabelle, das den bereinigten/sanitisierten Titel des Blogs enthält (z.B. "typo3-routing" bildet auf die Blog-ID 10 ab).

1. StaticValueMapper

Der StaticValueMapper ersetzt Werte einfach auf einer 1:1-Zuordnungsliste eines Arguments in ein sprechendes Segment.

# Result
t3planet.com/archive/{year}/{month}

 

# Config.yaml
routeEnhancers:
  NewsArchive:
    type: Extbase
    limitToPages: [13]
    extension: News
    plugin: Pi1
    routes:
      - { routePath: '/{year}/{month}', _controller: 'News::archive' }
    defaultController: 'News::list'
    defaults:
      month: ''
    aspects:
      month:
        type: StaticValueMapper
        map:
          january: 1
          february: 2
          march: 3
          april: 4
          may: 5
          june: 6
          july: 7
          august: 8
          september: 9
          october: 10
          november: 11
          december: 12

 

2. LocaleModifier

# Result
English Language: t3planet.com/archive/{year}/{month}/
German Language: t3planet.com/archiv/{year}/{month}/

 

# Config.yaml
routeEnhancers:
  NewsArchive:
    type: Extbase
    limitToPages: [13]
    extension: News
    plugin: Pi1
    routes:
      - { routePath: '/{localized_archive}/{year}/{month}', _controller: 'News::archive' }
    defaultController: 'News::list'
    aspects:
      localized_archive:
        type: LocaleModifier
        default: 'archive'
        localeMap:
          - locale: 'fr_FR.*|fr_CA.*'
            value: 'archives'
          - locale: 'de_DE.*'
            value: 'archiv'

 

3. StaticRangeMapper

# Result
t3planet.com/list/{page}/1

 

# Config.yaml
routeEnhancers:
  NewsPlugin:
    type: Extbase
    limitToPages: [13]
    extension: News
    plugin: Pi1
    routes:
      - { routePath: '/list/{page}', _controller: 'News::list', _arguments: {'page': '@widget_0/currentPage'} }
    defaultController: 'News::list'
    defaults:
      page: '0'
    requirements:
      page: '\d+'
    aspects:
      page:
        type: StaticRangeMapper
        start: '1'
        end: '100'

 

4. PersistedAliasMapper

Wenn eine Erweiterung mit einem Slug-Feld oder einem anderen Feld geliefert wird, das für den sprechenden URL-Pfad verwendet wird, kann dieses Datenbankfeld zum Aufbau der URL verwendet werden:

# Result
t3planet.com/detail/{path_segment}/

 

# Config.yaml

routeEnhancers:
  NewsPlugin:
    type: Extbase
    limitToPages: [13]
    extension: News
    plugin: Pi1
    routes:
      - { routePath: '/detail/{news_title}', _controller: 'News::detail', _arguments: {'news_title': 'news'} }
    defaultController: 'News::detail'
    aspects:
      news_title:
        type: PersistedAliasMapper
        tableName: 'tx_news_domain_model_news'
        routeFieldName: 'path_segment'
        routeValuePrefix: '/'

 

5. PersistedPatternMapper

Wenn ein Platzhalter aus mehreren Feldern der Datenbank geholt werden soll, ist der PersistedPatternMapper das Richtige für Sie. I

# Result
t3planet.com/blog/{title}-{uid}/

 

# Config.yaml
routeEnhancers:
  Blog:
    type: Extbase
    limitToPages: [13]
    extension: BlogExample
    plugin: Pi1
    routes:
      - { routePath: '/blog/{blogpost}', _controller: 'Blog::detail', _arguments: {'blogpost': 'post'} }
    defaultController: 'Blog::detail'
    aspects:
      blogpost:
        type: PersistedPatternMapper
        tableName: 'tx_blogexample_domain_model_post'
        routeFieldPattern: '^(?P<title>.+)-(?P<uid>\d+)$'
        routeFieldResult: '{title}-{uid}'

 

6. Kundenspezifische TYPO3-Aspekte entwickeln

 

Ähnlich wie Enhancers bietet der TYPO3-Kern eine API, mit der Sie Ihre eigenen benutzerdefinierten Aspekte erstellen können, indem Sie sich unten registrieren.
​​​​​​
# ext_localconf.php
$GLOBALS['TYPO3_CONF_VARS']['SYS']['routing']['aspects']['MyCustomMapperNameAsUsedInYamlConfig'] = \MyVendor\MyExtension\Routing\Aspect\MyCustomMapper::class;

Praktisches Beispiel für TYPO3 Enhancers & TYPO3-Aspekte

Example #1 TYPO3 Routing for EXT:news

# Result
Detail view: t3planet.com/news/detail/the-news-title
Pagination: t3planet.com/news/page-2
Category filter: t3planet.com/news/my-category
Tag filter: t3planet.com/news/my-tag

 

# Config.yaml
routeEnhancers:
  News:
    type: Extbase
    extension: News
    plugin: Pi1
    routes:
      - routePath: '/page-{page}'
        _controller: 'News::list'
        _arguments:
          page: '@widget_0/currentPage'
      - routePath: '/{news-title}'
        _controller: 'News::detail'
        _arguments:
          news-title: news
      - routePath: '/{category-name}'
        _controller: 'News::list'
        _arguments:
          category-name: overwriteDemand/categories
      - routePath: '/{tag-name}'
        _controller: 'News::list'
        _arguments:
          tag-name: overwriteDemand/tags
    defaultController: 'News::list'
    defaults:
      page: '0'
    aspects:
      news-title:
        type: PersistedAliasMapper
        tableName: tx_news_domain_model_news
        routeFieldName: path_segment
      page:
        type: StaticRangeMapper
        start: '1'
        end: '100'
      category-name:
        type: PersistedAliasMapper
        tableName: sys_category
        routeFieldName: slug
      tag-name:
        type: PersistedAliasMapper
        tableName: tx_news_domain_model_tag
        routeFieldName: slug

 

Example #2 TYPO3 Routing for EXT:blog

Die TYPO3-Blog-Erweiterung bietet eine integrierte TYPO3-Routing-Konfiguration, die Sie einfach wie unten beschrieben in Ihr Projekt importieren können.

 

# Config.yaml
imports:
- { resource: "EXT:blog/Configuration/Routes/Default.yaml" }

Hilfreiche TYPO3-Routing-Erweiterungen

Um Ihnen die Arbeit zu erleichtern, habe ich versucht, hilfreiche TYPO3-Routing-Erweiterungen wie unten beschrieben zu finden.

1. Slug

Hilft bei der Verwaltung der URL-Slugs Ihrer TYPO3-Seiten und benutzerdefinierten Datensätze! Das Slug-Backend-Modul wurde entwickelt, um große Mengen von Slugs für Seiten und Extension-Datensätze zu verwalten.

2. URL-Slugs wiederherstellen

Hilft bei der Verwaltung der URL-Slugs Ihrer TYPO3-Seiten und benutzerdefinierten Datensätze! Das Slug-Backend-Modul wurde entwickelt, um große Mengen von Slugs für Seiten und Extension-Datensätze zu verwalten.

3. Just In Case - Case-insensitive URLs

Bei eingehenden URLs spielt es keine Rolle, ob sie groß- oder kleingeschrieben sind, sie funktionieren einfach. Standardmäßig ist TYPO3 v9 streng, wenn Ihre eigentliche Seite aufgerufen wird https://t3planet.com/TYPO3-learn/ aber Ihre Marketing-Typen nennen es t3planet.com/TYPO3-Learn/. TYPO3 v9 speichert URLs standardmäßig in Kleinbuchstaben.

4. Extbase Yaml-Routen

Bietet die Möglichkeit, einen Route Slug an einen bestimmten Extbase Action-Endpunkt zu binden. Diese Erweiterung gibt Ihnen die Möglichkeit, den URL-Endpunkt mit einer bestimmten Extbase Action zu binden. Kurz gesagt, Sie können eine API für Ihr TYPO3-Projekt erstellen.

Merkmale

  • Erlauben Sie dem Entwickler, seine eigene Route mit YAML zu registrieren.
  • CRUD sofort einsatzbereit.
  • Zusätzliche Middleware für Ihre Routen.
  • Einfaches Modul für allgemeine Informationen.

5. Konfigurierbare Routen

Konfigurieren Sie spezifische RouteEnhancers in den Seiteneigenschaften für die URL-Behandlung.

6. Sprechende URL-Fragmente (Anker)

Fügt ein Slug-Feld für menschenlesbare Anker ("domain.com/page/#my-section") zu TYPO3-Inhaltselementen hinzu. Standardmäßig wird dieser Anker als id-Attribut des Header gerendert.

# Vor
https://www.t3planet.com/page/#c123

# Nach
https://www.t3planet.com/page/#section-of-interest

Tipps & Tricks zum TYPO3-Routing

Tipp 1. Wie migriert man von EXT:realurl zum Routing?

Wenn Sie Ihr Projekt z.B. von TYPO3 v8 auf v9 mit der alten TYPO3 realurl-Extension upgraden, dann empfehle ich dringend, von EXT:realurl auf die Routing-Funktion des TYPO3-Kerns zu migrieren.

Es wurde ein Upgrade-Assistent bereitgestellt, der sich um die Generierung von Slugs für alle vorhandenen Seiten kümmert. Wenn Sie zuvor RealURL verwendet haben, versucht der Assistent, die RealURL-Caches zu verwenden, um passende Slugs zu generieren. Dies wird jedoch nicht in allen Fällen erfolgreich sein, und Sie sollten die generierten Slugs erneut überprüfen, wenn Sie möchten, dass die URL-Struktur nach einem Upgrade gleich bleibt.
Für Ihre eigenen TYPO3-Erweiterungen müssen Sie die Datenbank wie unten beschrieben manuell aktualisieren.

 

# Database SQL Queries
UPDATE tx_table_name AS n JOIN tx_realurl_uniqalias AS r ON (n.uid = r.value_id AND r.tablename = 'tx_table_name') SET n.slug = r.value_alias WHERE (n.slug IS NULL OR n.slug = '');

Eines möchte ich sagen: "Herzlichen Dank an Dmitry Dulepov" für seine engagierte Arbeit und Unterstützung der RealURL-TYPO3-Extension für ein Jahr. EXT:realurl war eine der großartigen TYPO3-Erweiterungen, die uns sehr hilft.

Tipp 2. Verwenden Sie die Funktion "Importe"

Eine Routing-Konfiguration (und die Site-Konfiguration im Allgemeinen) kann schnell ziemlich lang werden, Sie sollten in Ihrer YAML-Konfiguration den Import nutzen, der es Ihnen erlaubt, Routing-Konfigurationen aus verschiedenen Dateien und mit verschiedenen Erweiterungen hinzuzufügen.

 

# Config.yaml
imports:
   - { resource: "EXT:myblog/Configuration/Routes/Default.yaml" }
   - { resource: "EXT:mynews/Configuration/Routes/Default.yaml" }
   - { resource: "EXT:template/Configuration/Routes/Default.yaml" }

 

Tipp 3. Fügen Sie einen Schrägstrich oder ein .html-Suffix am Ende von URL

 

Sie können PageTypeSuffix einfach so konfigurieren, dass Sie .html am Ende der URL erhalten.

# Ergebnis
https://t3planet.com/about

 

# Config.yaml
rootPageId: 7
base: 'https://mydomain.com/'
errorHandling: {  }
routes: {  }
routeEnhancers:
  PageTypeSuffix:
    type: PageType
    default: '.html'
    index: 'index'
    map:
      '.html': 0

Tipp 4. Wie setzt man statische Routen in TYPO3?

Statische Routen bieten eine Möglichkeit, scheinbar statische Inhalte auf einer Basis pro Standort zu erstellen. 

StaticText (Beispiel von Robots.txt)

 

routes:
 -
   route: robots.txt
   type: staticText
   content: "User-agent: *\r\nDisallow: /typo3/\r\nDisallow: /typo3_src/\r\nAllow: /typo3/sysext/frontend/Resources/Public/*\r\n"

TYPO3 URL (Example of Sitemapxml)
routes:
 -
   route: sitemap.xml
   type: uri
   source: 't3://page?uid=1&type=1533906435'
 -
   route: favicon.ico
   type: uri
   source: 't3://file?uid=77'

 

Tipp 5. Debugging-Route verbessert

Wenn es um die Auflösung geht, sind die PSR-15-Middleware "PageResolver" und der "PageRouter" ein guter Anfang beim Debugging.

 

typo3/sysext/core/Classes/Routing/PageRouter.php -> generateUri
typo3/sysext/extbase/Classes/Routing/ExtbasePluginEnhancer.php -> enhanceForGeneration

Tipp 6. Slug-Bearbeitung erhält automatische Umleitung

Denken Sie einfach daran, dass immer, wenn Sie einen Slug (von Seiten oder Datensätzen) bearbeiten, die alte URL automatisch auf "307 Redirect" gesetzt wird. Das ist nützlich in Produktionsumgebungen, verursacht aber unnötige Einträge in Entwicklungsumgebungen.

Tipp 7. Wie erstellt man TYPO3 Sitemap-Routing?

Sie können eine TYPO3-Sitemap mit PageTypeSuffix > PageType vorbereiten.

 

# Setup.typoscript
seo_sitemap = PAGE
seo_sitemap {
  typeNum = 1533906435
  config {
    cache_period = 900
    disableAllHeaderCode = 1
    admPanel = 0
    removeDefaultJS = 1
    removeDefaultCss = 1
    removePageCss = 
    additionalHeaders.10 {
      header = Content-Type:application/xml;charset=utf-8
    }
  }
  10 = USER
 10.userFunc = TYPO3\CMS\Seo\XmlSitemap\XmlSitemapRenderer->render
}
# Config.yaml

routeEnhancers:
  PageTypeSuffix:
    type: PageType
    map:
      sitemap.xml: 1533906435

Schlussfolgerung

Vielen Dank für die Lektüre dieses etwas langen TYPO3-Artikels.

Ich hoffe, dass Ihnen die grundlegenden bis fortgeschrittenen Fähigkeiten des TYPO3-Routings gefallen haben und Sie diese erkunden konnten. Lassen Sie mich kurz die wichtigsten Punkte zusammenfassen.

  • Die Grundstruktur von config.yaml verstehen, die über das Backend-Modul Site Management verwaltet wird.
  • Das URL-Segment können Sie ganz einfach unter Seite > Eigenschaft bearbeiten konfigurieren.
  • Lernen und erforschen Sie TYPO3 Enhancer und TYPO3-Aspekt

Gibt es Probleme bei der Konfiguration des TYPO3-Routings? Ich bin Ihnen gerne behilflich, Fragen können Sie gerne in das Kommentarfeld schreiben.

Haben Sie ein glückliches TYPO3-Routing!

Your One-Stop Solutions for Custom TYPO3 Development

  • A Decade of TYPO3 Industry Experience
  • 350+ Successful TYPO3 Projects
  • 87% Repeat TYPO3 Customers
TYPO3 Service
service

Post a Comment

×
Captcha Code Kann das Bild nicht gelesen werden? Klicken Sie hier, um zu aktualisieren
  • user
    Sebastian 2023-07-14 um 2:51 pm
    I appreciate how well-researched and informative this blog post is.
  • user
    Sabrina Kuster 2023-07-14 um 2:51 pm
    Thank you for this insightful blog post on TYPO3 routing!
  • user
    Sabrina Kuster 2023-07-14 um 2:50 pm
    Thank you for this insightful blog post on TYPO3 routing!
  • user
    Sebastian 2023-07-14 um 2:48 pm
    I appreciate how well-researched and informative this blog post is.
  • user
    fchaussin 2021-03-10 um 11:13 am
    From far, the best ressources for TYPO3 Routing!
  • user
    Kurt Hoffstädt 2020-10-06 um 8:56 am
    Sanjay, many thanks for this post on TYPO3 routing has been a great help.
    Thanks for TYPO3 Routing Extensions options, they worked for me
  • user
    Tanja Fitzner 2020-10-06 um 8:43 am
    Thank you so much, you don't how much i search for a solution for this .. i even contacted my host and they couldn't know how to do it …. Method 3 solved it.
    you're really my trusted source for everything TYPO3.
    again thank you so much.