Um Mehrsprachigkeit in TYPO3 zu aktivieren sind mehrere Schritte erforderlich. Der hier dargestellte Weg zeigt eine mögliche Variante auf, besonders hinsichtlich RealURL sind viele unterschiedliche Konfigurationen möglich.
1. Sprache im Backend aktivieren:
Im Modul „Web > Liste“ (engl. „Web > List“) wählt man die Rootseite mit der ID „0“ (Seite mit vorangestelltem TYPO3-Symbol) aus. Nun fügt man einen neuen Datensatz vom Typ „Alternative Seitensprache“ (engl. „Website language“) ein und füllt die erforderlichen Felder aus. Die hier festgelegten Werte haben keinerlei Relevanz für die weitere Konfiguration, sondern dienen nur der Unterscheidung für Benutzer. Nach dem Speichern sucht man sich die Objekt-ID(s) im Modul „Web > Liste“ der angelegten Sprachen heraus, z.B. indem man mit der Maus auf die gewünschte Flagge zeigt. Die Standardsprache ist nicht anzulegen und hat implizit die ID 0 – in diesem Fall ist dies „Deutsch“. Als alternative Sprachen wurden „English“ mit der ID 1 und Italiano mit der ID 2 angelegt.
2. TypoScript-Setup:
config { linkVars = L(0-2) uniqueLinkVars = 1 defaultGetVars.L = 0 language = de locale_all = de_AT.UTF-8 sys_language_uid = 0 htmlTag_langKey = de } [globalVar = GP:L = 1] config { language = en locale_all = en_GB.UTF-8 sys_language_uid = 1 htmlTag_langKey = en } [globalVar = GP:L = 2] config { language = it locale_all = it_IT.UTF-8 sys_language_uid = 2 htmlTag_langKey = it } [global]
Die Einstellung „linkVars“ legt hier fest, dass der Parameter „L“ im Wertebereich 0-2 bei der Erzeugung von Links immer berücksichtigt wird. Hat man mehr oder weniger Sprachen, muss der Wertebereich entsprechend angepasst werden. Damit Parameter in der URL nur ein Mal vorkommen, wird „uniqueLinkVars“ aktiviert, andernfalls könnten URLs im Format „?L=0&L=2“ erzeugt werden.
Die Zahlen in den Bedingungen/Conditions (z.B.: „[globalVar = GP:L = 1]“) und für den Parameter „sys_language_uid“ (z.B.: „sys_language_uid = 1“) entsprechen den IDs der im ersten Schritt angelegten Sprachen.
Der Parameter „locale_all“ muss an die installierten Systemsprachen angepasst werden und ist erforderlich um beispielsweise das Datum in der korrekten Sprache auszugeben.
3. RealURL: (Die Konfiguration ist hier nur auszugsweise dargestellt):
// [...] 'preVars' => array( // [...] 'GETvar' => 'L', 'valueMap' => array( 'de' => 0, 'en' => 1, 'it' => 2, ), 'noMatch' => 'bypass', // [...] ), // [...]
Damit die 404-Fehlerbehandlung auch auf der ersten Ebene korrekt funktioniert, muss für alle „preVars“ die Option „’noMatch‘ => ‚bypass'“ aktiviert und es darf „postVarSet_failureMode“ nicht gesetzt sein.
4. Sprachkürzel in der URL:
Die gezeigte Konfiguration würde für die Default-Sprache Links im Format „domain.tld/seite/“ generieren, Links für zusätzliche Sprachen im Format „domain.tld/sprache/seite/“ (z.B.: „domain.tld/en/page/“). Möchte man auch bei der Standardsprache das Kürzel in der URL haben, muss man mit dem TypoScript-Setup „config.defaultGetVars.L = 0“ den Standardwert setzen. Würde man in der RealURL-Konfiguration anstelle für „’noMatch‘ => ‚bypass'“ die Option „‚valueDefault‘ => ‚de'“ setzen, würde man zwar das selbe URL-Format erreichen, allerdings würde die 404-Fehlerbehandlung auf der ersten Ebene nicht mehr funktionieren.
Eine Antwort zu Mehrsprachigkeit in TYPO3 konfigurieren
Sven Burkert 6. Februar 2015
Danke! Ich hatte das Problem, dass die 404 Seite nicht mehr angezeigt wurde, weil er als erstes Pfadsegment jede Eingabe akzeptiert hat und dann per Default auf „valueDefault“ umgestellt hat.
Mit deiner Konfiguration stimmt es nun.