Sandini Bib
TYPO3 – Tipps & Tricks
Sandini Bib
Open Source Software wird gegenüber kommerziellen Lösungen immer wichtiger. Addison-Wesley trägt dieser Entwicklung Rechnung mit den Büchern der Open Source Library. Administratoren, Entwickler und User erhalten hier professionelles Know-how, um freie Software effizient einzusetzen. Behandelt werden sowohl Themen wie Betriebssysteme, Netzwerke und Sicherheit als auch Programmierung. Eine Auswahl aus unserem Programm: phpMyAdmin ist das am weitesten verbreitete Tool zur Verwaltung von MySQL-Datenbanken. Dieses Buch gibt Ihnen einen profunden Einstieg in die effiziente Verwaltung von MySQL-Datenbanken mit phpMyAdmin (neue Version 2.6.0) bis hin zur professionellen Administration. Der Autor zeigt, wie Sie mit phpMyAdmin Datenbanken anlegen, editieren, abfragen und pflegen und wie Sie Benutzer anlegen und verwalten. Sie lernen, wie Sie Abfragen optimieren und automatisieren und was Sie beim Arbeiten mit verschiedenen Zeichensätzen und MIMETypen beachten müssen u.v.a.m. Ein TroubleshootingKapitel hilft bei Problemen. phpMyAdmin Marc Delisle 260 S. Euro 19,95 (D), 20,60 (A) ISBN 3-8273-2250-2 Sind Sie Webentwickler und suchen Sie PHP- und MySQLGrundlagen sowie Programmiertechniken in einem Buch? Dann sind Sie hier richtig. Dieses praxisorientierte Buch liefert nach einem kurzen Grundlagenteil eine ganze Sammlung von PHP- und MySQL-Rezepten: objektorientierte Programmierung mit PHP 5, XML-Funktionen, prepared statements, stored procedures, SQL-Grundlagen und -Rezepte, GIS-Funktionen, mysqli-Schnittstelle, etc. Anschließend demonstrieren mehrere umfangreiche Beispielprojekte das Zusammenspiel von PHP und MySQL. Ein Kapitel über TYPO3 zeigt exemplarisch, wie im Internet kostenlos verfügbare PHP/MySQL-Projekte installiert und für eigene Zwecke adaptiert werden. PHP 5 & MySQL 5 Michael Kofler, Bernd Öggl 696 S., 1 CD Euro 49,95 (D), 51,40 (A) ISBN 3-8273-2190-5
Sandini Bib
Christoph Lindemann Maik Caro
Typo3 Tipps & Tricks Erste Hilfe von Installation bis Extensions
An imprint of Pearson Education München • Boston • San Francisco • Harlow, England Don Mills, Ontario • Sydney • Mexico City Madrid • Amsterdam
Sandini Bib
Die Deutsche Bibliothek – CIP-Einheitsaufnahme Die Deutsche Bibliothek verzeichnet diese Publikation in der Deutschen Nationalbibliografie; detaillierte bibliografische Daten sind im Internet über http://dnb.ddb.de abrufbar. Die Informationen in diesem Produkt werden ohne Rücksicht auf einen eventuellen Patentschutz veröffentlicht. Warennamen werden ohne Gewährleistung der freien Verwendbarkeit benutzt. Bei der Zusammenstellung von Texten und Abbildungen wurde mit größter Sorgfalt vorgegangen. Trotzdem können Fehler nicht vollständig ausgeschlossen werden. Verlag, Herausgeber und Autoren können für fehlerhafte Angaben und deren Folgen weder eine juristische Verantwortung noch irgendeine Haftung übernehmen. Für Verbesserungsvorschläge und Hinweise auf Fehler sind Verlag und Herausgeber dankbar. Alle Rechte vorbehalten, auch die der fotomechanischen Wiedergabe und der Speicherung in elektronischen Medien. Die gewerbliche Nutzung der in diesem Produkt gezeigten Modelle und Arbeiten ist nicht zulässig.
Fast alle Hardware- und Softwarebezeichnungen und weitere Stichworte und sonstige Angaben, die in diesem Buch verwendet werden, sind als eingetragene Marken geschützt. Da es nicht möglich ist, in allen Fällen zeitnah zu ermitteln, ob ein Markenschutz besteht, wird das ® Symbol in diesem Buch nicht verwendet.
Umwelthinweis: Dieses Produkt wurde auf chlorfrei gebleichtem Papier gedruckt.
10 9 8 7 6 5 4 3 2 1 07 06 ISBN 3-8273-2280-4
© 2006 by Addison-Wesley Verlag, ein Imprint der Pearson Education Deutschland GmbH Martin-Kollar-Straße 10–12, D-81829 München/Germany Alle Rechte vorbehalten Einbandgestaltung: Marco Lindenbeck, webwo GmbH (
[email protected]) Lektorat: Boris Karnikowski,
[email protected] Fachlektorat: Mathias Schreiber, wmdb Korrektorat: Brigitte Hamerski Herstellung: Monika Weiher,
[email protected] Satz: reemers publishing services gmbh, Krefeld Druck: Bercker Graph. Betrieb, Kevelaer Printed in Germany
Sandini Bib
Inhaltsübersicht Zu diesem Buch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13
1
Installation & Konfiguration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
15
2
Arbeiten mit Inhalten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
47
3
Administrationsoberflächen konfigurieren . . . . . . . . . . . . . . . . . . . . . . . . . . .
97
4
Templates unter TYPO3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137
5
Navigationen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 183
6
TYPO3-Konfiguration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205
7
TYPO3 Extensions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 223
Stichwortverzeichnis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 255
Sandini Bib
Sandini Bib
Inhaltsverzeichnis 1
Zu diesem Buch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13
Installation & Konfiguration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
15
1.1 Installation auf Windows mit WAMP QuickStart . . . . . . . . . . . . . . . . . .
15
1.2 Installation auf Mac OS X mit XAMPP . . . . . . . . . . . . . . . . . . . . . . . . . . .
21
1.3 Installation auf Linux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
25
1.3.1 1.3.2 1.3.3 1.3.4 1.3.5 1.3.6
Debian GNU/Linux Basis-System installieren . . . . . . . . . . . . . . . . . . . . Installation weiterer Komponenten . . . . . . . . . . . . . . . . . . . . . . . . . . . . Installation der TYPO3-Komponenten . . . . . . . . . . . . . . . . . . . . . . . . . . Automatische Backups durch cron-Job . . . . . . . . . . . . . . . . . . . . . . . . . Benutzerrechte im Dateisystem korrekt setzen . . . . . . . . . . . . . . . . . . Das Install-Tool sichern . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
25 28 34 39 40 41
1.4 MySQL-Datenbank . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
42
1.4.1 1.4.2 1.4.3
root-Passwort setzen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Datenbank-Frontend MySql Commander einsetzen . . . . . . . . . . . . . . . Datenbank-Backup einspielen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
42 42 43
1.5 PHP-Konfigurationseinstellungen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
44
1.5.1 1.5.2 1.5.3
2
PHP-Speicherlimit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . PHP Upload-Limits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Safe Mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
44 45 45
Arbeiten mit Inhalten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
47
2.1 Struktur . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
47
2.1.1 2.1.2 2.1.3 2.1.4 2.1.5 2.1.6 2.1.7 2.1.8
Seiten verstecken . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Seiten kopieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Seiten verschieben . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Mehrere Seiten kopieren oder verschieben . . . . . . . . . . . . . . . . . . . . . Mehrere Seiten löschen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Neue Seiten anlegen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Mehrere Seiten schnell erzeugen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Seiten sortieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
47 48 50 51 52 53 55 56
2.2 Inhalte . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
57
2.2.1 2.2.2 2.2.3
Einfaches Bearbeiten der Datumsfelder . . . . . . . . . . . . . . . . . . . . . . . . Links im RTE (Rich Text Editor) löschen . . . . . . . . . . . . . . . . . . . . . . . . . Alternative Navigationstitel für Seiten setzen . . . . . . . . . . . . . . . . . . .
57 58 59
Sandini Bib
Inhaltsverzeichnis
2.2.4
Seiten anzeigen lassen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
61
2.2.5
Shortcut-Seiten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
62
2.2.6
Der Seitentyp Externe URL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
63
2.2.7
Inhalte bearbeiten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
64
2.2.8
Inhalte zwischen Seiten verschieben . . . . . . . . . . . . . . . . . . . . . . . . . . .
66
2.2.9
Aktuelle Änderungen rückgängig machen . . . . . . . . . . . . . . . . . . . . . . .
68
2.2.10 Bilder in Inhaltselemente einfügen . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
69
2.2.11
Bilder im RTE einfügen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
70
2.2.12 Download-Links einfügen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
72
2.2.13 Links zu Seiten und Elemente einfügen . . . . . . . . . . . . . . . . . . . . . . . . .
74
2.2.14 Link zu E-Mail-Adresse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
75
2.2.15 Eine einfache Bildergalerie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
76
2.2.16 Ein E-Mail-Formular einfügen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
78
2.2.17 Eine Suche einfügen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
80
2.2.18 Inhalte von anderen Seiten verknüpfen . . . . . . . . . . . . . . . . . . . . . . . . .
82
2.2.19 Seiten im Frontend bearbeiten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
83
2.2.20 Mehrere Inhalte zur gleichzeitigen Bearbeitung öffnen . . . . . . . . . . . .
84
2.2.21 Seiten und Inhalte schnell über die ID öffnen . . . . . . . . . . . . . . . . . . . .
85
2.3 Arbeiten mit Dateien . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
85
2.3.1
Dateien übertragen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
85
2.3.2
Dateien löschen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
86
2.3.3
Dateien und Verzeichnisse umbenennen . . . . . . . . . . . . . . . . . . . . . . . .
87
2.3.4
Dateien und Verzeichnisse verschieben oder kopieren . . . . . . . . . . . .
87
2.4 Funktionalitäten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
89
2.4.1
3
8
Zeitsteuerung von Seiten und Inhalten . . . . . . . . . . . . . . . . . . . . . . . . .
89
2.4.2
Seitencache löschen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
90
2.4.3
Suchen und Finden im Backend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
90
2.4.4
Seitenalias setzen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
91
2.4.5
Häufig wiederkehrende Inhalte bearbeiten . . . . . . . . . . . . . . . . . . . . . .
92
2.4.6
Notizen anlegen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
94
2.4.7
CSV-Listen exportieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
94
2.4.8
Vorschau von Seiten und Inhalten . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
94
Administrationsoberflächen konfigurieren . . . . . . . . . . . . . . . . . . . . . . . . . . .
97
3.1 Benutzer in TYPO3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
97
3.1.1
Benutzer und Benutzergruppen erzeugen . . . . . . . . . . . . . . . . . . . . . . .
97
3.1.2
Zugriff auf Module freigeben . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
98
3.1.3
Benutzern Zugang zum Dateisystem erlauben . . . . . . . . . . . . . . . . . . .
99
Sandini Bib
Inhaltsverzeichnis
3.1.4 3.1.5 3.1.6
Seiteneinstiegspunkt setzen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 Seitenrechte setzen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 Bearbeitungsrechte für Benutzer setzen . . . . . . . . . . . . . . . . . . . . . . . . 103
3.2 Allgemeine Einstellungen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 3.2.1 3.2.2 3.2.3 3.2.4 3.2.5 3.2.6
Bildunterschriften für jedes Bild . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105 Erstellen individueller Links für Bilder . . . . . . . . . . . . . . . . . . . . . . . . . . 107 Neu erstellte Seiten automatisch definieren . . . . . . . . . . . . . . . . . . . . . 108 Die Toolbar vom RTE modifizieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110 Login-Interfaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111 Session-Timeout heraufsetzen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112
3.3 Arbeiten im Backend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 3.3.1 3.3.2 3.3.3 3.3.4 3.3.5 3.3.6 3.3.7 3.3.8 3.3.9 3.3.10 3.3.11
Die Navigationsframes im Backend anpassbar machen . . . . . . . . . . . 113 Shortcut-Frame aktivieren für Backend-Benutzer . . . . . . . . . . . . . . . . 113 Shortcuts zum Bearbeiten von Inhalten . . . . . . . . . . . . . . . . . . . . . . . . 114 Shortcuts zur Bearbeitung von Dateien . . . . . . . . . . . . . . . . . . . . . . . . . 115 Feste Shortcuts für Benutzer festlegen . . . . . . . . . . . . . . . . . . . . . . . . . 115 Befehle zum Bearbeiten von Elementen anlegen . . . . . . . . . . . . . . . . . 118 Per Befehl eine Datensatzliste anzeigen lassen . . . . . . . . . . . . . . . . . . 119 Per Befehl eine CSV-Liste exportieren . . . . . . . . . . . . . . . . . . . . . . . . . . 121 Per Befehl Backend-Benutzer anlegen . . . . . . . . . . . . . . . . . . . . . . . . . 123 Element Browser modifizieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125 Inhaltsspalten konfigurieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
3.4 Frontend & Admin Panel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128 3.4.1 3.4.2 3.4.3 3.4.4 3.4.5 3.4.6 3.4.7
4
Bearbeitungswerkzeuge ohne Admin Panel . . . . . . . . . . . . . . . . . . . . . Backend-Login mit Weiterleitung zum Frontend . . . . . . . . . . . . . . . . . . Nur Frontend-Bearbeitung erlauben . . . . . . . . . . . . . . . . . . . . . . . . . . . Admin Panel frei platzieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . News im Frontend bearbeitbar machen . . . . . . . . . . . . . . . . . . . . . . . . . Logout vom Frontend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Bearbeitungsleiste an beliebiger Stelle im Template positionieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
128 129 129 130 130 132 133
Templates unter TYPO3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137 4.1 Zum Einsatz von TypoScript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137 4.1.1 4.1.2 4.1.3 4.1.4 4.1.5
Style Sheets in Projekte integrieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . Einbinden dynamischer Style Sheets . . . . . . . . . . . . . . . . . . . . . . . . . . . Stylesheets als Ressource anfügen und bearbeiten . . . . . . . . . . . . . . Styles über den CSS Styler bearbeiten . . . . . . . . . . . . . . . . . . . . . . . . . Abfragen globaler Variablen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
137 138 141 142 144
9
Sandini Bib
Inhaltsverzeichnis
4.1.6 4.1.7 4.1.8 4.1.9 4.1.10 4.1.11 4.1.12 4.1.13 4.1.14 4.1.15
Browserabhängiges Template . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Betriebssysteme erkennen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Das Datum anzeigen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Das Datum als Grafik ausgeben . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Verschiedene Formatierungen von internen und externen Links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Inhalte von den Inhaltsspalten LEFT, RIGHT und BORDER verwenden . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Neue Websites basierend auf Standard-Templates erstellen . . . . . . . Standard-Templates bearbeiten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Upload und Benutzung von Ressourcen in Template Records . . . . . . Den Seiten-/Untertitel im Template hinzufügen . . . . . . . . . . . . . . . . . .
145 146 147 151 154 157 158 159 168 170
4.2 Layout . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171 4.2.1 4.2.2 4.2.3 4.2.4
clear.gif bei Überschriften . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Überschriften korrekt mit Header-Tags auszeichnen . . . . . . . . . . . . . . Auf jeder Seite ein anderes Bild . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Accesskeys . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
171 171 172 174
4.3 Inhalte verschieden ausgeben . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 176 4.3.1 4.3.2 4.3.3
5
PDF-Ausgabe . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 176 Ausgabe von Webseiten für Drucker optimiert . . . . . . . . . . . . . . . . . . . 178 Weitere Ausgabeformate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 181
Navigationen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 183 5.1 HMENU . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 183 5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7
Navigationszustände aktivieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Hauptnavigation durch Unternavigation erweitern . . . . . . . . . . . . . . . . Haupt- und Unternavigation räumlich trennen . . . . . . . . . . . . . . . . . . . Footer-Navigation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Browse-Navigation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Breadcrumb-Navigation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Bereichsüberschriften . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
183 184 186 187 189 190 192
5.2 TMENU . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 193 5.2.1
Trennzeichen in Text-Menüs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 194
5.3 GMENU . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196 5.3.1 5.3.2 5.3.3 5.3.4 5.3.5 5.3.6
10
Simple GMENU . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . GMENU mit Hintergrundgrafiken . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . GMENU mit Rollover-Effekt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Aktive Seiten im GMENU hervorheben . . . . . . . . . . . . . . . . . . . . . . . . . . Die unterschiedlichen Zustände des GMENU . . . . . . . . . . . . . . . . . . . . GMENU mit unterschiedlich breiten Grafiken . . . . . . . . . . . . . . . . . . . .
196 196 198 198 200 200
Sandini Bib
Inhaltsverzeichnis
5.4 Dropdown-Menüs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202 5.4.1 5.4.2
6
Dropdown-Menü mit dem JSMENU-Objekt . . . . . . . . . . . . . . . . . . . . . . 202 Dropdown-Menü mit TMENU . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202
TYPO3-Konfiguration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205 6.1 Backend-Anpassungen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205 6.1.1
Standardwerte für neue Datensätze modifizieren . . . . . . . . . . . . . . . . 205
6.2 Frontend-Anpassungen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 206 6.2.1 6.2.2 6.2.3
Frontend-Admin Panel konfigurieren . . . . . . . . . . . . . . . . . . . . . . . . . . . 206 Bilder an PopUp-Fenster anpassen . . . . . . . . . . . . . . . . . . . . . . . . . . . . 207 Dateiverweise formatieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 210
6.3 Strukturen in TYPO3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 212 6.3.1
Inhalte auf mehreren Unterseiten automatisch platzieren . . . . . . . . . 212
6.4 Formulare . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 214 6.4.1
Rollover-Effekt im E-Mail-Formular . . . . . . . . . . . . . . . . . . . . . . . . . . . . 214
6.5 Website-Optimierung . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 215 6.5.1 6.5.2 6.5.3 6.5.4 6.5.5
7
Meta-Tags . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Getrennte Websitebereiche mit Subdomains . . . . . . . . . . . . . . . . . . . . Unterschiedliche Start-Seiten je nach Domain . . . . . . . . . . . . . . . . . . . Statische/suchmaschinenfreundliche URLs simulieren . . . . . . . . . . . . Größenbeschränkung von Bildern . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
215 217 217 218 220
TYPO3 Extensions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 223 7.1 Allgemeines . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 223 7.1.1 7.1.2 7.1.3
Erweiterungen im Extension Manager installieren . . . . . . . . . . . . . . . . 223 Download von Extensions von TYPO3.org als Datei . . . . . . . . . . . . . . . 224 Extensions als T3X-Datei installieren . . . . . . . . . . . . . . . . . . . . . . . . . . . 224
7.2 RTE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 225 7.2.1 7.2.2 7.2.3 7.2.4 7.2.5 7.2.6 7.2.7
RTE-Schriftarten . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . RTE-Funktionen – Absatzformate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . RTE-Funktionen – eigene Absatz-Klassen . . . . . . . . . . . . . . . . . . . . . . . RTE-Funktionen – Farben . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . RTE-Funktionen – Erscheinungsbild anpassen . . . . . . . . . . . . . . . . . . . RTE-Funktionen – Schaltflächen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . RTE-Funktionen – Tabellen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
226 228 229 230 232 233 233
7.3 News tt_news . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234 7.3.1 7.3.2
News auf der Seite integrieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234 News archivieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234
11
Sandini Bib
Inhaltsverzeichnis
7.3.3
Autorennamen voreintragen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 236
7.3.4
Newsübersicht auf jeder Seite . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 237
7.4 Adressdatenbank tt_address . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239 7.4.1
tt_address einbinden . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239
7.5 Forum tt_board . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 240 7.6 Einladungen mit tipafriend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 240 7.7 Kalender tt_calender . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 241 7.7.1
Kalendereinträge unterteilen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243
7.7.2
Produktbeschreibung in der Produktliste von tt_products automatisch kürzen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244
7.8 Abstimmungen mit tt_poll anlegen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 245 7.9 Anmeldeformulare erweitern . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 246 7.10 AWSTATS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248 7.10.1
AWSTATS automatisieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248
7.11 Login implementieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 250 7.12 Benutzerregistrierung integrieren . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 252 Stichwortverzeichnis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 255
12
Sandini Bib
Zu diesem Buch Mal ehrlich: Wann haben Sie sich das letzte Mal ordentlich und in aller Ruhe in eine so komplexe Anwendung wie TYPO3 eingearbeitet, mit der Sie doch eigentlich vom Start weg produktiv arbeiten wollten? Wahrscheinlich ging es Ihnen wie den meisten Anwendern: Ihr Basiswissen trug Sie ein Stück weit, dann fingen Sie an, herumzuprobieren, über die ersten Hürden halfen Sie sich mit ein wenig Googlen hinweg, doch irgendwann kamen Sie nicht mehr weiter. Sie saßen frustriert vor einem Berg von Möglichkeiten, dabei fehlte Ihnen nur ein kleiner Tipp hier und ein kleiner Trick dort, um zum gewünschten Ergebnis zu gelangen. Hier setzt unser Buch „TYPO3 – Tipps & Tricks“ an. Kein Buch zum Durcharbeiten (obwohl Sie das natürlich tun können), sondern zum Querlesen und Immer-wiederzur-Hand-nehmen. Nicht nur für Quereinsteiger, sondern auch für TYPO3-Anwender mit Vorwissen, die keine Zeit für umfangreiche Einführungen haben und schnell zu Ergebnissen gelangen möchten. Mit den wichtigsten Tipps und Tricks für alle Content-Arbeiter und ihre Administratoren, leicht auffindbar aufbereitet – sozusagen ein „Best of“ der TYPO3-Anwenderforen. Wir zeigen Ihnen z.B. prägnant und übersichtlich, wie Sie TYPO3 auf verschiedenen Plattformen installieren, wie Sie Ihre Inhalte anlegen und verwalten, wie Sie mit Templates arbeiten, wie Sie Seitennavigationen programmieren und wie Sie TYPO3 konfigurieren und um Funktionalitäten erweitern. Aber wir zeigen Ihnen noch vieles andere mehr – insgesamt stecken in diesem Buch über 150 Tipps und Tricks aus unserer eigenen langjährigen TYPO3-Praxis, die Ihnen den Einstieg in und das Arbeiten mit diesem enorm leistungsfähigen CMS erleichtern sollen. Wir hoffen, Sie finden hier, was Sie suchen. Wenn nicht, schreiben Sie uns – wir sind für jede Anregung und Kritik dankbar. Ihre Mail an
[email protected] wird der Verlag umgehend an uns weiterleiten. Viel Spaß und Erfolg bei Ihrer Arbeit mit TYPO3 und diesem Buch!
Christoph Lindemann, Maik Caro November 2005
Sandini Bib
Sandini Bib
1
Installation & Konfiguration
Grundsätzlich sollten Sie sich vor dem Einsatz von TYPO3 überlegen, in welcher Umgebung das System laufen soll. Als Empfehlung kann gelten »TYPO3 arbeitet auch unter Windows, aber es lebt unter Linux«. Aus diesem Grunde werden wir weiter unten nicht nur die Installation von TYPO3 unter Linux detaillierter beschreiben, sondern auch die Installation des Linux-Systems selbst.
1.1
Installation auf Windows mit WAMP QuickStart
Für Windows Benutzer hat Ingmar Schlecht ein Paket geschnürt, das alle erforderlichen Komponenten für eine TYPO3-Installation beinhaltet und die erste Installation zu einem Kinderspiel macht. Die TYPO3-Installer-Pakete können Sie von der Typo3.org-Website herunterladen. Die fertigen Pakete finden Sie auf der Seite: http://typo3.org/download/installers/ Laden Sie das 20 MByte große WAMP QuickStart Paket von der Internetseite und starten es nach dem Herunterladen.
Abbildung 1.1: Mit dem Windows Installer ist das erste eigene TYPO3-System im Handumdrehen installiert
Sandini Bib
1 Installation & Konfiguration
Nach der Zustimmung zu den Lizenzbedingungen sind Sie nur noch wenige Sekunden von der ersten TYPO3-Installation entfernt. Einzig der Zielordner für das QuickStart Setup ist noch anzugeben, in das alle notwendigen Programme installiert werden. In den Unterordnern dieses Zielordners finden Sie alle Programme und auch das htdocs-Verzeichnis, welches das Root-Verzeichnis des Apache Webservers darstellt. Neben den notwendigen Programmen werden auch einige Verknüpfungen im Startmenü angelegt. Über diese Verknüpfungen können Sie den Apache Webserver und die MySQL-Datenbank starten. Die beiden TYPO3-Verknüpfungen rufen die URL http://localhost bzw. http://127.0.0.1 auf. Wenigstens die zweite Verknüpfung sollte in das Root-Verzeichnis des Webservers verweisen, da diese IP-Adresse für den Localhost reserviert ist.
Abbildung 1.2: Im Startmenü finden Sie nach der Installation Verknüpfungen zum Startern der Datenbank und des Webservers Damit der Apache Webserver Anfragen beantworten kann, müssen Sie diesen über die Verknüpfung start Apache starten. Dabei öffnet sich automatisch ein Konsolenfenster, das den Status des Apache Webservers anzeigt. Mit dem Schließen dieses Konsolenfensters wird der Apache Webserver gestoppt.
16
Sandini Bib
1.1 Installation auf Windows mit WAMP QuickStart
Abbildung 1.3: Eine ähnliche Eingabeaufforderung gibt es auch für die MySQL-Datenbank, wenn diese gestartet wurde Im Windows-Ordner system32\drivers\etc befindet sich die Datei hosts, über die Sie die lokale Namensauflösung anpassen können. Standardmäßig ist hier der IP 127.0.0.1 der Name localhost zugewiesen. Soll der Testserver aber über eine andere Adresse erreichbar sein, können Sie die dafür vorgesehenen DNS-Namensauflösungen in dieser Datei leicht eintragen. In einem Editor geöffnet, stellt sich die Datei wie im folgenden Listing dar: # # # # # # # # # # # # # # # # # # # #
Copyright (c) 1993-1999 Microsoft Corp. Dies ist eine HOSTS-Beispieldatei, die von Microsoft TCP/IP für Windows 2000 verwendet wird. Diese Datei enthält die Zuordnungen der IP-Adressen zu Hostnamen. Jeder Eintrag muss in einer eigenen Zeile stehen. Die IPAdresse sollte in der ersten Spalte gefolgt vom zugehörigen Hostnamen stehen. Die IP-Adresse und der Hostname müssen durch mindestens ein Leerzeichen getrennt sein. Zusätzliche Kommentare (so wie in dieser Datei) können in einzelnen Zeilen oder hinter dem Computernamen eingefügt werden, aber müssen mit dem Zeichen '#' eingegeben werden. Zum Beispiel: 102.54.94.97 38.25.63.10
127.0.0.1
rhino.acme.com x.acme.com
# Quellserver # x-Clienthost
localhost
17
Sandini Bib
1 Installation & Konfiguration
Hier können nun beliebige Zeilen hinzugefügt werden. Soll der Test-Server beispielsweise unter http://testserver.typo3 erreichbar sein, braucht nur die folgende Zeile ergänzt zu werden: 127.0.0.1
testserver.typo3
Jetzt könnn Sie mit jedem beliebigen Webbrowser die neue Adresse erreichen. Der Apache Webserver meldet sich mit einer statischen HTML-Seite zurück.
Abbildung 1.4: Über die Startseite des WAMP-Systems kann das TYPO3-System aufgerufen werden Bevor Sie nun TYPO3 aufrufen können, müssen Sie noch die MySQL-Datenbank starten. Beim Starten der Datenbank über den Startmenüeintrag öffnet sich ein Konsolenfenster, das Sie nicht schließen dürfen, da ansonsten die Datenbank gestoppt wird. Nachdem der Apache Webserver und die Datenbank gestartet sind, können Sie die TYPO3-Seite aufrufen. Über den Link TYPO3 Frontend erreichen Sie jetzt die im QuickStart-Paket mitgelieferte Beispielseite.
18
Sandini Bib
1.1 Installation auf Windows mit WAMP QuickStart
Abbildung 1.5: Die MySQL-Eingabeaufforderung sollte über die Verknüpfung im Startmenü beendet werden und nicht durch einfaches Schließen der Eingabeaufforderung, sonst kann die Datenbank abstürzen
Abbildung 1.6:
Die Demo-Website des FC Bigfeet
19
Sandini Bib
1 Installation & Konfiguration
Hinter dem Eintrag TYPO3-Backend verbirgt sich das Administrationsinterface. Die Zugangsdaten hierfür lauten wie folgt:
Abbildung 1.7:
Das Backend-Login
Die Zugangsdaten werden bei aktuellen Browsern in der Regel direkt übergeben und im Login-Formular voreingetragen, sodass ein Klick auf den Button LOG IN genügt, um das Administrationsinterface aufzurufen.
Abbildung 1.8:
20
Das TYPO3-Backend im WAMP-Paket – leider – nur in der Version 3.6.0RC1
Sandini Bib
1.2 Installation auf Mac OS X mit XAMPP
Das war’s, damit haben Sie die Installation Ihrer ersten TYPO3-Testumgebung fertig gestellt und können damit beginnen, die ersten Schritte in TYPO3 zu machen.
1.2
Installation auf Mac OS X mit XAMPP
Die Installation auf dem Mac mit einem OS X gestaltet sich ähnlich simpel wie die unter Windows. Andreas Beutel hat ein Paket für Mac OS X ab der Version 10.2 geschnürt, mit dem eine TYPO3-Installation ein echtes Kinderspiel ist. Das Herunterladen des Pakets nimmt dabei fast die meiste Zeit in Anspruch. Das Paket basiert auf dem XAMPP und beinhaltet die Komponenten Apache, MySQL, PHP & PEAR, SQLite, Perl, ProFTPD, phpMyAdmin, OpenSSL, GD, Freetype2, libjpeg, libpng, zlib, Ming, Webalizer, mod_perl, eAccelerator, phpSQLiteAdmin. Nach dem Download muss das Archiv extrahiert werden und über das DMA kann dann das Laufwerk TYPO3 QuickStart 3.8.0-1.1 gemappt werden. Dort finden Sie dann das Installationsprogramm.
Abbildung 1.9: eingerichtet
Es werden alle notwendigen Komponenten über diesen Installer
Nachdem den Lizenzbedingungen zugestimmt wurde, müssen Sie das Zielvolume auswählen. Auf dem Zielvolume werden dann alle Softwarepakete installiert.
21
Sandini Bib
1 Installation & Konfiguration
Abbildung 1.10: Wählen Sie die Festplatte aus, auf der die Software installiert werden soll Jetzt kann die Installation gestartet werden. Nach Abschluss der Installation wird das TYPO3-Verzeichnis geöffnet. In diesem Verzeichnis finden Sie alle wichtigen Verknüpfungen.
Abbildung 1.11: Das TYPO3-Verzeichnis mit den wichtigen Verknüpfungen
22
Sandini Bib
1.2 Installation auf Mac OS X mit XAMPP
Über die Verknüpfungen Start XAMPP.term und Stop XAMPP.term wird das System, also der Apache Webserver und der MySQL-Datenbankserver, gestartet.
Abbildung 1.12: Das Terminal, über das die Server gesteuert werden Beim Aufruf dieser Verknüpfung öffnet sich ein Terminal-Fenster, in dem unter Umständen das Administratoren-Kennwort eingegeben werden muss. Wenn die Start- bzw. Stoppaktionen durchgeführt sind, schließt sich dieses Terminal-Fenster selbstständig. Sind die Server gestartet, kann über einen Webbrowser die erste Anfrage an der Webserver geschickt werden. Der Webserver wird über http://localhost aufgerufen. Im Document Root, das über die gerade genannte Adresse aufgerufen werden kann, befindet sich die XAMPP-Website mit einigen nützlichen Werkzeugen, Dokumentationen, Beispielen und vielen Informationen zum System. Über die XAMPP-Website kann das System jederzeit kontrolliert werden. Sollte sich diese Seite nicht über http://localhost aufrufen lassen, ist der Webserver nicht gestartet und Sie müssen erneut Start XAMPP.term aufrufen. In seltenen Fällen kann es auch an der Namensauflösung liegen. Dann sollte es aber mit der Adresse http://127.0.0.1 klappen. Wenn die XAMPP-Seite angezeigt wird, können Sie über das Verzeichnis TYPO3 das Frontend und Backend von TYPO3 aufrufen. Über QUICKSTART WEBSITE.WEBLOC rufen Sie die TYPO3-Website in Ihrem Standardbrowser auf. TYPO3-BACKEND.WEBLOC öffnet das TYPO3-Backend im Webbrowser.
23
Sandini Bib
1 Installation & Konfiguration
Abbildung 1.13: Die XAMPP-Seite mit vielen hilfreichen Links in der Navigation
Abbildung 1.14: Die Website des TYPO3 QuickStart Paketes
24
Sandini Bib
1.3 Installation auf Linux
1.3
Installation auf Linux
Auf Linux-Systemen können die TYPO3-Quellcode-Dateien mittels so genannter Symlinks eingebunden werden. Hier sollten Sie die tar.gz-Pakete verwenden, die auf Windows-Betriebssystemen nicht funktionieren, da Symlinks dort nicht verwendet werden können. Wir werden im Folgenden nicht nur eine TYPO3-Installation auf einem Debian-System zeigen, sondern auch die Installation des Debian-Systems selbst. Debian GNU/Linux – so der vollständige Name – ist eine frei im Internet entwickelte und erhältliche Linux-Distribution, die professionellsten Ansprüchen genügt.
1.3.1
Debian GNU/Linux Basis-System installieren
Debian GNU/Linux – nachfolgend der Einfachheit halber Debian – kann auf verschiedenen Wegen installiert werden, von denen hier nur der einfachste kurz beschrieben werden soll. Dazu ist es notwendig, dass Sie die erste CD-ROM des stabilen Debian-Releases haben, um von dieser zu booten. Bei Fertigstellung dieses Buches war dies das Debian-Release 3.1r0, sarge. Unter http://www.debian.de/CD/http-ftp/ finden Sie eine Liste von Servern (sogenannte »Spiegel« oder »Mirrors«), auf denen die CD-Images angeboten werden. Das Release umfasst insgesamt sieben CD-Images. Für diese Anleitung benötigen Sie lediglich das erste Image, da die restlichen Programme über das Netzwerk installiert werden können. Eine detaillierte Installationsanleitung erhalten Sie unter www.debian.de. Auch die alternativen Installationsmöglichkeiten werden dort beschrieben. Sollten bei der Installation Probleme auftreten, finden Sie am schnellsten hilfreiche Tipps in der Debian-Mailingliste oder im Archiv der Mailingliste. Sehr hilfreich bei den ersten (und allen weiteren) Schritten mit Debian ist auch das Debian-Anwenderhandbuch, online zu finden unter www.debiananwenderhandbuch.de. Für den Download des ersten Debian-CD-Images empfiehlt es sich, einen Downloadmanager einzusetzen, da ein eventuell unterbrochener Download von den meisten Webbrowsern nicht wieder aufgenommen werden kann. Fresh Download (http://www.freshdevices.com/) oder File Zilla (http://sourceforge.net/projects/filezilla/) sind nur zwei dieser Downloadmanager. Das Image kann mit den gängigen Brennprogrammen auf CD-ROM gebrannt werden. Sollten Sie über keine geeignete Brennsoftware verfügen, können Sie z.B. Sie burnatonce (http://www.burnatonce.de/) ausprobieren, das für den privaten Einsatz frei ist. Booten Sie das System nun von der Debian-CD. Sollte die Hardware ein Booten von CD nicht unterstützen, muss eine Boot-Diskette erstellt werden. Dazu müssen die Disketten-Images rescue.bin und root.bin jeweils auf eine Diskette geschrieben werden. Diese Images liegen wie das Programm, mit dem Sie diese Disketten erzeugen, im Verzeichnis install auf der ersten Debian-CD. Starten Sie im Windows-Dateimanager einfach das Programm rawrite2.exe im Verzeichnis install durch Doppelklick
25
Sandini Bib
1 Installation & Konfiguration
und geben Sie als Sourcefile rescue.bin und das Diskettenlaufwerk (vermutlich a:) an, in dem sich die noch leere Bootdiskette befindet.
Abbildung 1.15: Mit RaWrite können bootfähige Disketten erzeugt werden Um anschließend das Image root.bin auf die Diskette zu schreiben, verfahren Sie analog. Stecken Sie dann die so erzeugte Boot-Diskette in das Diskettenlaufwerk und booten Sie das System neu. Die Debian-Installation sollte nun starten und das Basis Debian-System auf Ihrem Server installieren. Nach Fertigstellung sollte bereits die Netzwerkverbindung und Namensauflösung funktionieren. Dies kann überprüft werden, indem Sie nach dem Login versuchen, eine bekannte Internetadresse mit dem Ping-Befehl zu erreichen. Wenn das noch nicht funktioniert, sollten die Netzwerkeinstellungen überprüft werden. Nach Fertigstellung der Standardinstallation kann jetzt der Server vom Arbeitsplatzrechner aus weiter konfiguriert werden. Dazu benötigen Sie einen SSH-Client, über den Sie sich mit dem Debian-Server verbinden. Der SSH-Server sollte bei der Installation auf dem Debian-Server mit installiert worden sein. Nach dem Start von Putty1 müssen Sie die IP-Adresse des Debian-Servers eingeben und das Protokoll auf SSH umstellen. Ein Klick auf OPEN sollte nun eine SSH-Verbindung zum Debian-Server öffnen. Beim ersten Versuch wird Putty mit einer Warnung antworten, da Putty den Server Key des Debian-Servers noch nicht kennt. Antworten Sie mit JA, um die Verbindung aufzubauen. Anschließend erscheint das LogIn, sodass Sie sich nun auf dem Server einloggen können. 1
26
http://www.chiark.greenend.org.uk/~sgtatham/putty/
Sandini Bib
1.3 Installation auf Linux
Abbildung 1.16: Der Windows SSH-Client Putty ist frei erhältlich und leicht zu bedienen
Abbildung 1.17: Der Key Fingerprint für die verschlüsselte SSH-Verbindung muss auf dem lokalen Rechner abgelegt werden Bevor Sie mit der Installation der einzelnen Komponenten fortfahren können, ist noch zu überprüfen, ob die Internetverbindung hergestellt ist und ob die Namensauflösung funktioniert. Wenn Sie mit dem Befehl ping gefolgt von einer beliebigen vorhandenen Internetdomain eine Antwort erhalten, ist die Internetverbindung hergestellt und die Namensauflösung funktioniert ebenfalls korrekt.
27
Sandini Bib
1 Installation & Konfiguration
Sollte der Ping keine Antwort hervorbringen, obwohl die Domain vorhanden ist, ist die Internetverbindung nicht korrekt eingerichtet oder die Netzwerkkarte funktioniert nicht korrekt. Lesen Sie dann die online verfügbare Debian-Installationsanleitung gründlich durch. http://www.debian.de/releases/stable/installmanual Im Abschnitt 7.7, Konfiguration des Netzwerkes, sollte ein Hinweis oder Lösungsansatz zu Ihrem Problem vorhanden sein.
1.3.2
Installation weiterer Komponenten
Das Basissystem beinhaltet die wichtigsten Programme des Betriebssystems. Ein Webserver oder Datenbankserver muss jetzt erst noch installiert werden. Das APT »a package tool« ist das Debian-Paketmanagement-Werkzeug, mit dem einfach neue Pakete installiert werden können. Bevor die Installation neuer Pakete durchgeführt werden kann, muss das APT erst noch konfiguriert werden. Der Befehl apt-setup öffnet die APT-Konfiguration. Da die restlichen Pakete über das Internet installiert werden sollen, wählen Sie HTTP aus und folgen dem Dialog.
Abbildung 1.18: Die Quelle des Paketmanagements muss auf http eingestellt werden Wenn das Konfigurations-Setup komplett durchlaufen wurde, können weitere Quellen hinzugefügt werden, was aber noch nicht notwendig ist. Beantworten Sie die Frage nach weiteren Quellen also mit NEIN.
28
Sandini Bib
1.3 Installation auf Linux
Abbildung 1.19: An dieser Stelle müssen noch keine weiteren Installationsquellen hinzugefügt werden Die APT-Konfiguration wird dann beendet und Sie erhalten wieder die Kommandozeile des Debian-Servers. Wechseln Sie nun mit dem Befehl cd /etc/apt/ in das Verzeichnis /etc/apt/. Dort befindet sich die Datei sources.list mit einer Liste der Installationsquellen. Mit dem Befehl vi sources.list können Sie die Liste mit dem Editor vi öffnen. Dort sollten sich einige Einträge finden, die die APT-Konfiguration entsprechend Ihrer Angaben vorgenommen hat. Bei der Standardkonfiguration müsste die Datei wie folgt aussehen: deb http://ftp.de.debian.org/debian/ stable main deb-src http://ftp.de.debian.org/debian/ stable main deb http://non-us.debian.org/debian-non-US stable/non-US main deb-src http://non-us.debian.org/debian-non-US stable/non-US main deb http://security.debian.org/ stable/updates main
Als Erstes sollte nun das Debian-System auf den aktuellen Stand gebracht werden. Der Befehl apt-get update
aktualisiert die Paketliste. Der Parameter upgrade veranlasst apt anschließend, die Installation der aktuellen Pakete durchzuführen: apt-get -u upgrade
29
Sandini Bib
1 Installation & Konfiguration
APT gibt eine Liste der Pakete aus, die aktualisiert werden und die Datenmengen, die heruntergeladen werden müssen, sowie den notwendigen Speicherplatz für die Aktualisierung dieser Pakete. Wenn nun fortgefahren wird, startet APT die einzelnen Dateidownloads und installiert die Pakete. Je nach Internetverbindung kann das einige Minuten in Anspruch nehmen. Nachdem das System up to date ist, müssen Datenbank, Webserver und PHP installiert werden. Dies geschieht mit dem folgenden Befehl: apt-get -u install apache php4-gd2 mysql-server php4-mysql
Während der Installation öffnet sich die MySQL-Konfiguration. Die meisten Vorgaben können übernommen werden. Lediglich die Frage, ob MySQL beim Booten automatisch gestartet werden soll, sollte mit YES beantwortet werden.
Abbildung 1.20: Wenn der Datenbankserver beim Starten des Systems immer mitgestartet wird, braucht das nicht manuell erledigt zu werden Nach Abschluss der MySQL-Konfiguration wird die Installation fortgesetzt. Im weiteren Verlauf werden Sie gefragt, ob das apacheconfig-Skript gestartet werden soll. Starten Sie das Skript und lassen Sie die Änderungen in die Konfigurationsdateien schreiben. Im weiteren Verlauf beantworten Sie alle Fragen mit Y, damit die ApacheErweiterungen geladen werden und der Webserver neu gestartet wird. Wenn die Installation und Konfiguration abgeschlossen ist, gelangen Sie wieder zurück zum Kommandozeilen-Prompt.
30
Sandini Bib
1.3 Installation auf Linux
Nun kann der Webserver getestet werden. Dazu muss im lokalen Netzwerk mit einem Webbrowser die IP-Adresse des Debian-Servers aufgerufen werden. Der Server antwortet mit der Debian-Willkommen-Seite.
Abbildung 1.21: Das Dokument im Document Root erzeugt diese Seite Diese Seite gibt schon ein paar wichtige Informationen über den Webserver aus, wie zum Beispiel das Verzeichnis des Document Root und wo Sie die wichtigen Konfigurationsdateien des Apache finden können. Hier sind jetzt noch von Hand drei Anpassungen an der Konfigurationsdatei des Webservers vorzunehmen. Um diese Datei – httpd.conf in /etc/apache/ – editieren zu können, müssen Sie zuerst Superuser werden. Geben Sie dazu IU (¢) ein, gefolgt von Ihrem rootPasswort. Rufen Sie dann vi zusammen mit der Apache-Konfigurationsdatei auf: vi /etc/apache/httpd.conf
Durch den Befehl :set number
können Sie im Editor die Zeilennummern anschalten. In der Zeile 310 sollte der ServerName auf localhost gesetzt werden. Mit der Taste (x) können Zeichen gelöscht werden. Anschließend müssen Sie mit (i) in den Insert-Modus wechseln und den Namen eingeben. Die Zeile sollte dann wie folgt aussehen: 310 ServerName localhost
31
Sandini Bib
1 Installation & Konfiguration
Den Insert-Modus verlassen Sie wieder, indem Sie die Taste (Esc) drücken. In den Zeilen 752, 753, 757 und 758 müssen die Rauten entfernt werden. Diese kommentieren die folgenden Codes aus. 752 753 754 755 756 757 758
AddType application/x-httpd-php3 .php3 AddType application/x-httpd-php3-source .phps # # And for PHP 4.x, use: # AddType application/x-httpd-php .php AddType application/x-httpd-php-source .phps
Zum Schluss muss noch in der Zeile 241 die Raute entfernt werden, damit das php4Modul vom Apache geladen wird: 241 LoadModule php4_module /usr/lib/apache/1.3/libphp4.so
Speichern Sie die Datei und verlassen Sie den Editor, indem Sie :wq eingeben, was für write quit steht. Anschließend gelangen Sie zurück in die Kommandozeile. Laden Sie die geänderte Konfiguration, damit die Modifikationen dem Webserver bekannt werden: /etc/init.d/apache reload
Um die Skriptsprache PHP zu testen, sollten Sie nun ein kleines PHP-Skript in das Document Root schreiben. Wechseln Sie dazu in das Document Root-Verzeichnis des Webservers: cd /var/www/
Dort legen Sie eine neue Datei an: vi phpinfo.php
Wechseln Sie wieder mit (i) in den Insert-Modus und schreiben Sie den folgenden Code:
Verlassen Sie den Insert-Modus mit (Esc) und speichern Sie die Datei (mit :w). Nun kann die Datei über einen Webbrowser aufgerufen werden und der phpinfo-Befehl gibt den derzeitigen Status des PHP aus. Die MySQL-Datenbank braucht nicht weiter konfiguriert zu werden. Es empfiehlt sich aber, den Datenbankserver vor unerlaubten Zugriffen zu schützen. Vergeben Sie aus Sicherheitsgründen immer ein Kennwort für den root-Zugriff auf den MySQLServer: /usr/bin/mysqladmin -u root password neues_passwort
32
Sandini Bib
1.3 Installation auf Linux
Abbildung 1.22: Der Befehl phpinfo() liefert eine komplette Ausgabe aller PHPEinstellungen Um auf die Datenbank über ein komfortables grafisches Frontend zugreifen zu können, sollten Sie phpMyAdmin installieren, das auch als Debian-Paket angeboten wird. apt-get install phpmyadmin
phpMyAdmin läuft als Webanwendung im Browser. Weil phpMyAdmin aber in das Verzeichnis /usr/share/phpmyadmin/ installiert wird, muss noch eine Verknüpfung vom Document Root in dieses Verzeichnis angelegt werden. cd /var/www/ ln –s /usr/share/phpmyadmin/ phpmyadmin
Bevor phpMyAdmin auf die Datenbank zugreifen kann, müssen noch die Kennwörter der Benutzer in der config.inc.php eingetragen werden: vi /usr/share/phpmyadmin/config.inc.php $cfgServers[1]['stduser']= 'root'; $cfgServers[1]['stdpass']= 'passwort';
33
Sandini Bib
1 Installation & Konfiguration
$cfgServers[1]['auth_type']= 'cookie'; $cfgServers[1]['user']= 'root'; $cfgServers[1]['password']= 'passwort';
Nun kann phpMyAdmin über den Webbrowser aufgerufen werden.
Abbildung 1.23: Das Login von phpMyAdmin
1.3.3
Installation der TYPO3-Komponenten
Die TYPO3-Komponenten sind nicht auf den Debian-Servern vorhanden, sodass die Liste der Installationsquellen zuerst angepasst werden muss. vi /etc/apt/sources.list
Fügen Sie der Liste die folgenden beiden Zeilen Code am Ende an: deb http://typo3.sunsite.dk/software/debian/ ./ deb-src http://typo3.sunsite.dk/software/debian/ ./
Das Paket typo3-env beinhaltet alle erforderlichen Pakete, die für den Einsatz von TYPO3 notwendig sind. Zuvor muss aber die Paketliste aktualisiert werden, bevor von den neuen Quellen die Pakete geladen werden können. apt-get update apt-get install typo3-env
34
Sandini Bib
1.3 Installation auf Linux
Nachdem die Pakete installiert wurden, kann mit dem typo3-site-installer eine neue TYPO3-Seite angelegt werden. Dem typo3-site-installer muss lediglich ein Zielverzeichnis übergeben werden, in dem die TYPO3-Seite angelegt wird. typo3-site-installer -d=/var/www/typo3
Der typo3-site-installer antwortet nach Fertigstellung mit einem Hinweis über noch ausstehende Arbeiten.
Abbildung 1.24: Nach dieser Meldung ist das System schon fertig installiert Als Erstes sollten Sie die Dateirechte der TYPO3-Installation anpassen. chown www-data.www-data /var/www/typo3/ -R www-data ist der Benutzer und die Benutzergruppe des Apache Webservers. Kann dieser nicht auf die TYPO3-Verzeichnisse zugreifen, wird es zu Problemen kommen.
Mit dem TYPO3 Install Tool wird die TYPO3-Seite eingerichtet. Damit dieses Tool aufgerufen werden kann, muss ein Befehl auskommentiert werden, der den Aufruf dieses Tools aus Sicherheitsgründen unterbindet. Rufen Sie die Datei index.php mit dem vi auf: vi /var/www/typo3/typo3/install/index.php
In Zeile 40 der Datei befindet sich der Befehl die, der durch zwei Schrägstriche auskommentiert werden muss. Wechseln Sie dazu wieder mit (i) in den Insert-Modus. // die("In the main source distribution of Ty …
35
Sandini Bib
1 Installation & Konfiguration
Mit der Tastenfolge [Esc] (:) (w) (q) wird die Änderung wieder gespeichert und der Editor vi verlassen. Nun kann TYPO3 das erste Mal aufgerufen werden. Das TYPO3-Administrationsinterface befindet sich im Unterverzeichnis typo3/. Ist TYPO3 direkt im Webroot installiert, können Sie das TYPO3-Backend wie folgt aufrufen: www.IhreDomain.de/typo3/ bzw. localhost/typo3/. Nach dem Aufruf von TYPO3 wird erkannt, dass es sich um eine Neuinstallation handelt und Sie werden zum 1-2-3-Go Install Tool von TYPO3 weitergeleitet. Im Schritt eins sind die Zugangsdaten zum Datenbankserver anzugeben, damit TYPO3 auf diesem neue Datenbanken anlegen kann.
Abbildung 1.25: Die 1-2-3 Installationsvariante des TYPO3 Install Tools
36
Sandini Bib
1.3 Installation auf Linux
Im zweiten Schritt müssen Sie eine neue Datenbank anlegen, in die das Content Management System die Daten ablegen kann. Die bereits existierenden Datenbanken sollten hierzu nicht genutzt werden.
Abbildung 1.26: TYPO3 benötigt eine eigene Datenbank, die über das Install Tool angelegt werden kann Im dritten Schritt werden dann noch einige Daten importiert und eine Basis-Datenbankstruktur angelegt, bevor das Install Tool die »frohe Botschaft« verkündet. Bevor Sie jetzt das TYPO3-Backend aufrufen, sollten noch ein paar wichtige Einstellungen erwähnt werden. Wie das Install Tool empfiehlt, sollten Sie noch ein paar grundlegende Änderungen vornehmen, da sonst jeder Zugriff auf das Install Tool bekommen kann. Der Link CONTINUE TO CONFIGURE TYPO3 öffnet das Standard Install Tool. Hier sollten Sie zuerst ein neues Kennwort für das Install Tool festlegen, was unter dem Punkt acht ABOUT möglich ist. Damit ist das Install Tool schon nicht mehr mit dem allgemein bekannten Kennwort aufzurufen.
37
Sandini Bib
1 Installation & Konfiguration
Abbildung 1.27: Jetzt kann schon mit der Arbeit in TYPO3 losgelegt werden Wenn Sie die Konfiguration abgeschlossen haben, sollte der die-Befehl, den Sie kurz zuvor auskommentiert haben, wieder aktiviert werden. Wenn Sie wie weiter unten unter Abschnitt 2.3.7, Das Install-Tool sichern, beschrieben vorgehen, können Sie die Deaktivierung des Install-Tools sogar mit einer Weiterleitung verbinden. Über die Adresse http://192.168.1.16/typo3/typo3/ können Sie das TYPO3-Backend aufrufen. Das Kennwort für den ADMIN lautet password und sollte natürlich auch schnellstmöglich geändert werden.
38
Sandini Bib
1.3 Installation auf Linux
1.3.4
Automatische Backups durch cron-Job
Backup-Erweiterungen für TYPO3 gibt es mittlerweile einige. Allerdings muss der Administrator diese immer manuell starten. Wir wollen Ihnen jetzt ein einfaches Beispiel vorstellen, womit regelmäßig automatische Backups durch einen Cronjob auf Linux-Systemen erzeugt werden können. Dabei wird zum einen ein Dump der Datenbank gesichert und in einer weiteren Datenbank die TYPO3-Dateistruktur. In diesem einfachen Beispiel gehen wir von einer Stand Alone TYPO3-Installation aus. Das vorgestellte Skript ist aber auch auf andere Serverkonfigurationen erweiterbar. #!/bin/bash # aktuellen Wochentag setzen wochentag=`date '+%A'` # Datenbank Dump erzeugen und mit gzip packen mysqldump --opt -h localhost -u root –p IhrPassword typo3_db | gzip > /typo3backup/typo3_backup.dump.sql.$ wochentag.gz # Dateistruktur sichern und mit gzip packen tar -cf /typo3backup/typo3_backup.$ wochentag /var/www/typo3Verzeichnis/ gzip -f /typo3backup/typo3_backup.$ wochentag
In der Zeile 3 wird der aktuelle Wochentag in die Variable wochentag geschrieben. Die Backup-Dateien erhalten später den Wochentag ZUSATZ. So werden die Backups in einem wöchentlichen Zyklus überschrieben. In der Zeile 5 wird der Dump vom der MySQL-Datenbank erzeugt. Der Dump wird mit gzip gepackt und im Verzeichnis /typo3backup/ abgelegt. Sie müssen also das Verzeichnis angelegt und gzip auf Ihrem Linux-System installiert haben. Hinter -u müssen Sie den Datenbankbenutzer angeben, der bei den meisten Installationen root ist. Hinter -p müssen Sie das Kennwort des Benutzers angeben. Sollten Sie kein Kennwort vergeben haben, kann die Angabe zum Testen entfernt werden. Sie sollten bei einem Live-System aber immer ein Kennwort vergeben. Als letzte Angabe fehlt noch der Name der Datenbank, die gesichert werden soll. Sie können den mysqldump-Befehl auch direkt über eine Shell ausprobieren. Je nach Datenbankgröße kann der Dump allerdings einige Zeit in Anspruch nehmen. Jetzt muss noch die Dateistruktur gesichert werden. Dazu wird in der vorletzten Zeile unseres kleinem Backup-Skriptes ein TAR-Ball erzeugt. Auch dieser TAR-Ball wird in das /typo3backup/-Verzeichnis geschrieben und erhält als Zusatz den aktuellen Wochentag. Anschließend wird der TAR-Ball mit dem Programm gzip noch komprimiert und fertig ist das Backup-Skript. Die acht Zeilen Code speichern Sie in eine Datei mit der Endung .sh.
39
Sandini Bib
1 Installation & Konfiguration
Jetzt muss nun noch dafür gesorgt werden, dass dieses Backup-Skript täglich ausgeführt wird. Mit dem Befehl crontab –e können Sie Ihre crontab-Einträge editieren. Geben Sie die folgende Zeile ein, um das Backup-Skript täglich um 3:00 Uhr zu starten: 0 3 * * * /Pfad zum Backup-Skript/backupSkript.sh
Die Änderungen an der crontab können anschließend mit crontab –l überprüft werden. Jetzt sollte täglich um 3:00 Uhr ein Backup angelegt werden. Bei Problemen überprüfen Sie die Rechte an der Skript-Datei.
1.3.5
Benutzerrechte im Dateisystem korrekt setzen
Damit die TYPO3-PHP-Skripte vom Webserver ausgeführt werden können, müssen die Zugriffsrechte korrekt gesetzt werden. Hat der Webserver nicht ausreichend Rechte, um die Skripte auszuführen, erhalten Sie eine Fehlermeldung. Die Zugriffsrechte sind meist korrekt gesetzt. Das Problem besteht oft darin, dass der User nicht korrekt gesetzt ist. Als Besitzer muss der User gesetzt sein, auf dem Ihr Webserver läuft. Auf Linux-Servern finden Sie den Benutzer in der Apache-Konfigurationsdatei httpd.conf. Bei den meisten Distributionen finden Sie die Datei im Verzeichnis /etc/apache/. Von der Server-Konsole können Sie die Konfigurationsdatei mit dem Editor vi aufrufen. vi /etc/apache/httpd.conf
Suchen Sie in der Konfigurationsdatei nach User. In der darauf folgenden Zeile werden Sie auch gleich die Gruppe finden, unter der der Webserver läuft. Bei vielen Distributionen heißen sowohl der User als auch die Gruppe www-data. Damit wissen Sie nun, wie der User und die Gruppe lauten. Die Zugriffsrechte des TYPO3-Verzeichnisses müssen jetzt entsprechend gesetzt werden. Mit dem Befehl chown müssen Sie den Eigentümer der TYPO3-Skripte anpassen, wenn nicht schon der korrekte User gesetzt ist. Sie geben nach dem Befehl erst den User, dann die Gruppe getrennt durch einen Punkt an, anschließend folgt das TYPO3-Verzeichnis. Die Option -R bewirkt, dass der Besitzer auch für alle Unterverzeichnisse entsprechend gesetzt wird. chown www-data.www-data TYPO3Verzeichnis –R
Mit dem Befehl ls –la können Sie überprüfen, ob der Benutzer und die Gruppe korrekt geändert wurden.
40
Sandini Bib
1.3 Installation auf Linux
1.3.6
Das Install-Tool sichern
Über das Install Tool können Sie Admin-User anlegen und auf die Datenbank zugreifen. Das Install Tool sollte also nur bei der Installation zugänglich gemacht werden. Ist TYPO3 installiert und fertig eingerichtet, wird das Tool nicht oder nur sehr selten benötigt und sollte dann deaktiviert werden. Um den Aufruf des Install Tools zu unterbinden, ist bereits eine Code-Zeile im Skript eingeführt, die Sie sicherlich bei der Installation bereits auskommentiert haben. Die Zeile befindet sich in der Datei index.php im Verzeichnis typo3/install/. // die("In the source distribution of TYPO3, the install script is disabled by a die() function call.
Fix: Open the file typo3/install/index.php and remove/out-comment the line that outputs this message!");
Die Funktion die bricht die Abarbeitung des Skriptes ab und gibt eine Nachricht aus. Durch Entfernen der beiden Schrägstriche wird der Code aktiv, die Funktion die bricht die Abarbeitung des Skriptes ab und gibt eine Nachricht aus. Wenn Sie die Nachricht ein wenig anpassen, können Sie die Aufrufe des Install Tools zu Ihrer Startseite umleiten. Dazu ist ein wenig HTML-Code notwendig. Das wichtigste Element ist der Meta-Tag, der zu einer anderen Seite weiterleitet. <meta http-equiv=\"refresh\" content=\"0;URL=../../\">
Über den Parameter content stellen Sie die Zeit bis zur Weiterleitung und das Ziel ein. In diesem Fall wird einfach in der Verzeichnishierarchie zwei Ebenen nach oben weitergeleitet, wo sich die Startseite befindet. Sie können natürlich auch zu einer anderen beliebigen Seite weiterleiten. Mit der die-Funktion würde das dann wie folgt aussehen: die("<meta http-equiv=\"refresh\" content=\"0;URL=../../\">Unbenanntes Dokument<meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\">");
Den Code müssen Sie in der index.php in Zeile 46 einfügen. Der Code muss innerhalb der if-Bedingung stehen. Wenn Sie allerdings direkt weiterleiten, wie im Beispiel beschrieben, sollten Sie besser die PHP-Funktion header verwenden. Das ist die sicherere Methode. header("Location: http://www.IhreDomain.de"); exit;
Geben Sie über die Eigenschaft Location Ihre Domain an. Das anschließende exit stellt sicher, dass auch wirklich kein Code mehr ausgeführt werden kann. Diese Weiterleitung wird serverseitig vorgenommen und vom Browser des Clients, wie im vorherigen Beispiel, was deutlich sicherer ist.
41
Sandini Bib
1 Installation & Konfiguration
1.4
MySQL-Datenbank
MySQL ist eine attraktive Alternative zu hochpreisigen, komplexeren DatenbankTechnologien. Seine preisgekrönte Geschwindigkeit, Skalierbarkeit und Zuverlässigkeit machen MySQL zur richtigen Wahl für IT-Abteilungen in den Unternehmen, für Webentwickler und Software-Entwickler.
1.4.1
root-Passwort setzen
Sie sollten ein Kennwort für den Benutzer root festlegen. Andernfalls ist ein Zugriff ohne Kennwort auf die Datenbank möglich. Mit dem folgenden Befehl setzen Sie ein Kennwort für den Benutzer root. mysqladmin –u root password new-password
Wenn die MySQL-Datenbank nicht extern erreichbar sein muss, sollten Sie darauf achten, dass skip-networking in der Datei my.cnf nicht auskommentiert ist. Mit diesen beiden Einstellungen ist bereits ein gutes Maß an Sicherheit gewährleistet. Wenn Sie jetzt noch jeder neu angelegten Datenbank einen eigenen Benutzer mit Kennwort zuweisen, kann Ihre Datenbank bereits als äußerst sicher gelten.
1.4.2
Datenbank-Frontend MySql Commander einsetzen
Das grafische Datenbank-Frontend phpMyAdmin ist bereits in TYPO3 integriert und kann vom Administrator im Backend aufgerufen werden. Ein alternatives Frontend ist der MySQL Commander von Oliver Kührig, der unter http://www.bitesser.de heruntergeladen werden kann. Der MySQL Commander wird als ZIP-Archiv angeboten und kann auf dem LinuxServer mit dem Befehl unzip mysqlcommander.zip entpackt werden. Anschließend müssen die Dateien in ein Verzeichnis im Document Root verschoben werden, damit der MySQL Commander auch aufgerufen werden kann. Damit der Webserver das Web Frontend ausgeben kann, müssen jetzt noch die Dateirechte angepasst werden. Dazu reicht es in der Regel, mit dem Befehl chown den Besitzer der Webserver einzutragen. In diesem Beispiel setzen wir die Rechte des Ordners samt aller Dateien, die sich in dem Ordner befinden. chown www-data.www-data mysqlcommander/ -R
Über das install.php-Skript im Unterverzeichnis ressourcen/install/ können Sie nun die Konfiguration des MySQL Commanders vornehmen.
42
Sandini Bib
1.4 MySQL-Datenbank
Abbildung 1.28: Der MySQL Commander kann über das mitgelieferte KonfigurationsSkript eingestellt werden Nachdem die Konfiguration abgespeichert wurde, kann der Commander über den Link am Seitenanfang der Konfigurationsseite aufgerufen werden.
1.4.3
Datenbank-Backup einspielen
Datenbank-Backups können mit den grafischen Frontend-Werkzeugen, wie phpMyAdmin oder MySQL Commander erzeugt und wieder eingespielt werden. Sie werden aber beim Arbeiten mit Datenbank-Backups schnell an die Grenzen dieser Werkzeuge stoßen. Nicht so bunt und anschaulich, aber wesentlich stabiler und sicherer ist die Arbeit direkt auf der Konsole. Hier können Sie mit dem Befehl mysqldump ein Backup einer Datenbank erzeugen.
43
Sandini Bib
1 Installation & Konfiguration
Das Manual des mysqldump können Sie mit man mysqldump aufrufen. Hier werden alle Optionen und Beispiele erklärt. In den meisten Fällen genügen die folgenden Optionen, um ein Dump der Datenbank zu erzeugen: mysqldump --opt -h localhost -u Benutzer –p Passwort Datenbankname >/pfad/MySQL_Backup.sql
Dieses auf der Konsole erzeugte Dump kann ohne Probleme wieder eingespielt werden. Mit dem Befehl mysql kann das Backup wieder eingespielt werden. Dazu geben Sie einfach die Zieldatenbank an und die SQL Dump-Datei. Durch die spitze Klammer wird der SQL Dump in die Datenbank geschrieben. mysql Name_Zieldatenbank < /pfad/MySQL_Backup.sql
Wie gesagt, Sie können auch den Umweg über ein Datenbank-Frontend gehen. Schneller ist aber immer die Variante über die Konsole.
1.5
PHP-Konfigurationseinstellungen
Neben der Konfiguration von TYPO3 sind einige Einstellungen in der Skriptsprache PHP vorzunehmen. Hier werden besonders Beschränkungen und sicherheitsrelevante Optionen konfiguriert, die in der zentralen Konfigurationsdatei php.ini eingetragen werden.
1.5.1
PHP-Speicherlimit
Bei der Installation von PHP wird das Limit des Arbeitsspeichers, den PHP zum Ausführen von Skripten verwenden darf, auf 8 Mbyte voreingestellt. Das ist für TYPO3 bei weitem nicht ausreichend. Sie müssen diesen Wert auf wenigsten 32 Mbyte hoch setzen. Diese Einstellung finden Sie in der PHP-Initialisierungsdatei php.ini. Die Datei ist bei den meisten Linux-Distributionen im Verzeichnis /etc/ oder /etc/php4/apache/ zu finden. Suchen Sie in der Datei php.ini nach der Variable memory_limit. Dort setzen Sie den Wert auf wenigstens 32M herauf. Bei Shared Hosting-Servern kann das ein Problem werden. Wie der Name schon sagt, handelt es sich hier um Server, die sich mehrere Kunden teilen müssen. Je nachdem, mit wie viel Speicher ein solcher Server ausgestattet ist und wie viele Kunden der Server beherbergt, stehen dem Einzelnen nur feste Speichermengen zur Verfügung. Diese Werte können Sie nicht anpassen. Sie sollten vor der Installation von TYPO3 also genau die Leistungsbeschreibung Ihres Providers ansehen, ob zum Ausführen von TYPO3 auch ausreichend Arbeitsspeicher zur Verfügung gestellt wird.
44
Sandini Bib
1.5 PHP-Konfigurationseinstellungen
1.5.2
PHP Upload-Limits
Das Upload-Limit kann in TYPO3 eingestellt werden, aber auch in PHP wird der Dateiupload begrenzt und kann sogar ganz unterbunden werden. Sollte ein Upload nicht funktionieren, überprüfen Sie zunächst die Einstellung des File-Limits im TYPO3-Install Tool unter Punkt 4 ALL CONFIGURATION.
Abbildung 1.29: Die maximale Dateigröße kann ein Grund für Probleme beim Upload sein Die zweite Begrenzung wird in PHP eingestellt. Um das PHP Upload-Limit anzupassen, müssen Sie die php.ini öffnen. Über die Einstellung file_uploads kann der Upload über HTTP gänzlich unterbunden werden. In der php.ini muss also zunächst file_uploads = On gesetzt sein. Über upload_max_filesize wird dann die maximale Dateigröße für Dateiuploads eingestellt. upload_max_filesize = 10M
Mit 10M wird das Dateilimit auf 10 Mbyte eingestellt.
1.5.3
Safe Mode
Safe Mode versucht auf Shared Hosting-Servern Sicherheitsprobleme zu lösen. Wenn safe_mode aktiviert ist, wird von PHP überprüft, ob der Eigentümer des laufenden Skripts mit dem Eigentümer der Datei übereinstimmt, an der die im Skript enthaltenen Dateifunktionen arbeiten sollen. Ist dies nicht der Fall, wird das Skript mit einer entsprechenden Fehlermeldung abgebrochen. Bei aktiviertem safe_mode kann es also zu Problemen kommen, wenn Dateifunktionen ausgeführt werden. Aus diesem Grund sollte der safe_mode möglichst deaktiviert bleiben. Dazu müssen in der PHP-Konfigurationsdatei php.ini die folgenden beiden Parameter eingestellt werden: safe_mode = Off safe_mode_gid = Off
45
Sandini Bib
Sandini Bib
2
Arbeiten mit Inhalten
In diesem Kapitel wollen wir Ihnen die vielen kleinen und großen Tricks und Kniffe zeigen, die das Arbeiten mit Content in TYPO3 erst richtig erleichtern. Aufgegliedert ist dieses Kapitel in die Bereiche: Struktur, Inhalte, Arbeiten mit Dateien und Funktionalitäten. Sicher werden auch Sie noch ein paar hilfreiche Dinge finden.
2.1
Struktur
Im Bereich Struktur zeigen wir Ihnen Hilfreiches zum Umgang mit Seiten und Seitenstrukturen. So sehen Sie, wie viele Wege zum Ziel führen können und finden manch schnelleren Pfad.
2.1.1
Seiten verstecken
Sie können Seiten von der Anzeige auf der Website ausschließen, indem Sie im SeitenHeader das Häkchen SEITE VERSTECKEN setzen. Dieses Häkchen lässt sich über die unterschiedlichsten Wege erreichen und setzen. Im Kontextmenü der Seite können Sie direkt über den Punkt AUSBLENDEN/EINBLENdas Häkchen aktivieren oder entfernen. Ebenso können Sie diese Einstellung im Kontextmenü über die Punkte der SICHTBARKEITSEINSTELLUNGEN und BEARBEITE SEITEN-HEADER erreichen und bearbeiten. DEN
Eine weitere Möglichkeit, Seiten zu verstecken und wieder sichtbar zu machen, finden Sie im Liste-Modul. Rufen Sie dazu eine Seite auf, deren Unterseiten Sie einstellen möchten. Im Hauptfenster erscheinen die Unterseiten. Aktivieren Sie hier ERWEITERTE ANSICHT. In der erweiterten Ansicht stehen Ihnen zahlreiche Icons zur Verfügung, über die Sie die Seite ebenfalls verstecken können.
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.1: Hier sehen Sie die unterschiedlichen Optionen im Kontextmenü, über die Seiten versteckt werden können
Abbildung 2.2: Seiten im Liste-Modus verstecken
2.1.2
Seiten kopieren
Sie können eine Seite über das Kontextmenü kopieren. Nachdem Sie die Seite kopiert haben, können Sie diese an beliebiger Stelle in der Seitenstruktur Ihrer Website wieder einfügen. Beim Einfügen haben Sie dann die Möglichkeit, die kopierte Seite in eine vorhandene oder nach einer vorhandenen Seite einzufügen. Das Seite-Modul ermöglicht Ihnen auch, die selektierte Seite über die Schaltfläche SEITE VERSCHIEBEN zu kopieren. Wenn Sie den Befehl SEITE VERSCHIEBEN angeklickt haben, öffnet sich der Dialog ELEMENT VERSCHIEBEN, in dem Sie dazu das Häkchen KOPIEREN STATT VERSCHIEBEN setzen müssen. Anschließend können Sie die Seite wieder an beliebiger Stelle in Ihrer Struktur einfügen.
48
Sandini Bib
2.1 Struktur
Abbildung 2.3: Eine Seite über das Kontextmenü kopieren
Abbildung 2.4: Seiten über das Seite-Modul kopieren
49
Sandini Bib
2 Arbeiten mit Inhalten
Natürlich können Sie auch im Liste-Modul Seiten kopieren. Dazu müssen Sie wieder die ERWEITERTE ANSICHT aktiviert haben. Über das Icon SEITE VERSCHIEBEN können Sie dann auch hier die Seite kopieren. Es wird auch aus dem Liste-Modul der ELEMENT VERSCHIEBEN-Dialog aufgerufen, in dem Sie wieder das Häkchen KOPIEREN STATT VERSCHIEBEN setzen müssen.
Abbildung 2.5: Seiten über das Liste-Modul kopieren
2.1.3
Seiten verschieben
Um Seiten zu verschieben, klicken Sie im Kontextmenü der betreffenden Seite auf AUSSCHNEIDEN. Anschließend können Sie die ausgeschnittene Seite über das Kontextmenü in jede Seite oder nach jeder Seite wieder einfügen.
Abbildung 2.6: Eine Seite über das Kontextmenü verschieben
50
Sandini Bib
2.1 Struktur
Außerdem können Sie Seiten über das Seite- und Liste-Modul verschieben. Im SeiteModul klicken Sie auf die Schaltfläche SEITE VERSCHIEBEN und platzieren die Seite im anschließend erscheinenden ELEMENT VERSCHIEBEN-Dialog. Dort platzieren Sie die Seite an gewünschter Stelle. Auch über das Liste-Modul können Sie den SEITE VERSCHIEBEN-Dialog aufrufen. Sie müssen die ERWEITERTE ANSICHT aktiviert haben und brauchen dann nur noch das Icon SEITE VERSCHIEBEN anzuklicken.
2.1.4
Mehrere Seiten kopieren oder verschieben
Um mehrere Seiten kopieren oder verschieben zu können, müssen Sie sich das Klemmbrett anzeigen lassen. Wechseln Sie dazu in das Liste-Modul und setzen das Häkchen vor KLEMMBRETT ANZEIGEN. Jetzt müssen Sie eines der Klemmbretter mit den Nummern eins bis drei aktivieren, indem Sie auf das kleine PLUS-Icon klicken. Es werden jetzt kleine Kästchen hinter jeder Seite angezeigt. Über diese Kästchen können Sie nun verschiedene Seiten an unterschiedlicher Stelle in der Struktur selektieren. Anschließend transferieren Sie alle ausgewählten Datensätze über das erste der vier Icons über den Kästchen auf das Klemmbrett. Abschließend wechseln Sie in eine andere Seite und fügen den Klemmbrettinhalt dort wieder ein. Auf diese Weise werden die Seiten verschoben. Wenn Sie die Seiten kopieren möchten, müssen Sie die Option OBJEKTE KOPIEREN STATT ZU VERSCHIEBEN im Klemmbrett aktivieren. Die aktivierte Option wird orange gekennzeichnet.
Abbildung 2.7:
Sie können mehrere Seiten über das Klemmbrett verschieben oder kopieren
51
Sandini Bib
2 Arbeiten mit Inhalten
2.1.5
Mehrere Seiten löschen
Genauso, wie Sie Seiten kopieren und verschieben können, können Sie auch mehrere Seiten löschen. Dazu löschen Sie die übergeordnete Seite über das Kontextmenü. Dann werden alle Unterseiten mit gelöscht.
Abbildung 2.8: Seiten über das Kontextmenü löschen In den meisten Fällen erhalten Sie an dieser Stelle aber eine Fehlermeldung. Diese Fehlermeldung ist ein Schutzmechanismus, der Benutzer davor bewahrt, komplette Seitenzweige zu löschen.
Abbildung 2.9: Sie dürfen keine Seiten mit Unterseiten löschen Um diese Fehlermeldung zu umgehen, können Sie Ihrem Benutzer die Rechte zum Löschen von Seiten mit Unterseiten geben. Rufen Sie dazu die EINSTELLUNGEN unter BENUTZER auf. Im Bereich der erweiterten Funktionen können Sie das rekursive Löschen für Benutzer erlauben.
Abbildung 2.10: Die Benutzereinstellung, um Seitenzweige löschen zu können
52
Sandini Bib
2.1 Struktur
2.1.6
Neue Seiten anlegen
Neue Seiten können über das Kontextmenü einer jeden Seite angelegt werden. Dazu klicken Sie im Kontextmenü auf den Punkt NEU. Jetzt können Sie in oder auch nach der Seite, deren Kontextmenü Sie aufgerufen haben, eine neue Seite anlegen. Wenn Sie sich für eine Variante entschieden haben, müssen Sie einen Seitentitel angeben und die neue Seite speichern. Die neue Seite wird sofort in die Struktur integriert.
Abbildung 2.11: Eine neue Seite über das Kontextmenü einfügen Eine weitere Möglichkeit zum Anlegen einer neuen Seite ist der NeuerstellungsAssistent. Dieser Assistent lädt die Seitenstruktur, in der Sie durch Klicken bequem Ihre neue Seite einfügen können. Diesen Assistenten erreichen Sie auf drei unterschiedlichen Wegen. Sie können über das Kontextmenü den Punkt NEU aufrufen – und statt nun die neue Seite direkt in oder nach der Seite zu platzieren, rufen Sie den Assistenten auf. Im Assistenten platzieren Sie Ihre neue Seite an der gewünschten Stelle. Die neue Seite wird nach dem Speichern sofort in die Seitenstruktur integriert. Sie können den Assistenten auch direkt über WEITERE EINSTELLUNGEN im Kontextmenü aufrufen. Klicken Sie dann im sich neu öffnenden Menü auf NEUERSTELLUNGSASSISTENT. Es wird wieder die Seitenstruktur geladen, in der Sie nun Ihre neue Seite frei platzieren können. Für die dritte Möglichkeit zum Aufruf des Assistenten müssen Sie das Seiten-Modul aktiviert haben. Selektieren Sie eine Seite, innerhalb derer Sie eine neue Seite anlegen möchten. Jetzt können Sie auf NEUE SEITE klicken, um wiederum zum Assistenten zu gelangen.
53
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.12: Den Assistenten über das Kontextmenü aufrufen
Abbildung 2.13: Den Neuerstellungs-Assistenten über die weiteren Einstellungen des Kontextmenüs aufrufen
54
Sandini Bib
2.1 Struktur
Abbildung 2.14: Den Assistenten aus dem Seite-Modus aufrufen
2.1.7
Mehrere Seiten schnell erzeugen
Damit Sie bei umfangreicheren Webseiten nicht jede Seite separat anlegen müssen, gibt es eine kleine Hilfe, mit der Sie mehrere Unterseiten auf einmal anlegen können. Dazu müssen Sie in den Funktionen-Modus wechseln. Selektieren Sie dann die Seite, in der Sie Ihre neuen Unterseiten anlegen möchten, und wählen Sie unter ERWEITERTE FUNKTIONEN den Assistenten ERZEUGE MEHRERE SEITEN aus. Sie können jetzt bis zu neun neue Seiten zugleich anlegen. Geben Sie dazu die Titel der einzelnen Seiten ein und bestimmen Sie, wo die neuen Seiten angelegt werden sollen, falls schon Unterseiten vorhanden sind. Wenn die Seiten vorerst nicht sichtbar sein sollen – etwa damit Sie diese im Hintergrund ungestört mit Inhalten füllen können –, aktivieren Sie das Häkchen NEUE SEITEN VERBERGEN. Sind alle Angaben gemacht, können Sie die neuen Seiten mit der Schaltfläche SEITEN erzeugen. Nach der Bestätigung des Hinweises werden die neuen Seiten in der Seitenstruktur angelegt. ANLEGEN
55
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.15: Mehrere Seiten auf einen Schlag bequem mit den erweiterten Funktionen anlegen
2.1.8
Seiten sortieren
Wenn Sie Seiten neu sortieren möchten, können Sie dies auch von einem Assistenten erledigen lassen. Rufen Sie dazu im Funktionen-Modul die Seite auf, deren Unterseiten Sie sortieren möchten. Dort wählen Sie unter ERWEITERTE FUNKTIONEN den Assistenten SORTIERE SEITEN aus, mit dem Sie Seiten nach vier Kriterien sortieren können: alphabetisch nach dem Seiten- oder dem Untertitel, nach dem Erzeugungszeitpunkt oder nach dem Zeitpunkt der letzten Änderung der jeweiligen Seite. Bei der Sortierung nach den Zeitpunkten werden die Seiten von alt nach neu sortiert. Also stehen die Seiten mit dem ältesten Datum am Anfang. Aber besonders bei der Sortierung nach dem Änderungszeitpunkt möchte man häufig die Seiten mit den letzten Änderungen nach oben sortieren. Das erreichen Sie, indem Sie die Sortierreihenfolge nach der Sortierung umkehren. Sortieren Sie Ihre Seiten nach dem Änderungszeitpunkt und kehren Sie die Reihenfolge anschließend um. Auf diese Weise haben Sie die Seite mit der letzten Änderung als erstes.
56
Sandini Bib
2.2 Inhalte
Abbildung 2.16: Seiten lassen sich komfortabel mit dem Assistenten sortieren Achtung Bei großen Seitenanzahlen können Sie schnell die maximale Zeit erreichen, die einem PHP-Skript zur Verfügung steht, um den Programmcode auszuführen. In der Regel stehen dafür 30 Sekunden zur Verfügung. Wenn Sie mehrere hundert Seiten sortieren möchten, kann das je nach Ausstattung des Servers schon einige Minuten in Anspruch nehmen. In diesem Fall sollten Sie die Bearbeitungszeit für PHP-Skripte durch Anpassen der Variablen max_execution_time in der Datei php.ini höher stufen.
2.2
Inhalte
Im Bereich Inhalte wollen wir Ihnen Hilfen und Anregungen für Standardsituationen im Umgang mit unterschiedlichsten Contentelementen geben.
2.2.1
Einfaches Bearbeiten der Datumsfelder
Im TYPO3-Backend gibt es zwei unterschiedliche Datumsfelder. Einmal das Datumsfeld ohne Zeit, in denen der Tag, Monat und das Jahr angegeben wird. Diese Angaben werden durch Bindestriche getrennt. Im erweiterten Datumsfeld kann zusätzlich noch die Zeit angegeben werden.
57
Sandini Bib
2 Arbeiten mit Inhalten
Um die Eingabe von Daten zu erleichtern, gibt es eine automatische Berechnung des Datums. Dabei geben Sie einfach die Differenz zum aktuellen Datum in Tagen an. Also +1 für das morgige Datum oder -7 das für das Datum vor einer Woche. TYPO3 berechnet das Datum dann automatisch. Bei den Datumsfeldern mit Zeit wird als Zeit standardmäßig immer die aktuelle Zeit eingetragen. Wenn Sie also ein Seiteninhaltselement am dem morgigen Tag für eine Woche veröffentlichen möchten, dann brauchen Sie lediglich +1 in das START-Feld und +8 in das STOP-Feld einzugeben. Beim Verlassen des jeweiligen Feldes berechnet TYPO3 das gewünschte Datum.
Abbildung 2.17: Lassen Sie TYPO3 das Datum berechnen
2.2.2
Links im RTE (Rich Text Editor) löschen
Wenn Sie Texte im Rich Text Editor verlinkt haben, dann können Sie diese Links auf gleichem Weg wieder entfernen, auf dem Sie den Link angelegt haben. Markieren Sie also als Erstes den Text, der bereits verlinkt ist. Klicken Sie anschließend im Rich Text Editor auf das Icon LINK EINFÜGEN, um den Dialog LINK EINFÜGEN/BEARBEITEN zu öffnen. Dort finden Sie vier Registerkarten zum Einfügen der unterschiedlichen Verknüpfungen wie SEITE, DATEI, EXTERNE URL und E-MAIL sowie eine Registerkarte, über die Sie die Verknüpfung löschen können. Eine weitere Möglichkeit, Links zu entfernen, ist das Icon ZEICHENART im Rich Text Editor. Setzen Sie den Cursor an eine beliebige Stelle des verlinkten Textes und klicken auf das Icon ZEICHENART. In einem kleinen Fenster bekommen Sie dann angezeigt, welches der Ziel-HTML-Marker ist. A steht hier für den A HREF, also einen Link. Jetzt können Sie diesen HTML-Marker entfernen.
58
Sandini Bib
2.2 Inhalte
Abbildung 2.18: Links können über den Link-Dialog bearbeitet und auch entfernt werden Mithilfe dieser Variante können Sie auch beliebige andere HTML-Marker aus jedem Text entfernen. Die dritte und wohl einfachste Variante Links im Rich Text Editor zu löschen, ist einfach den Cursor direkt nach dem verlinkten Text zu positionieren. Dann drücken Sie die (æ___) (auch Backspace) genannt, mit der Sie das Zeichen vor dem Cursor löschen können. Jetzt wird aber nicht das letzte Zeichen Ihres verlinkten Textes gelöscht, sondern die Verlinkung. Der Text bleibt unverändert.
2.2.3
Alternative Navigationstitel für Seiten setzen
Im Backend und Frontend wird normalerweise der Seitentitel herangezogen, um die Navigationspunkte zu generieren. Wenn Sie im Frontend andere Bezeichnungen für Ihre Seiten in den Menüs haben wollen als im Backend, dann können Sie dies über den Navigationstitel realisieren. Ist ein Navigationstitel angegeben, wird dieser für die Menüpunkte auf der Website verwendet. Im Backend wird die Seitenstruktur weiterhin aus den Seitentiteln generiert. Damit Sie den Navigationstitel eingeben können, müssen Sie den Seiten-Header bearbeiten und den TYP der Seite auf ERWEITERT umstellen. Erst bei Seiten vom Typ ERWEITERT erscheint das Feld NAVIGATIONSTITEL. Geben Sie hier jetzt den gewünschten Navigationstitel ein.
59
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.19: Sie können alle HTML-Marker über Zeichenart setzen auch wieder entfernen
Abbildung 2.20: Alternative Navigationstitel können über Seiten vom Typ Erweitert angegeben werden
60
Sandini Bib
2.2 Inhalte
2.2.4
Seiten anzeigen lassen
Sie können Ihre Seiten aus dem Backend über das Kontextmenü der jeweiligen Seite aufrufen. Das Frontend mit der entsprechenden Seite wird dann in einem neuen Browserfenster geladen. Alternativ dazu können Sie Seiten auch im Seite- oder ListeModul durch Klicken der Lupe-Symbole im Hauptbereich aufrufen.
Abbildung 2.21: Das Frontend in einem neuen Browserfenster über das Kontextmenü aufrufen Sie können sich das Frontend aber auch im Hauptfenster des Backend anzeigen lassen. Dazu müssen Sie nur in das Anzeigen-Modul wechseln und die gewünschte Seiten aufrufen.
Abbildung 2.22: Das Frontend kann im Backend über das Anzeigen-Modul aufgerufen werden
61
Sandini Bib
2 Arbeiten mit Inhalten
Wenn Sie auf einer Seite mehrere Inhaltselemente platziert haben, können Sie auch direkt zu einem dieser Inhaltselemente springen. Dazu müssen Sie in das Liste-Modul wechseln. In der Seitenstruktur selektieren Sie nun die gewünschte Seite und im Hauptfenster klicken Sie auf das Lupe-Icon des gewünschten Datensatzes. Das Frontend wird dann in einem neuen Browserfenster geladen und zeigt direkt das gewünschte Seiteninhaltselement an. Damit das Lupe-Icon angezeigt wird, müssen Sie die ERWEITERTE ANSICHT aktiviert haben.
Abbildung 2.23: Über das Liste-Modul kann direkt zu Inhaltselementen gesprungen werden
2.2.5
Shortcut-Seiten
Seiten vom Typ Shortcut sind Seiten, bei deren Aufruf direkt auf eine andere Seite verwiesen wird. Sie müssen zum Erstellen von solchen Shortcut-Seiten im SeitenHeader den TYP der Seite auf SHORTCUT einstellen. In der Seitenstruktur wird dann nach dem Speichern der Änderung ein anderes Symbol für die Seite angezeigt.
Abbildung 2.24: Das Icon für Seiten vom Typ Shortcut Außerdem erhalten Sie jetzt neue Felder, über die Sie das Ziel des Shortcuts einstellen müssen. Sie können eine Zielseite unter SHORTCUT zur Seite angeben. Dann wird direkt zu dieser Seite weitergeleitet. Über den Shortcut-Modus kann auf eine zufällige Unterseite der zuvor angegebenen Seite oder zur ersten Unterseite weitergeleitet werden. Wenn Sie keine Angaben bei SHORTCUT zur Seite gemacht haben, wird der Modus auf die aktuelle Seite angewendet. In eines der beiden Felder müssen Sie aber eine Angabe machen, da TYPO3 sonst nicht weiterleiten kann und eine entsprechende Meldung ausgibt.
62
Sandini Bib
2.2 Inhalte
Abbildung 2.25: Die wichtigen Felder der Seite vom Typ Shortcut
2.2.6
Der Seitentyp Externe URL
Externe URL ist ein spezieller Seiten-Typ, der direkt zu einer externen URL weiterleitet. Bearbeiten Sie den Seiten-Header und stellen Sie den TYP auf EXTERNE URL ein. Sie erhalten einen neuen Bereich, in dem Sie die URL eingeben müssen. Außerdem müssen Sie den Typ der URL angeben. In der Regel geben Sie beim TYP http:// an, es sind aber auch alle andere Internetprotokolle möglich. Im Feld ZIEL können Sie den Ziel-Frame angeben, in den die URL geladen werden soll. Soll die URL in einem neuen Browserfenster geladen werden, müssen Sie als Ziel _blank angeben.
Abbildung 2.26: So legen Sie einen Menüpunkt mit einer Verlinkung zur TYPO3.org-Seite an Im Backend werden Seiten, die auf eine externe URL verweisen, mit einem gesonderten Icon gekennzeichnet. Dies geschieht direkt nach der Umstellung des Seiten-Typs. Im Frontend wird diese Seite wie alle anderen in Ihrem Menü angezeigt. Beim Klick auf diesen Menüpunkt wird dann statt einer internen TYPO3-Seite lediglich die externe URL geladen.
Abbildung 2.27: Das Icon im Backend für Seiten vom Typ Externe URL
63
Sandini Bib
2 Arbeiten mit Inhalten
2.2.7
Inhalte bearbeiten
Im Seiten-Modus gibt es zwei wichtige Bearbeitungs-Modi. Meist wird der SpaltenModus verwendet. Ist die Anzeige nicht durch TypoScript verändert worden, werden im Spalten-Modus die Spalten LINKS, NORMAL, RECHTS und RAND angezeigt. In den einzelnen Spalten befinden sich dann die Inhaltselemente. Sie können die Inhaltselemente durch Klicken auf den Text oder auf das BEARBEITEN-Icon zur Bearbeitung öffnen. Die Inhaltselemente lassen sich auch über das Kontextmenü der jeweiligen Inhalts-Symbole zur Bearbeitung öffnen.
Abbildung 2.28: Die drei Möglichkeiten, Inhalte zur Bearbeitung im Spalten-Modus zu öffnen
64
Sandini Bib
2.2 Inhalte
Für ein schnelles Bearbeiten können Sie im Seite-Modul vom Spalten-Modus in den Schnelleingabe-Modus wechseln. Im Schnelleingabe-Modus wird das erste Inhaltselement in der Spalte NORMAL sofort nach dem Seitenaufruf zur Bearbeitung geöffnet. Am Ende der Seite wird eine Übersicht aller auf der Seite vorhandenen Inhaltselemente angezeigt. Hier können Sie dann auch zwischen den Inhaltselementen wechseln, Inhaltselemente verschieben oder neue Inhalte erzeugen. Dieser Modus steht aber nicht bei Seiten zur Verfügung, die vom Typ SHORTCUT oder EXTERNE URL sind.
Abbildung 2.29: Die Schnelleingabe erleichtert den Umgang mit Inhaltselementen
65
Sandini Bib
2 Arbeiten mit Inhalten
Auch im Liste-Modul können Sie jederzeit Ihre Seiteninhalte bearbeiten. Wenn Sie die ERWEITERTE ANSICHT aktiviert haben, steht Ihnen eine Palette mit kleinen Icons hinter jedem Inhaltselement zur Verfügung. Über das Icon DATENSATZ BEARBEITEN, das ist das kleine STIFT-Symbol, können Sie das Inhaltselement zur Bearbeitung öffnen. Ist die ERWEITERTE ANSICHT deaktiviert, können Sie immer noch über das Kontextmenü des jeweiligen Inhaltselementes dieses zur Bearbeitung öffnen.
Abbildung 2.30: Inhaltselemente können auch über das Liste-Modul bearbeitet werden
2.2.8
Inhalte zwischen Seiten verschieben
Inhaltselemente können im Seiten-Modul und im Liste-Modul über das Kontextmenü des jeweiligen Elementes ausgeschnitten werden. In der Zielseite klicken Sie dann auf das Inhaltselement, hinter dem Sie das zuvor ausgeschnittene Element platzieren möchten.
Abbildung 2.31: Inhalte über das Kontextmenü verschieben
66
Sandini Bib
2.2 Inhalte
Eine weitere Möglichkeit verbirgt sich im Kontextmenü hinter den Punkt WEITERE EINSTELLUNGEN. Dort finden Sie unter anderem den Punkt ELEMENT VERSCHIEBEN. In dem sich öffnenden Dialog ELEMENT VERSCHIEBEN können Sie in der Seitenstruktur eine Seite auswählen und das Inhaltselement an gewünschter Position platzieren. An dieser Stelle können Sie wieder durch Aktivieren der Option KOPIEREN STATT VERSCHIEBEN das Inhaltselement auch als Kopie an der gewünschten Stelle einfügen.
Abbildung 2.32: Elemente über Weitere Einstellungen des Kontextmenüs verschieben Diesen Dialog können Sie auch aus dem Liste-Modul direkt aufrufen. Sie müssen dazu nur die ERWEITERTE ANSICHT aktiviert haben. Hinter jedem Inhaltselement erscheint dann eine Reihe von Icons, wovon eines das Verschieben ermöglicht.
Abbildung 2.33: Inhalte aus dem Liste-Modul verschieben Sie können mehrere Inhaltselemente gleichzeitig über eines der numerischen Klemmbretter verschieben. Sie müssen dazu wieder in den Liste-Modus wechseln und sich das Klemmbrett anzeigen lassen. Anschließend öffnen Sie eines der Klemmbretter mit der Nummer eins bis drei. Sie haben dann die Möglichkeit, hinter jedem Element ein Häkchen zu setzen. Wählen Sie dort die zu verschiebenden Inhaltselemente aus und transferieren Sie die Elemente auf das Klemmbrett. Wenn die Inhalte auf das Klemmbrett transferiert wurden, können Sie diese über das EINFÜGEN-Symbol an beliebiger Stelle wieder einfügen. Wenn die Elemente kopiert werden sollen, müssen Sie auf das Icon OBJEKTE KOPIEREN im Klemmbrett klicken. Das Icon wird dann orange hinterlegt.
STATT ZU VERSCHIEBEN
67
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.34: So können Sie mehrere Inhalte auf das Klemmbrett transferieren
Abbildung 2.35: Das Einfügen Symbol
2.2.9
Aktuelle Änderungen rückgängig machen
TYPO3 speichert die letzten zwanzig Änderungen, die Sie an Datensätzen vornehmen. Um die letzte Änderung rückgängig zu machen, öffnen Sie den Datensatz einfach zur Bearbeitung. Neben den Icons zum Speichern, Schließen und Löschen des Datensatzes am Anfang und am Ende der Seite befindet sich das Icon, um Änderungen rückgängig zu machen. Klicken Sie das Icon einfach an und machen damit die letzte Änderung am aufgerufenen Datensatz rückgängig.
Abbildung 2.36: Die letzte Änderung kann mit einem Klick wieder rückgängig gemacht werden Wenn Sie einen früheren Bearbeitungsstand wieder herstellen möchten, dann müssen Sie den Bearbeitungsverlauf aufrufen. Über WEITERE EINSTELLUNGEN im Kontextmenü können Sie den Bearbeitungsverlauf von Seiten und Inhaltselementen öffnen. Sie bekommen dann eine Verlaufsliste mit den Änderungen angezeigt. Über das UNDO-Icon können Sie nun die Werte bis zu einem der aufgelisteten Zeitpunkte rückgängig machen. Über das INFO-Icon können Sie sich die Änderungen detailliert auflis-
68
Sandini Bib
2.2 Inhalte
ten lassen, die vorgenommen wurden und rückgängig gemacht werden können. In der Detailansicht können Sie dann zum jeweils nächsten und vorherigen Status wechseln und so die Änderungen nachvollziehen.
Abbildung 2.37: Im Bearbeitungsverlauf können Sie bis zu zwanzig Änderungen rückgängig machen
2.2.10
Bilder in Inhaltselemente einfügen
Bilder können in die Inhaltselemente BILD und TEXT MIT BILD eingefügt werden. Öffnen Sie Ihr Inhaltselement und scrollen hinunter Sie bis zum Bereich BILD. Über die Schaltfläche DURCHSUCHEN öffnet sich der DATEI-Dialog Ihres lokalen Computers. Sie können über diesen Dialog eine Grafik von Ihrem lokalen Computer direkt auf den Webserver übertragen. TYPO3 speichert die so übertragenen Dateien stan-
69
Sandini Bib
2 Arbeiten mit Inhalten
dardmäßig im Verzeichnis upload oder in einem der dort vorhandenen Unterverzeichnisse ab. Das übertragene Bild wird automatisch im Bereich INHALTSELEMENT eingefügt.
Abbildung 2.38: Bilder können direkt eingefügt werden, oder aber über den Element Browser, der einige Zusatzfunktionen bietet Wenn Sie Bilder über den TYPO3 Element Browser einfügen möchten, benötigen Sie Zugriffsrechte auf das Dateiliste-Modul. Im Element Browser können Sie gleichzeitig mehrere Dateien übertragen und in Ordnerstrukturen ablegen. Diese Bilder können auch mehrfach auf unterschiedlichen Inhaltselementen verwendet werden. Auch lassen sich über den Element Browser mehrere Bilder zuweisen.
2.2.11
Bilder im RTE einfügen
Im Rich Text Editor fügen Sie Bilder über das Icon BILD EINFÜGEN ein. Im folgenden neuen Fenster bekommen Sie links Ihren Verzeichnisbaum angezeigt und rechts den Inhalt des selektierten Verzeichnisses. Über das Formular am Seitenende können Sie auch weitere Bilder auf den Webserver übertragen. Der über den Rich Text Editor geöffnete BILDER-Dialog bietet drei Möglichkeiten, Bilder einzufügen. Wenn Sie ZAUBER-BILDER einfügen, können auch Nicht-Web-Bilder wie zum Beispiel TIFF-Bildformate genutzt werden. Diese »Fremdformate« werden dann automatisch in ein Webformat konvertiert. Dabei wird automatisch auch die Größe der Grafiken für das Web optimiert.
70
Sandini Bib
2.2 Inhalte
Abbildung 2.39: Fügen Sie mehrere Bilder in einem Arbeitsschritt über den Element Browser ein Über NORMALES BILD lassen sich nur Grafiken in Webformaten (also GIF, JPG und PNG) einfügen, die nicht größer als 640x480 Pixel sind. Alle anderen Dateien werden von der Anzeige ausgeblendet. Wenn die Registerkarte DRAG’N’DROP angewählt ist, können Sie die angezeigten Bilder per Drag’n’Drop direkt in das Hauptfenster an beliebiger Textposition platzieren. Wenn Sie ein Bild eingefügt haben, können Sie dieses später noch im Text verschieben und mit den Ausrichtungs-Icons im Text ausrichten. Selektieren Sie das Bild durch Anklicken, erscheint ein Begrenzungsrahmen. Diesen Begrenzungsrahmen können Sie verändern und so die Größe des Bildes anpassen. Sollten Sie beim Verändern des Begrenzungsrahmens diesen nicht proportional verändert haben, ist das kein Problem. Nach dem Speichern des Inhaltselementes korrigiert TYPO3 die Proportionen, sodass das Bild auf jeden Fall unverzerrt angezeigt wird.
71
Sandini Bib
2 Arbeiten mit Inhalten
Wenn Sie ein Bild selektieren, der Begrenzungsrahmen wird angezeigt, und dann auf das Icon BILD EINFÜGEN im Rich Text Editor klicken, erhalten Sie die Möglichkeit, das aktuelle Bild zu bearbeiten. Hier können Sie Seitenränder, Titel des Bildes, Größe und Rand einstellen.
Abbildung 2.40: Bilder können auch im Rich Text Editor später noch angepasst werden
2.2.12
Download-Links einfügen
Um Datei-Downloads auf Ihrer Website zu platzieren, können Sie das Inhaltselement DATEIVERWEIS nutzen. Platzieren Sie es wie normale Inhaltselemente auf einer Seite. Über die Schaltfläche DURCHSUCHEN können Sie direkt von Ihrem lokalen Computer Dateien einfügen. Wenn Sie Zugriff auf das Dateiliste-Modul haben, können Sie dazu auch den TYPO3 Element Browser verwenden. Auf Wunsch zeigt TYPO3 gleich die Dateigröße im Frontend mit an. Setzen Sie dafür einfach die Option ZEIGE DATEIGRÖSSE. Über die drei Layouts können Sie die Darstellung der Download-Links beeinflussen. Sie können Vorschaubilder anzeigen lassen, Icons passend zum jeweiligen Dateiformat oder auch nur Textinformationen. Die Dateigröße ist bei diesem Inhaltselement allerdings beschränkt. Wenn Sie größere Dateien verknüpfen möchten, können Sie dies über den Rich Text Editor realisieren.
72
Sandini Bib
2.2 Inhalte
Abbildung 2.41: Dateien über das Inhaltselement Dateiverweise bzw. Dateilinks einfügen Dazu können Sie ein Inhaltselement vom Typ Text zur Bearbeitung öffnen und eine Textpassage markieren, die mit einer Datei verknüpft werden soll. Klicken Sie dann auf das Icon LINK EINFÜGEN im Rich Text Editor und selektieren den Typ DATEI. Wechseln Sie über den VERZEICHNISBAUM die Verzeichnisse und wählen Sie die Zieldatei aus. Auf diese Weise können Sie auf einfachem Weg auch größere Dateien verknüpfen. Erst bei größerer Anzahl von Downloads lohnt sich die Installation einer der vielen Download-Erweiterungen. Für die meisten Zwecke reichen die TYPO3-Standardmittel aus.
73
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.42: Dateien können auch über den Rich Text Editor verknüpft werden
2.2.13
Links zu Seiten und Elemente einfügen
Links können Sie über das LINK-Icon einfügen. Beim Klick auf das Icon öffnet sich ein Dialog mit dem SEITENBAUM und den unterschiedlichen Link-Typen im Kopf. Hier muss der Typ SEITE ausgewählt werden. Um auf den Anfang einer Seite zu verweisen, können Sie einfach auf den Seitentitel im Seitenbaum klicken. Angaben über das Ziel, also den Frame oder ein neues Fenster, können Sie am Ende machen. Wenn Sie auf den Seitentitel klicken, wird der Link erzeugt und der Dialog schließt sich automatisch. Möchten Sie nicht an den Anfang der zu verlinkenden Seite springen, sondern zu einem bestimmten Inhaltselement auf der Seite, dann können Sie dies tun, indem Sie auf das Icon rechts neben dem Seitentitel im Seitenbaum klicken. Im rechten Bereich bekommen Sie die Inhaltselemente der Seite angezeigt. Hier klicken Sie dann auf das gewünschte Inhaltselement, zu dem verlinkt werden soll.
74
Sandini Bib
2.2 Inhalte
Abbildung 2.43: Links müssen nicht immer an den Seitenanfang verweisen, sondern können auch direkt zu Inhaltselementen verweisen
2.2.14
Link zu E-Mail-Adresse
Wenn Sie in Ihrem Menü einen Link zu einer E-Mail-Adresse integrieren möchten, dann muss der TYP der Seite auf EXTERNE URL eingestellt werden. Jetzt können Sie im Feld URL die E-Mail-Adresse eingeben. Dazu müssen Sie noch den Typ auf MAILTO: einstellen. Wenn Sie jetzt im Menü auf die entsprechend eingestellte Seite klicken, wird sich Ihr standardmässig eingestellter E-Mail-Client mit der angegebenen E-Mail-Adresse im Empfängerfeld öffnen.
Abbildung 2.44: E-Mail-Adressen in die Menüstruktur integrieren
75
Sandini Bib
2 Arbeiten mit Inhalten
Üblicherweise werden Verlinkungen zu E-Mails in Inhaltselementen eingefügt. Öffnen Sie dazu den LINK EINFÜGEN/BEARBEITEN-Dialog durch Klicken auf das LINKIcon. Wählen Sie die Registerkarte EMAIL an und geben die E-Mail-Adresse in das Feld ein. Jetzt müssen Sie nur noch den Link setzen und der Dialog schließt sich automatisch.
Abbildung 2.45: In den Inhaltselementen öffnen Sie einfach den Dialog zum Einfügen von Links. Hierüber können auch Verknüpfungen zu E-Mail-Adressen eingefügt werden. Der Rich Text Editor erkennt E-Mails aber auch automatisch. Geben Sie im Rich Text Editor die E-Mail-Adresse ein. Im Anschluss drücken Sie die Leertaste oder (Enter), und der Rich Text Editor verlinkt den E-Mail-Text mit selbiger E-Mail-Adresse. Bei deaktiviertem Rich Text Editor können Sie den TYPO3 Tag LINK verwenden, um eine Verknüpfung zu einer E-Mail-Adresse einzugeben. Das würde dann wie folgt aussehen: schreib mir
2.2.15
Eine einfache Bildergalerie
Häufig will man nur ein paar Bilder in einer Galerie zusammenstellen und es lohnt nicht, dafür eine Galerie-Extension einzubinden. Für solche Situationen können Sie eine einfache Bildergalerie über das Inhaltselement BILD EINFÜGEN erstellen. Platzieren Sie das Inhaltselement auf einer Seite. Die Bilddaten sollten Sie über das Dateiliste-Modul übertragen, da dort bis zu zehn Dateien auf einmal übertragen werden können.
76
Sandini Bib
2.2 Inhalte
Wenn Sie die Daten übertragen haben, öffnen Sie das Inhaltselement zur Bearbeitung. Im nächsten Schritt müssen Sie Ihre Bilder zuweisen. Öffnen Sie dazu den TYPO3 Element Browser. Im Element Browser selektieren Sie den Ordner in der Verzeichnisstruktur, in den Sie zuvor die Bilder übertragen haben. Im rechten Bereich werden die Inhalte des Ordners aufgelistet. Hier können Sie jetzt durch Klicken auf das PLUSIcon die gewünschten Bilder auswählen. Haben Sie alle gewünschten Bilder über das PLUS-Icon der Liste hinzugefügt, können Sie das Fenster mit dem Element Browser wieder schließen. Sie sollten jetzt eine Auswahl der Bilder in der Liste unter BILDER in Ihrem Inhaltselement auffinden.
Abbildung 2.46: Senden Sie mehrere Bilder vom Element Browser in die Bilderliste des Inhaltselementes Abschließend sollten Sie die Spaltenzahl zur Darstellung der Bilder anpassen. Unter POSITION können Sie angeben, in wie vielen Spalten die Bilder arrangiert werden sollen. Die Einstellung befindet sich in der zweiten Optionspalette, die Sie entweder aktiviert haben müssen oder Sie klicken auf WEITERE OPTIONEN im Bereich POSITION. Stellen Sie gegebenenfalls noch die Bildgröße ein und aktivieren die Funktion KLICKVERGRÖSSERN, damit die Bilder auch in voller Pracht durch den Besucher angezeigt werden können.
77
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.47: Bildeinstellungen für die Galerie
2.2.16
Ein E-Mail-Formular einfügen
E-Mail-Formulare können von den Websitebesuchern ausgefüllt werden und TYPO3 überträgt die Daten an eine hinterlegte E-Mail-Adresse. Ein solches Formular fügen Sie wie alle anderen Inhaltselemente auf einer Seite ein. Das Inhaltselement finden Sie im Inhaltselemente-Assistenten unter FORMULARE. Das Mail-Formular wird mit einer Beispiel-Konfiguration eingefügt, die Sie an Ihre Wünsche anpassen können. Nachdem Sie das Formular einmal gespeichert haben, erhalten Sie neben dem Konfigurations-Feld ein Icon, über das der FORMULAR-ASSISTENT geöffnet werden kann. In diesem Assistenten lassen sich bequem ein oder mehrere neue Formular-Elemente anlegen oder bestehende bearbeiten. Im Bereich SPEZIELLE KONFIGURATION FÜR MAIL-FORMULARE müssen Sie eine Empfänger-E-Mail-Adresse angeben, damit die Formulardaten auch zugestellt werden können. Bei aktiviertem HTML-Modus werden HTML-Mails generiert, die visuell etwas ansprechender aufbereitet sind. Sollte Ihr E-Mail-Client keine HTML-Mails unterstützen, deaktivieren Sie den HTML-Modus einfach. Sollten Änderungen beim Feld EMPFÄNGER EMAIL nicht übernommen werden, dann verfügt Ihr Benutzer über nicht ausreichende Rechte. Um die E-Mail-Adresse speichern zu können, muss dem Benutzer über eine Benutzergruppe das Tabellen-Feld UNTERTITEL DER SEITENINHALTE zur Verfügung gestellt werden. Erst dann wird nach dem Speichern die E-Mail-Adresse auch übernommen. Um den Benutzer über die Weiterleitung der ausgefüllten Felder zu informieren oder dafür zu danken, kann bei der Zielseite eine Seite angegeben werden, auf die nach der Übertragung der Daten weitergeleitet wird. Damit diese Seite nicht in der Navigation auftaucht, sollten Sie diese Seite auf den Typ NICHT im Menü einstellen.
78
Sandini Bib
2.2 Inhalte
Abbildung 2.48: Der Formular-Assistent mit der Beispiel-Konfiguration
79
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.49: Der Benutzer benötigt Rechte zum Untertitel der Seiteninhalte, um die E-Mail im Formular speichern zu können
2.2.17
Eine Suche einfügen
Die Suche fügen Sie auf einer Seite ein, wie auch andere Inhaltselemente. Im Assistenten für die Inhaltselemente finden Sie die Suche im Bereich FORMULARE. Weitere Einstellungen sind nicht zu machen. Wenn Sie die Seite mit dem Suchformular aufrufen, werden Sie feststellen, dass Sie entweder die Seiten-Header und -Keywords durchsuchen können oder aber die kompletten Seiteninhalte. Bei den über die Trefferliste aufgerufenen Seiten markiert TYPO3 das gefundene Suchwort im Text gesondert.
80
Sandini Bib
2.2 Inhalte
Abbildung 2.50: Das Suchformular ist im Assistenten unter den Formularen zu finden
Abbildung 2.51: Das Suchwort wird auf den Seiten besonders hervorgehoben
81
Sandini Bib
2 Arbeiten mit Inhalten
2.2.18
Inhalte von anderen Seiten verknüpfen
Wenn Sie ein Inhaltselement auf unterschiedlichen Seiten mehrfach platzieren möchten, dann können Sie Verknüpfungen auf den Seiten einfügen, die auf das Inhaltselement verweisen. Auf diese Weise brauchen Sie bei Aktualisierungen nur das Inhaltselement zu bearbeiten und die Änderungen wirken sich auf alle Seiten aus, die dieses Inhaltselement verknüpft haben. Um eine solche Verknüpfung anzulegen, platzieren Sie ein beliebiges Inhaltselement auf Ihrer Seite. Anschließend müssen Sie den Typ des Inhaltselementes auf DATENSATZ EINFÜGEN umstellen. Der Name des Inhaltselementes dient nur zu Ihrer eigenen Orientierung und wird nicht im Frontend angezeigt. Im Frontend wird dafür der Titel des verknüpften Inhaltselementes genutzt. Jetzt müssen Sie noch das Objekt, also das Inhaltselement verknüpfen. Öffnen Sie den Element Browser und selektieren Sie das oder die gewünschten Inhaltselemente. Wenn Sie das PLUS-Icon anklicken, wird das Inhaltselement in die Liste der verknüpften Objekte übernommen, ohne dass der Element Browser geschlossen wird. Wenn Sie nur ein Element verknüpfen wollen, können Sie auch auf dessen Überschrift im Element Browser klicken. Dadurch wird das Element direkt in die Liste der Objekte aufgenommen und der Element Browser automatisch wieder geschlossen.
Abbildung 2.52: Inhaltselemente können über den Inhaltstyp Datensatz einfügen verknüpft und damit mehrfach genutzt werden, ohne jeweils Kopien anlegen zu müssen
82
Sandini Bib
2.2 Inhalte
2.2.19
Seiten im Frontend bearbeiten
Im Frontend können Sie direkt auf der Webseite Inhaltselemente und Seiten bearbeiten, löschen oder neue anlegen. Damit das möglich ist, müssen die entsprechenden Bearbeitungswerkzeuge im Frontend bei Ihrem Benutzer aktiviert sein, oder das Admin Panel muss zur Verfügung stehen, in dem Sie die Werkzeuge an- und abschalten können. Sie erhalten dann auf der Webseite kleine Icons, über die die jeweiligen Inhaltsabschnitte bearbeitet werden können. Sollten Sie keine Admin Panel- oder Bearbeitungs-Symbole auf der Webseite nach dem Backend-Login sehen, dann muss das Admin Panel vom Administrator aktiviert werden.
Abbildung 2.53: Inhalte können Sie intuitiv direkt im Frontend bearbeiten
83
Sandini Bib
2 Arbeiten mit Inhalten
2.2.20 Mehrere Inhalte zur gleichzeitigen Bearbeitung öffnen Um mehrere Elemente zur gleichzeitigen Bearbeitung öffnen zu können, müssen Sie eines der numerischen Klemmbretter im Liste-Modus aktiviert haben. Erst dann werden Ihnen die Kästchen angezeigt, über die Sie die zu bearbeitenden Elemente markieren können. Wenn die Elemente markiert sind, müssen Sie auf den kleinen Stift über den Kästchen klicken. TYPO3 öffnet alle markierten Elemente, die Sie jetzt bearbeiten können. Anschließend werden alle Änderungen in allen Elementen durch die bekannten Symbole zum Speichern übernommen.
Abbildung 2.54: Das numerische Klemmbrett muss aktiviert sein, bevor Mehrfachauswahlen getroffen werden können Auf diese Weise können auch Nicht-Seiteninhalte gleichzeitig zur Bearbeitung geöffnet werden. Dies funktioniert auch mit Seiten, Datensätzen und allen anderen im Liste-Modul angezeigten Inhalten. Auch Benutzer-Datensätze und Templates können so gleichzeitig zur Bearbeitung geöffnet werden.
84
Sandini Bib
2.3 Arbeiten mit Dateien
2.2.21
Seiten und Inhalte schnell über die ID öffnen
Im unteren Frame des Backend können Seiten-IDs eingegeben werden. Auf diese Weise lassen sich Seiten, deren ID bekannt ist, schnell aufrufen.
Abbildung 2.55: Seiten schnell über die ID aufrufen Seit der TYPO3-Version 3.8.0 lassen sich hierüber auch beliebige Datensätze zur Bearbeitung aufrufen. Dazu geben Sie einfach den Tabellennamen des Datensatzes an und durch einen Doppelpunkt getrennt die ID des gewünschten Datensatzes aus der Tabelle. Um ein Inhaltselement über diese Funktion schnell zu öffnen, würde ein Aufruf wie folgt aussehen: tt_content:99
Sie können auch Adressdatensätze oder Backend-Benutzer auf diese Weise zur Bearbeitung öffnen. tt_address:99 be_users:1
Die korrekte Schreibweise der Tabellennamen entnehmen Sie am einfachsten dem Systemtool phpMyAdmin.
2.3
Arbeiten mit Dateien
Beim Arbeiten mit Dateien geht es meist darum, Daten auf einen Webserver zu transferieren oder Daten auf einem solchen zu strukturieren. Damit sind Vorgänge wie Kopieren, Verschieben, Löschen, Up- und Download gemeint.
2.3.1
Dateien übertragen
Dateien können direkt über TYPO3 zum Webserver übertragen werden, ein FTP-Client ist dafür nicht notwendig. Zum Übertragen von Dateien wechseln Sie in den Dateiliste-Modus und bekommen dann eine Ordnerstruktur angezeigt. Diese Struk-
85
Sandini Bib
2 Arbeiten mit Inhalten
tur kann je nach Backend-Login unterschiedlich sein. Der Administrator kann verschiedene Dateifreigaben anlegen. Im extremsten Fall hat jeder Online-Redakteur seine eigene Dateifreigabe. Klicken Sie auf den Titel des Ordner, um sich dessen Inhalt anzeigen zu lassen. Wenn Sie auf das Ordner-Symbol klicken, öffnet sich das Kontextmenü. In diesem selektieren Sie den Punkt DATEI-UPLOAD. Im Hauptbereich des Backend können Sie dann über das Pulldown-Menü einstellen, wie viele Dateien Sie übertragen möchten. Bis zu zehn Dateien gleichzeitig sind möglich. Über die Schaltfläche DURCHSUCHEN können Sie dann die Datei auf Ihrem lokalen Computer selektieren, die übertragen werden soll.
Abbildung 2.56: Bis zu zehn Dateien können über das Dateiliste-Modul auf einmal übertragen werden Ist die Datei bereits auf dem Webserver vorhanden, und Sie möchten diese durch eine aktuellere Version überschreiben, müssen Sie das Häkchen ÜBERSCHREIBE EXISTIERENDE DATEIEN aktivieren. Ist das Häkchen nicht aktiv, benennt TYPO3 die Dateien um, die mit identischen Namen bereits vorliegen. Je nach Dateigröße und Internetverbindung kann die Übertragung etwas dauern.
2.3.2
Dateien löschen
Über das Kontextmenü der Dateien können Sie diese auch löschen. Dazu müssen Sie ins Dateiliste-Modul wechseln und in der Verzeichnisstruktur einen Ordner aufrufen. Im Hauptbereich können Sie dann das Kontextmenü der Datei aufrufen, indem Sie das Symbol der Datei anklicken. Wollen Sie mehrere Dateien im selben Verzeichnis löschen, erreichen Sie das Ziel mithilfe der numerischen Klemmbretter. Rufen Sie das Verzeichnis mit den zu löschenden Dateien über das Dateiliste-Modul auf und aktivieren Sie am Seitenende die Klemmbrett-Anzeige. Wenn Sie jetzt eines der numerischen Klemmbretter ausklappen, wer-
86
Sandini Bib
2.3 Arbeiten mit Dateien
den hinter jeder Datei kleine Kästchen angezeigt. Über diese Kästchen können Sie eine Mehrfachauswahl treffen. Über das Mülleimer-Symbol am Anfang der Liste über den Kästchen können Sie dann alle markierten Dateien gleichzeitig löschen.
Abbildung 2.57: Mehrere Dateien können über die numerischen Klemmbretter gelöscht werden Sie können auch komplette Verzeichnisse samt Inhalt löschen. Dazu benötigen Sie allerdings, wie bereits erwähnt, die Rechte zum rekursiven Löschen. Haben Sie diese Rechte nicht, muss der zu löschende Ordner vorher komplett geleert werden.
2.3.3
Dateien und Verzeichnisse umbenennen
Dateien und Verzeichnisse können über das jeweilige Kontextmenü umbenannt werden. Klicken Sie im Dateiliste-Modus auf das Icon des Verzeichnisses und selektieren Sie dann den Punkt UMBENENNEN. Dateien werden genauso umbenannt.
2.3.4
Dateien und Verzeichnisse verschieben oder kopieren
Ebenso können Sie Dateien und Verzeichnisse über das Kontextmenü des jeweiligen Objektes ausschneiden. Über das Kontextmenü des Zielordners können die Dateien und Verzeichnisse dann wieder eingefügt werden. Gleiches gilt auch für das Kopieren von Dateien und Verzeichnissen. Die zu kopierenden Inhalte dürfen dann allerdings nicht ausgeschnitten werden, sondern müssen kopiert werden.
87
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.58: Zuvor ausgeschnittene Dateien können über das Kontextmenü wieder in den Zielordner eingefügt werden Zum Kopieren von Verzeichnissen benötigen Sie spezielle Rechte. Verfügen Sie nicht über die entsprechenden Rechte, erhalten Sie eine Fehlermeldung beim Versuch, das Verzeichnis an beliebiger Stelle einzufügen. Die Rechte vergeben Sie, indem Sie die Einstellungen unter BENUTZER aufrufen. Im Bereich der erweiterten Funktionen können Sie das rekursive Löschen für Benutzer erlauben.
Abbildung 2.59: Dateien und Verzeichnisse können auch über das Klemmbrett kopiert und verschoben werden
88
Sandini Bib
2.4 Funktionalitäten
Um eine individuelle Auswahl zu kopieren oder zu verschieben, müssen Sie wieder eines der numerischen Klemmbretter verwenden. Rufen Sie dazu über das DateilisteModul das Verzeichnis mit den Quelldaten auf. Über KLEMMBRETT ANZEIGEN können Sie das Klemmbrett aktivieren, falls es noch nicht angezeigt wird. Jetzt müssen Sie eines der numerischen Klemmbretter ausklappen, sodass Sie die Kästchen hinter den Verzeichnissen und Dateien angezeigt bekommen. Treffen Sie Ihre Auswahl der zu kopierenden oder zu verschiebenden Dateien und Verzeichnisse. Über das kleine Icon am Anfang der Liste können Sie die Auswahl auf das Klemmbrett transferieren. Im Klemmbrett können Sie jetzt umschalten, ob die Objekte verschoben oder kopiert werden sollen. Werden die Objekte kopiert, wird das Symbol orange hinterlegt. Jetzt können Sie den Zielordner aufrufen und auf das EINFÜGEN-Symbol klicken, oder direkt über das Kontextmenü des Zielordners die Objekte einfügen.
2.4
Funktionalitäten
Außer den vielen Möglichkeiten Content, Seiten und Verzeichnisse zu bearbeiten, gibt es weitere interessante Hilfsmittel für die tägliche Arbeit mit Seiten und Inhalten. Diese wollen wir Ihnen im folgenden Abschnitt vorstellen.
2.4.1
Zeitsteuerung von Seiten und Inhalten
Die Zeitsteuerung ist eine der großen Stärken von TYPO3. Seiten und alle Inhaltselemente können durch Angabe einer Start- und Stoppzeit gesteuert werden. Das heißt, Sie legen einmal fest, in welchem Zeitfenster die Seite oder der Inhalt angezeigt werden soll. TYPO3 passt dynamisch und voll automatisch die Inhalte und Navigationsstrukturen entsprechend an. Die Steuerzeiten können jeweils am Seitenende in den ALLGEMEINEN OPTIONEN angegeben werden. Hier können Sie auch die Schnelleingabe verwenden, indem Sie +1 für das morgige Datum verwenden, oder +7 für das Datum in einer Woche. Als Zeit wird die aktuelle Zeit zum Zeitpunkt der Eingabe verwendet. Angezeigt wird aber nur das Datum.
Abbildung 2.60: Die Zeitsteuerung wird unter den Erweiterten Optionen der Seiten und Inhaltselemente vorgenommen
89
Sandini Bib
2 Arbeiten mit Inhalten
Die zeitgesteuerten Seiten werden im Seitenbaum mit gesondertem Icon angezeigt.
Abbildung 2.61: Dieses Icon bezeichnet Seiten, bei denen ein Stopp-Datum gesetzt ist, die aber zurzeit noch angezeigt werden
Abbildung 2.62: Dieses Icon bezeichnet Seiten, bei denen ein Start-Datum gesetzt ist, das noch in der Zukunft liegt, die Seite also noch nicht angezeigt wird Für Inhaltselemente gibt es ähnliche Icons. Das kleine Uhr-Symbol in den Icons symbolisiert, dass die Elemente Zeit gesteuert sind. Gelbe Symbole bedeuten, dass das Element im Frontend angezeigt wird. Graue Symbole bedeuten, dass das Element noch nicht im Frontend angezeigt wird.
2.4.2
Seitencache löschen
Wenn Sie den Cache einer einzelnen Seite löschen möchten, können Sie dies über das Liste-Modul machen. Rufen Sie das Liste-Modul auf und selektieren die gewünschte Seite im Seitenbaum. Über den Seiteninhalten finden Sie eine erste Leiste mit Schaltflächen. Über die Schaltfläche mit dem C-Symbol können Sie den Cache der aufgerufenen Seite löschen.
Abbildung 2.63: Den Cache einer einzelnen Seite löschen
2.4.3
Suchen und Finden im Backend
Sie können im Liste- und Seite-Modul die aufgerufene Seite durchsuchen, indem Sie den Suchbegriff am Seitenende eingeben und die Suche starten. Wenn Sie zusätzlich die Unterseiten durchsuchen möchten, können Sie die Ebene im Pulldown-Menü angeben, bis zu welcher die Seiten durchsucht werden sollen.
Abbildung 2.64: Die Suche im Backend wird im Anschluss der Inhaltselemente im Liste- und Seite-Modul angezeigt
90
Sandini Bib
2.4 Funktionalitäten
TYPO3 zeigt dann im Liste-Modul die Seiten und Inhaltselemente an, die den Suchbegriff beinhalten. Im Seite-Modul bekommen Sie nur die Inhaltselemente angezeigt, dafür aber mit einer aussagekräftigeren Vorschau. Wenn Sie eine globalere Suche nicht nur über Seiten und Inhalte ausführen möchten, können Sie das Tool DB Überprüfung verwenden. Dieses Tool durchsucht alle Tabellen, die im TCA Array definiert sind. Rufen Sie dazu im Pulldown-Menü den Punkt FULL SEARCH auf. Im zweiten Pulldown-Menü muss RAW SEARCHE IN ALL FIELDS eingestellt sein. Unter SEARCH OPTIONS können Sie dann den zu suchenden Begriff eingeben.
Abbildung 2.65: Über das Tool DB Überprüfen lassen sich auch Websitebenutzer finden
2.4.4
Seitenalias setzen
Ein Seitenalias wird anstelle der Seiten-ID verwendet, wenn TYPO3 Links generiert. Ein normaler Seitenaufruf in TYPO3 sieht wie folgt aus: http://www.meineDomain.de/index.php?id=99&type=0
Oder bei Aktivierung der Simulation suchmaschinenfreundlicher URLs: http://www.maineDomain.de/seitentitel.99.0.html
Wenn Sie nun einen Alias angeben, wird die in unserem Beispiel verwendete SeitenID 99 gegen den Alias ausgetauscht. Da sich Seiten auch über die jeweilige Seiten-ID allein aufrufen lassen, kann dann eine Seite auch über den Alias allein aufgerufen werden. So können dann Seiten auch wie folgt aufgerufen werden: http://www.meineDomain.de/index.php?id=alias
91
Sandini Bib
2 Arbeiten mit Inhalten
Oder bei Simulation suchmaschinenfreundlicher URLs: http://www.meineDomain.de/alias.html
Auf diese Weise lassen sich einprägsamere HTTP-Adressen generieren. Um einen solchen Alias setzen zu können, müssen Sie den Seiten-Header zur Bearbeitung öffnen. In der zweiten Optionspalette finden Sie das Feld für den Alias. Wenn die zweite Optionspalette nicht aktiviert ist, können Sie das ALIAS-Feld auch über die weiteren Optionen des Seitentitels aufrufen. In das ALIAS-Feld tragen Sie einen beliebigen Aliasnamen ein, der aber in der aktuellen TYPO3-Struktur originär sein muss. Jeder Alias kann nur einmal in einer Site verwendet werden.
Abbildung 2.66: Den Alias können Sie über die zweite Optionspalette des Seitentitels eingeben
2.4.5
Häufig wiederkehrende Inhalte bearbeiten
Häufig bearbeitete Seiteninhalte werden im Dok. Modul bzw. ab Version 3.8.0 im Dokumente-Modul angezeigt. Sollten Sie noch ein Inhaltselement zur Bearbeitung geöffnet haben, wird dieses sofort aufgerufen, wenn Sie in das Dokumente-Modul wechseln. Schließen Sie dann das Element einfach, und Sie erhalten eine Liste der zuletzt bearbeiteten Inhaltselemente mit Datum und Zeit der letzten Änderung. Klicken Sie auf das gewünschte Dokument, um es zur Bearbeitung zu öffnen. Wenn Sie das Dokument anschließend wieder schließen oder speichern und schließen, kommen Sie wieder zurück zur Liste. Die zuletzt bearbeiteten Seiten können Sie über das Aufgaben-Modul aufrufen. Im Aufgaben-Modul klappen Sie die Rubrik LETZTE SEITEN auf. Klicken Sie einfach auf die gewünschte Seite, die dann in der Spalten-Ansicht oder der Schnelleingabe geöffnet wird. Sie können aber auch die zuletzt bearbeiteten Datensätze über das Aufgaben-Modul öffnen. Da sich seit Version 3.8.0 die Darstellung der Datensätze geändert hat, empfiehlt es sich, die Datensätze statt über das Dokumente-Modul über das AufgabenModul aufzurufen.
92
Sandini Bib
2.4 Funktionalitäten
Abbildung 2.67: Über das Dokumente-Modul können Sie die zuletzt geänderten Inhaltselemente aufrufen
Abbildung 2.68: In den Aufgaben findet jeder Benutzer seine zuletzt bearbeiteten Seiten und kann auch die zuletzt bearbeiteten Datensätze aufrufen
93
Sandini Bib
2 Arbeiten mit Inhalten
2.4.6
Notizen anlegen
Jeder Backend-Benutzer kann über das Aufgaben-Modul eine persönliche Notiz anlegen. Diese Notiz ist nur für den jeweiligen Benutzer einsichtig und kann jederzeit über das Aufgaben-Modul bearbeitet und aufgerufen werden.
Abbildung 2.69: Das digitale TYPO3 Post-it
2.4.7
CSV-Listen exportieren
Um Datensätze in eine CSV-Datei zu exportieren, müssen Sie zunächst in das ListeModul wechseln. Klicken Sie dann auf den Datensatz TYP, den Sie exportieren möchten, um die ERWEITERTE ANSICHT aufzurufen. In der erweiterten Ansicht können Sie dann die Felder selektieren, die Sie exportieren möchten. Für eine Mehrfachauswahl halten Sie die (Strg)-Taste gedrückt und selektieren die einzelnen Felder. Nachdem Sie die Felder gesetzt haben, wird die Liste mit den entsprechenden Feldern neu generiert. Oben rechts finden Sie die Schaltfläche zum Speichern der CSVDatei. Die exportierte CSV-Datei lässt sich dann in andere Programme wie zum Beispiel in die Tabellenkalkulation Excel importieren, wo sie dann weiterverarbeitet werden kann. TYPO3 zeigt standardmäßig einhundert Datensätze im Liste Modul an. Die CSV-Funktion erfasst auch nur genau diese angezeigten Datensätze. Sollen mehrere Datensätze exportiert werden, müssen Sie am Seitenende über den Wert hinter DATENSÄTZE ANZEIGEN die gewünschte Anzahl von Datensätzen einstellen.
2.4.8
Vorschau von Seiten und Inhalten
Backend-Benutzer können Seiten und Inhalte, die noch nicht freigeschaltet sind, im Frontend in einer Voransicht öffnen. Die einfachste Variante ist der Aufruf der versteckten Seite aus dem Backend.
94
Sandini Bib
2.4 Funktionalitäten
Abbildung 2.70: Datensätze können aus dem Liste-Modul exportiert werden, wobei die zu exportierenden Felder individuell gesetzt werden können
Abbildung 2.71: Versteckte Seiten werden mit dem rot hinterlegten PREVIEW-Hinweis im Frontend gekennzeichnet Wenn Sie versteckte Inhaltselemente oder Datensätze in der Vorschau angezeigt bekommen möchten, müssen Sie dies über das Admin Panel aktivieren. Das Admin Panel wird im Frontend unter der eigentlichen Seite angezeigt. Sei müssen zunächst das Admin Panel und dann die Vorschau aufklappen. Dort können Sie dann die Anzeige versteckter Datensätze aktivieren.
95
Sandini Bib
2 Arbeiten mit Inhalten
Abbildung 2.72: Versteckte Inhalte können über das Admin Panel in der Vorschau aktiviert werden Wenn Sie zeitgesteuerte Seiten oder Inhalte verwenden, können Sie beliebige Zeitpunkte über das Admin Panel simulieren und so die Auswirkungen der Zeitsteuerung überprüfen. Im Admin Panel können Sie auch die Schnelleingabe verwenden und z.B. mit +7 die aktuelle Zeit der nächsten Woche simulieren. TYPO3 berechnet automatisch das Datum und trägt die aktuelle Zeit ein. Damit die Eingabe wirksam wird, müssen Sie die Änderung einmal aktualisieren und schon bekommen Sie die Website angezeigt, wie sie in der nächsten Woche aussehen würde.
Abbildung 2.73: Durch die Simulation vom Zeitpunkt über das Admin Panel können zeitgesteuerte Seiten und Inhalte begutachtet werden Wenn Sie zugriffsbeschränkte Seiten angelegt haben, kann selbst der Admin diese Seite nicht unmittelbar aufrufen. Um Backend-Benutzern dies dennoch zu gewähren, können diese über das Admin Panel Benutzergruppen simulieren. Alle angelegten Website-Benutzergruppen stehen im Pulldown-Menü dem Backend-Benutzer zur Verfügung. Sobald eine Benutzergruppe ausgewählt ist, verhält sich die Website wie bei einem Benutzer, der sich auf der Website angemeldet hat.
96
Sandini Bib
3
Administrationsoberflächen konfigurieren
3.1
Benutzer in TYPO3
3.1.1
Benutzer und Benutzergruppen erzeugen
Backend-Benutzer und Benutzergruppen können Sie nur auf der Root-Seite des Seitenbaums über das Kontextmenü der Root-Seite als neue Datensätze anlegen. Im Hauptbereich erhalten Sie dann eine Übersicht aller Datensätze, die angelegt werden können. Diese Liste variiert stark in Abhängigkeit der von Ihnen installierten Extensions.
Abbildung 3.1: werden
Backend-Benutzer und Gruppen können nur auf der Root-Seite angelegt
Alternativ können Sie im Liste-Modul neue Benutzer und Benutzergruppen anlegen. Aber auch hier gilt, dass Benutzer und Benutzergruppen nur auf der Root-Seite angelegt werden können.
Sandini Bib
3 Administrationsoberflächen konfigurieren
Wenn Sie den Datensatz-Benutzer ausgewählt haben, erscheint das Formular für die Backend-Benutzer. Hier müssen Sie einen Usernamen und ein Passwort vergeben. Auf dem gleichen Weg legen Sie auch neue Benutzergruppen an, denen dann einzelne Benutzer zugewiesen werden können. Über die Benutzergruppen werden später die Rechte zur Verwaltung der Website gesetzt.
3.1.2
Zugriff auf Module freigeben
Um Module in den Benutzergruppen freigeben zu können, müssen Sie zuerst das Häkchen bei INCLUDE ACCESS LISTS setzen. Die Module in TYPO3, die Sie den Benutzern zur Verfügung stellen können, sind in vier Gruppen geordnet. Die Modulgruppe TOOLS steht nur den Administratoren zur Verfügung, die Gruppe HILFE wird allen Backend-Benutzern angezeigt. Die Module der Gruppe WEB ermöglicht Benutzern den Zugriff auf Seiten und Seiteninhalte über die Baumstruktur. Über die Gruppe DATEI können Sie den Benutzern Zugriff auf das Dateisystem auf dem Webserver einräumen. DOKUMENTE zeigt nur die zuletzt bearbeiteten Datensätze an. Über die Gruppe BENUTZER gelangen die Backend-Benutzer zu ihren Aufgaben und damit zum Taskcenter. Hier können Sie Ihre eigenen Einstellungen anpassen. Um im TYPO3-Backend arbeiten zu können, sollten wenigstens die Module SEITE, ANZEIGEN und LISTE aus der Gruppe WEB freigegeben werden. Wenn die Benutzer Zugriff auf das Dateisystem benötigen, sollten alle Module in der Gruppe DATEI freigegeben werden. Alle anderen Module sind für die Arbeit im VMS nicht zwingend notwendig, können aber sehr hilfreich sein.
Abbildung 3.2: Je nach Anforderung können auch weniger Module freigegeben werden
98
Sandini Bib
3.1 Benutzer in TYPO3
3.1.3
Benutzern Zugang zum Dateisystem erlauben
Um Backend-Benutzern Zugriff zum Dateisystem auf dem Webserver einzuräumen, müssen die Benutzer zuerst Zugriff auf das Dateiliste-Modul haben. Diese Rechte setzen Sie über die Benutzergruppe, die dem Benutzer zugewiesen ist.
Abbildung 3.3: Ohne Zugriff auf das Dateiliste-Modul können die Benutzer auch nicht auf das Dateisystem zugreifen Jetzt steht dem Benutzer das Modul zum Zugriff auf das Dateisystem im Backend zur Verfügung, aber es werden noch keine Ordner angezeigt. Das liegt daran, dass noch keine Dateifreigabe zugewiesen wurde. Legen Sie dazu auf der Root-Seite einen neuen Datensatz vom Typ Dateifreigabe an. Vergeben Sie einen Namen und geben Sie den Pfad des Ordners auf dem Server an, der freigegeben werden soll. Liegt der Ordner innerhalb des Ordners fileadmin des TYPO3-Projektes, verwenden Sie als BASE RELATIV und geben ausgehend vom Verzeichnis fileadmin den komplette Pfad an. Das Verzeichnis user_upload existiert in den meisten Fällen bereits im Verzeichnis fileadmin. In diesem Beispiel haben wir noch ein Unterverzeichnis angelegt, das über die Dateifreigabe dem Benutzer zugewiesen werden soll.
Abbildung 3.4: Verwenden Sie die relative Dateifreigabe und geben den Pfad zum gewünschten Verzeichnis an
99
Sandini Bib
3 Administrationsoberflächen konfigurieren
Diese Dateifreigabe müssen Sie jetzt noch dem jeweiligen Benutzer selber oder besser der Benutzergruppe, der der Benutzer angehört, zuweisen. Besonders wenn mehrere Benutzer verwaltet werden sollen, erleichtert die strukturierte Zuweisung der Dateifreigaben über Benutzergruppen die Arbeit beim Verwalten der Backend-Benutzer in TYPO3. Sollen die Dateifreigaben über die Benutzergruppen zugewiesen werden, muss das Mounten von Dateifreigaben beim Benutzer aktiviert sein.
3.1.4
Seiteneinstiegspunkt setzen
Jedem Backend-Benutzer müssen ein oder mehrere Einstiegspunkte zugewiesen werden. Der Benutzer kann dann, wenn die entsprechenden Seitenzugriffsrechte vergeben sind, auf die Seite als Einstiegspunkt und alle Unterseiten zugreifen. Die Einstiegspunkte können für jeden Benutzer separat gesetzt werden, besser arbeiten Sie aber über die Benutzergruppen. Der Benutzer bekommt dann in der Baumstruktur für jeden Einstiegspunkt eine Seite angezeigt, die ausgeklappt werden kann, sofern Unterseiten vorhanden sind. Ein solcher Einstiegspunkt wird Datenbank Mount oder kurz DB Mount genannt. Wenn Sie die DB Mounts über die Gruppen zuweisen möchten, dann muss das Erben von Mounts bei den Benutzern aktiviert sein, was zu empfehlen ist. Besonders wenn mehrere Benutzer verwaltet werden sollen, erleichtert das die Arbeit beim Verwalten der Backend-Benutzer.
Abbildung 3.5: Sie können einen oder mehrere DB Mounts zuweisen Damit der Benutzer die Seiten jetzt auch im Backend angezeigt bekommt bzw. dies auch bearbeiten kann, müssen Sie über das Zugriff-Modul entsprechende Rechte für die Benutzergruppe des Benutzers setzen. Der Benutzer benötigt ebenfalls eines der Web-Module, um den Seitenbaum aufrufen zu können. Sind alle Rechte und Module über die Benutzergruppe korrekt gesetzt, werden dem Benutzer die einzelnen DB Mounts als separate Seitenbäume im Backend angezeigt.
3.1.5
Seitenrechte setzen
Rechte an Seiten werden über das Zugriff-Modul gesetzt. Wenn Sie sich im ZugriffModul befinden, können Sie im Seitenbaum eine Seite selektieren, deren Rechte Sie anpassen möchten. Im Hauptbereich werden dann die selektierten Seiten und die Unterseiten in der Benutzer-Übersichts-Ansicht angezeigt. Klicken Sie in der Übersicht auf eines der Stift-Symbole, um die Rechte der entsprechenden Seite anzupassen.
100
Sandini Bib
3.1 Benutzer in TYPO3
Abbildung 3.6: Eines der Web-Module muss zugewiesen werden, damit der Benutzer die Seitenstruktur aufrufen kann
Abbildung 3.7: Wenn alle Rechte gesetzt sind, werden die DB Mounts als separate Seitenbäume angezeigt In der Rechte-Bearbeiten-Ansicht können Sie dann detailliert die Rechte für die Seite anpassen. Sie können einen Besitzer und eine Gruppe benennen, für die dann individuelle Rechte gesetzt werden. Als drittes gibt es noch die fest vorgegebene Gruppe ALLE, der maximal das Recht zum Zeigen von Seiten zugewiesen werden sollte. Unter der Rechte-Tabelle können Sie die vorgenommenen Einstellungen auch auf Unterseiten anwenden.
101
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.8: Rechte können individuell für den Besitzer einer Seite, für eine beliebige Benutzergruppe und für alle Backend-Benutzer gesetzt werden Um sich eine Übersicht über die Rechte einer Seiten zu verschaffen, können Sie die Ansicht im Zugriff-Modul auf RECHTE umschalten. Sie erhalten dann eine Auflistung der selektierten Seiten und deren Unterseiten mit den Rechten für den Besitzer, der Benutzergruppe und aller Backend-Benutzer sowie den Namen des Besitzers und der Benutzergruppe. Über TIEFE können Sie einstellen, über wie viele Ebenen diese Übersicht erweitert werden soll.
Abbildung 3.9: Verschaffen Sie sich eine Übersicht über die Rechtevergabe Ihrer Seiten mit der Rechte-Ansicht im Zugriff-Modul
102
Sandini Bib
3.1 Benutzer in TYPO3
3.1.6
Bearbeitungsrechte für Benutzer setzen
Backend-Benutzern müssen Rechte auf die einzelnen Felder der Datensätze und Inhaltstypen eingeräumt werden. Diese Rechte müssen Sie über eine Benutzergruppe zuweisen. Als Erstes müssen Sie Ihren Benutzern die Tabellen zuweisen, die verändert werden dürfen. Setzen Sie dazu unter TABELS (MODIFY) die Tabellen, die die Benutzergruppe modifizieren darf. Eine gängige Einstellung ist, dass Sie SEITE und SEITENINHALT zuweisen. Um eine Mehrfachauswahl zu treffen, halten Sie die (Strg)-Taste gedrückt, während Sie Ihre Auswahl tätigen.
Abbildung 3.10: Damit Backend-Benutzer die Inhalte der Seiten bearbeiten können, müssen Seiten und Seiteninhalte zum Modifizieren über die Benutzergruppe freigegeben werden Sollen die Benutzer neue Seiten anlegen können, dann muss außerdem mindestens ein Seitentyp zugewiesen werden, den die Benutzer setzen dürfen. Dies geben Sie im folgenden Feld unter PAGE TYPES an.
Abbildung 3.11: Sie sehen eine gängige Einstellung für die Zuweisung der Seitentypen
103
Sandini Bib
3 Administrationsoberflächen konfigurieren
Zu guter Letzt müssen Sie jetzt noch die einzelnen Felder der zuvor freigegebenen Tabellen setzen. Wenn Sie keine weiteren Felder freigeben, dürfen die Benutzer zwar die Inhalte anlegen, es stehen aber nur die wichtigsten Felder zur Verfügung. Bei den Seiten sind das nur der Seitentitel und der Alias. Auch bei den Seiteninhalten stehen nur, je nach Inhaltselement die wichtigsten Felder zur Verfügung. Wenn die Benutzer zum Beispiel die Zeitsteuerung nutzen sollen, dann müssen diese Felder im Bereich ALLOWED EXCLUDEFIELDS freigegeben werden.
Abbildung 3.12: Viele Felder müssen den Benutzern erst noch gesondert freigeschaltet werden
104
Sandini Bib
3.2 Allgemeine Einstellungen
Hinweis Sie sollten den Benutzern nur die wirklich benötigten Felder freischalten, um die Eingabemasken so übersichtlich wie möglich zu halten.
3.2
Allgemeine Einstellungen
3.2.1
Bildunterschriften für jedes Bild
Bildern können Bildunterschriften zugewiesen werden. Wenn Sie jetzt in einem Inhaltselement mehrere Bilder zugewiesen haben, können Sie für jedes Bild eine separate Bildunterschrift angeben. Trennen Sie die einzelnen Bildunterschriften durch Zeilenumbrüche. Wenn Sie sich jetzt die Seite anzeigen lassen, werden in der Regel die Bildunterschriften nicht unter den einzelnen Bildern zugewiesen. Um die Bildunterschriften jeweils unter dem Bild anzeigen zu lassen, muss die Funktion captionSplit aktiviert werden.
Abbildung 3.13: Links die Bilder ohne captionSplit und rechts mit, dadurch sind die Bildunterschriften den einzelnen Bildern zugeordnet Sie können das Caption Splitting aktivieren, indem Sie folgendes TypoScript in das CONSTANTS-Feld Ihres Templates schreiben: styles.content.imgtext.captionSplit = 1
105
Sandini Bib
3 Administrationsoberflächen konfigurieren
Sie können den Wert aber auch über den TypoScript Object Browser im TemplateModul setzen. Wechsel Sie dazu in das Template-Modul und rufen im Menü oben rechts den TypoScript Object Browser auf. Hier wählen Sie im Menü BROWSE CONSTANTS aus. Im OBJECT TREE müssen Sie jetzt STYLES ausklappen, dann CONTENT und danach noch IMGTEXT. Im Objekt IMGTEXT klicken Sie auf CAPTIONSPLIT. Unter EDIT OBJECT/ PROPERTY VALUE können Sie nun das Caption Splitting aktivieren, indem Sie eine 1 eintragen. Anschließend müssen Sie die Änderung durch einen Klick auf UPDATE aktualisieren.
Abbildung 3.14: Der TypoScript Object Browser schreibt das Objekt mit korrektem Pfad in das Constants-Feld Ihres Templates – so vermeiden Sie Tippfehler
106
Sandini Bib
3.2 Allgemeine Einstellungen
3.2.2
Erstellen individueller Links für Bilder
Bilder in den Inhaltselementen BILD und TEXT MIT BILD können über das Feld VERWEIS in der zweiten Optionspalette verlinkt werden. Wenn Sie mehrere Bilder über ein Inhaltselement eingefügt haben, werden alle Bilder mit einem identischen Ziel verknüpft. Um nun einen separaten Link für jedes Bild setzen zu können, muss der Wert der Eigenschaft comment_CSL-LinkList verändert werden. Sie können direkt in das CONSTANTS-Feld Ihres Templates folgendes TypoScript schreiben: styles.content.imgtext.comment_CSL-LinkList =
Besser ist es aber, den Wert über den TypoScript Object Browser im Template-Modul zu setzen. Verfahren Sie dabei wie bereits im Tipp Bildunterschriften für jedes Bild beschrieben. Die Eigenschaft findet Sie auch im Objekt styles.content.imagetext. Klicken Sie in dem Objekt auf die Eigenschaft COMMENT_CSL-LINKLIST und entfernen Sie die Raute im VALUE-Feld.
Abbildung 3.15: Bei der Eigenschaft comment_CSL-LinkList darf kein Wert eingetragen sein Wenn das Template angepasst wurde, können Sie jedem Bild einen eigenen Link zuweisen. Die Links werden durch Kommata getrennt. Das erste Bild wird mit dem ersten Link verknüpft und so weiter. Für externe Links geben Sie die komplette URL an. Interne Verweise können Sie setzen, indem Sie einfach die UID der Zielseite angeben, oder Sie geben eine E-Mail-Adresse an. TYPO3 erkennt die unterschiedlichen Verknüpfungen und generiert die korrekten Links.
107
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.16: Sie können Seiten-IDs angeben für interne Verknüpfungen, für komplette URLs und auch für E-Mail-Adressen
3.2.3
Neu erstellte Seiten automatisch definieren
Wenn Sie neue Seiten anlegen, werden diese mit einigen Default-Werten angelegt. So wird die Seite standardmäßig immer als versteckt und vom Typ Standard angelegt. Wenn Sie diese Vorgaben modifizieren möchten, können Sie dies über das TSCONFIGFeld der Backend-Benutzer oder Benutzergruppen realisieren. Dazu müssen Sie zunächst wissen, wie die Felder in der Datenbank benannt sind, deren Vorgabewerte Sie ändern möchten. Das erfahren Sie am einfachsten, wenn Sie den phpMyAdmin über das TYPO3-Backend aufrufen und die Tabelle pages selektieren. Feldbezeichnungen in der Tabelle pages
Auswirkungen
Doktype
Legt den Seitentypen fest 1 = Standard 2 = Erweitert 3 = Externe URL 4 = Shortcut 5 = Nicht im Menü 6 = Backend-Benutzer Bereich 7 = Mount Seite 199 = Abstand 254 = SysOrdner 255 = Papierkorb
Hidden
Versteckt Seiten 1 = versteckt 0 = sichtbar
no_cache
Caching Verhalten der Seite 1 = Seiten werden gecached 0 = Seiten werden bei jedem Aufruf neu aus der Datenbank generiert
Tabelle 3.1: Einige interessante Datenbankfelder aus der Tabelle pages
108
Sandini Bib
3.2 Allgemeine Einstellungen
Feldbezeichnungen in der Tabelle pages
Auswirkungen
fe_group
FE-Benutzergruppe mit der angegebenen ID wird bei Zugriff unter den ALLGEMEINEN OPTIONEN eingetragen.
Target
Das Ziel der Seite kann besonders interessant sein, bei Seiten mit Frames.
cache_timeout
Zeit in Sekunden nach der der Cache verfällt
no_search
Schließt Seite von der Suche aus no_searche = 1 Seite wird nicht von der Suche berücksichtigt no_searche = 0 Seite wird von der Suche berücksichtigt
Author
Name des Autors
author_email
E-Mail des Autors
nav_hide
Versteckt Seite im Menü nav_hide = 1 Seite ist versteckt Nav_hide = 0 Seite wird im Menü angezeigt
Tabelle 3.1: Einige interessante Datenbankfelder aus der Tabelle pages (Forts.) Über das TSCONFIG-Feld können Sie nun alle Vorgabewerte modifizieren. Über das Objekt TCAdefaults gefolgt von der Tabelle, also pages, und dem Tabellenfeld, können Sie die Vorgabewerte beliebig anpassen. TCAdefaults.pages { doktype = 2 hidden = 0 fe_group = 1 author = Maik Caro }
Angaben zum Autor sollten natürlich immer im TSCONFIG-Feld des Backend-Benutzers stehen. Alle anderen Angaben können auch über Benutzergruppen zugewiesen werden. In unserem Beispiel würden jetzt alle neuen Seiten mit dem Typ ERWEITERT, NICHT ZUGRIFFS BESCHRÄNKT für die FE Benutzergruppe mit der ID=1 erstellt und als Autor ist Maik Caro voreingetragen.
VERSTECKT,
Auf diese Weise können Sie auch Vorgaben machen, die der Backend-Benutzer nicht unmittelbar sieht. So könnten Sie zum Beispiel Vorgaben erzeugen, die nur bei Seiten vom Typ ERWEITERT angezeigt werden, obwohl eine Seite vom Typ STANDARD angelegt wird.
109
Sandini Bib
3 Administrationsoberflächen konfigurieren
3.2.4
Die Toolbar vom RTE modifizieren
Die Toolbar im RTE (Rich Text Editor) ist die Leiste mit den Bearbeitungswerkzeugen. Jedes diese Bearbeitungswerkzeuge kann separat für jedes Eingabefeld mit einem Rich Text Editor eingestellt werden.
Abbildung 3.17: Die Werkzeugleiste des Rich Text Editors erweitert mit den in der Tabelle beschriebenen Werkzeugen Diese Einstellung müssen Sie über das TSCONFIG-Feld einer Seite vornehmen. Sie können die Vorgaben um einzelne Icons erweitern oder auch Icons entfernen. Die entsprechenden Eigenschaften lauten SHOWBUTTONS und HIDEBUTTONS. Die Zuweisung erfolgt über RTE.config.[table].[field].Eigenschaft, wobei [table] die Datenbank-Tabelle ist und [field] das Feld der Tabelle. Das folgende Beispiel ergänzt den Rich Text Editor im Text-Feld der Seiteninhaltselemente um das Tabellen-Icon. RTE.config.tt_content.bodytext.showButtons = table
Das folgende TypoScript deaktiviert das Tabellen-Icon im Text-Feld der News: RTE.config.tt_news.bodytext.hideButtons = table
Diese Einstellungen des Rich Text Editors werden über das TSconfig der Seiten vorgenommen. Somit können Sie für Seiten oder Seitenzweige auch unterschiedliche Konfigurationen der Rich Text Editor-Toolbar einstellen. Code
Beschreibung
cut
Ausschneiden
copy
Kopieren
paste
Einfügen
formatblock
Absatzart
class
Zeichenart
fontstyle
Schriftart
fontsize
Schriftgröße
Icon
Tabelle 3.2: Die Icons, die im Rich Text Editor zur Verfügung stehen
110
Sandini Bib
3.2 Allgemeine Einstellungen
Code
Beschreibung
textcolor
Schriftfarbe
bold
Fett
italic
Kursiv
underline
Unterstrichen
left
Linksbündig
center
Zentriert
right
Rechtsbündig
orderedlist
Nummerierung
unorderedlist
Aufzählungszeichen
outdent
Einzug verkleinern
indent
Einzug vergrößern
link
Link einfügen
table
Tabelle einfügen
bgcolor
Hintergrundfarbe
image
Bild einfügen
emoticon
Symbol einfügen
line
Linie einfügen
user
Füge Benutzerelemente ein
Icon
Tabelle 3.2: Die Icons, die im Rich Text Editor zur Verfügung stehen (Forts.)
3.2.5
Login-Interfaces
Das Backend-Login ruft nach erfolgreichem Anmelden das Backend-Interface auf. Benutzer, die aber überwiegend im Frontend arbeiten, müssen um dorthin zu gelangen erst eine Seite aufrufen.
111
Sandini Bib
3 Administrationsoberflächen konfigurieren
Im Install Tool ist es möglich, neben dem Backend-Interface auch das Frontend-Interface beim Login anzubieten, wohin der Benutzer nach dem Login weitergeleitet wird. Der Benutzer erhält dann beim Aufruf des Login ein Pulldown-Menü, in dem er das Interface selektieren kann.
Abbildung 3.18: Das Login, erweitert um das Frontend-Interface Um diese Auswahl zu aktivieren, müssen Sie das Tool Installation im Backend aufrufen. Im Install Tool rufen Sie dann den Punkt vier ALL CONFIGURATION auf. Im Abschnitt BACKEND CONFIGURATION (BE:) befindet sich die Eigenschaft [interfaces]. Geben Sie die gewünschten Interfaces an. Das erstgenannte ist das Standard-Interface. Sie können auch nur das Frontend-Interface eingeben, dann werden alle Backend-Benutzer immer nach dem Login auf das Frontend weitergeleitet.
Abbildung 3.19: Um das Auswahlmenü beim Login zu aktivieren, müssen beide Interfaces angegeben werden
3.2.6
Session-Timeout heraufsetzen
Ist ein Benutzer im Backend angemeldet, verfällt dessen Session nach einer Stunde. Das hat zur Folge, dass Sie und alle anderen TYPO3-Backend-Benutzer sich jede Stunde neu anmelden müssen. Um Benutzern das ständige Neuanmelden zu ersparen, können Sie die Verfallszeit der Session im Installation-Modul heraufsetzen.
112
Sandini Bib
3.3 Arbeiten im Backend
Wechseln Sie dazu in das Modul Installation und rufen dann den Punkt vier ALL CONFIGURATION auf. Etwa in der Seitenmitte unter $TYPO3_CONF_VARS["BE"] finden Sie die Variable [sessionTimeout]. Geben Sie hier eine Zeit in Sekunden an, nach der die Session verfallen soll.
Abbildung 3.20: Die Backend-Benutzer Session verfällt standardmäßig nach einer Stunde, diese Zeitspanne kann im Install Tool angepasst werden
3.3
Arbeiten im Backend
3.3.1
Die Navigationsframes im Backend anpassbar machen
Wenn Sie lange Seitentitel benutzen, reicht der Navigationsframe oft nicht aus, um diese langen Seitentitel darzustellen. Der Navigationsframe ist normalerweise 245 Pixel breit. Bei Inhalten, die breiter sind, erscheint dann ein Scrollbalken. Mit einer kleinen Zeile TypoScript können Sie den Frame anpassbar machen. Dieses TypoScript müssen Sie in das TSCONFIG-Feld eines Backend-Benutzers oder in eine Seiten Benutzergruppen schreiben. setup.override.navFrameResizable = 1
Eine weitere interessante Eigenschaft in diesem Zusammenhang ist die Eigenschaft navFrameWidth. Wie bereits erwähnt, ist die Breite des Frames mit 245 Pixeln vorgegeben. Mit dieser Eigenschaft können Sie die Breite auf einen beliebigen Wert einstellen. setup.override.navFrameWidth = 180
3.3.2
Shortcut-Frame aktivieren für Backend-Benutzer
Am Ende jeder Seite im Backend wird das Icon zum Erzeugen eines Verweises auf diese Seite angezeigt. Die Verweise werden in einem separaten Frame am unteren Rand des Backend angezeigt. Verfügt der Backend-Benutzer nicht über ausreichend Rechte, werden weder das Icon noch der Frame zum Verwalten der Verweise angezeigt. Um den Backend-Benutzern die notwendigen Rechte einzuräumen, müssen Sie den shortcutFrame über das Objekt options aktivieren.
113
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.21: Lassen Sie die Backend-Benutzer selber bestimmen, wie breit der Navigationsframe sein soll
Abbildung 3.22: Das Shortcut-Icon befindet sich am Ende jeder Seite im Backend Dazu rufen Sie einen Backend-Benutzer oder eine seiner Benutzergruppen auf und fügen das folgende TypoScript in das TSCONFIG-Feld ein: options.shortcutFrame = 1
Jetzt wird dem Benutzer den Frame angezeigt, in dem die Verweise verwaltet werden können, und das Icon zum Erzeugen der Verweise wird am Ende jeder Seite im Backend sichtbar.
Abbildung 3.23: Der Shortcut-Frame mit einem Verweis
3.3.3
Shortcuts zum Bearbeiten von Inhalten
Um Shortcuts anlegen zu können, muss der Benutzer Rechte über den ShortcutFrame haben. Wie diese Rechte gesetzt werden, wurde bereits oben beschrieben.
114
Sandini Bib
3.3 Arbeiten im Backend
Verfügt der Benutzer über die Rechte, wird am Ende einer jeden Seite im Backend das Shortcut-Icon angezeigt. Öffnen Sie ein beliebiges Inhaltselement und klicken auf das Shortcut-Icon. Es öffnet sich ein Hinweis, den Sie zum Anlegen des Verweises bestätigen müssen. Im Shortcut-Frame erscheint dann der Shortcut. Aktivieren Sie das BEARBEITEN-Kästchen und klicken auf das Icon, um den Shortcut anzupassen. Sie können einen Namen vergeben und den Shortcut einer der vier Gruppen zuordnen. Die Shortcuts können dann über die Icons aufgerufen werden oder über das Pulldown-Menü, in dem die Bezeichnung des Shortcuts angezeigt wird.
Abbildung 3.24: Die drei Schritte: den Shortcut zur Bearbeitung öffnen, den Shortcut bearbeiten und speichern und den Shortcut über das Pulldown-Menü aufrufen Diese Shortcuts kann jeder Backend-Benutzer für sich separat setzen. Wie der Administrator einen Shortcut anlegt und diesen anderen Benutzern zuweisen kann, erfahren Sie in einem der folgenden Tipps.
3.3.4
Shortcuts zur Bearbeitung von Dateien
Shortcuts können auch auf Dateien verweisen. Beim Entwickeln von Templates kann der Administrator sich zum Beispiel die Datei mit den Stylesheets als Shortcut anlegen und spart sich so den ständigen Umweg über das Dateiliste-Modul. Sie müssen einmal die gewünschte Datei über das Dateiliste-Modul öffnen und dann das Shortcut-Icon am Seitenende klicken. Über den Shortcut-Frame kann nun mit einem einzigen Klick eine Datei zur Bearbeitung geöffnet werden.
3.3.5
Feste Shortcuts für Benutzer festlegen
Als Administrator können Sie Shortcuts festlegen und diese Backend-Benutzern über deren Benutzergruppen fest einrichten. Wie Shortcuts angelegt werden, wurde bereits oben beschrieben.
115
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.25: Die CSS-Datei kann von beliebiger Stelle im Backend mit einem einfachen Klick zur Bearbeitung geöffnet werden Wir haben einen Shortcut angelegt, über den man zum Formular für neue News gelangt. Diesen Shortcut wollen wir jetzt bearbeiten. Dazu setzen Sie das Häkchen BEARBEITEN und selektieren den gewünschten Shortcut. Vergeben Sie einen Namen und weisen dem Shortcut eine der Gruppen eins bis vier zu. Wenn Sie die Änderungen speichern, werden Sie sehen, dass vor dem Icon des Shortcuts die Nummer der selektierten Gruppe erscheint. Ist keine Gruppe selektiert, steht eine Null vor dem Icon.
Abbildung 3.26: Der Shortcut muss einer Gruppe zugewiesen werden, um den Shortcut anderen Benutzern zuordnen zu können Sie werden außerdem feststellen, dass Shortcuts, die einer globalen Gruppe zugeordnet sind, nicht mehr gelöscht werden können. Der Shortcut kann erst dann wieder gelöscht werden, wenn die globale Gruppe entfernt wird, was nur dem Administrator erlaubt ist. Damit auch andere Backend-Benutzer diesen Shortcut aufrufen können, öffnen Sie den Backend-Benutzer oder eine Benutzergruppe. Im Feld TSCONFIG muss jetzt die globale Gruppe der Shortcuts freigegeben werden. Öffnen Sie die TSCONFIG QUICKREFERENCE über das Icon rechts neben dem TSCONFIG-Feld. Unter [options] finden Sie die SHORTCUTGROUPS. Rechts finden Sie ein Beispiel, wie die Gruppen zugewiesen werden. Außerdem sollten Sie den Shortcut-Frame mit der entsprechenden Eigenschaft aktivieren, damit der Benutzer auch den Frame mit den Shortcuts angezeigt bekommt.
116
Sandini Bib
3.3 Arbeiten im Backend
Abbildung 3.27: Setzen Sie die Eigenschaften über die TSconfig QuickReference Wenn Sie die beiden Eigenschaften zur Liste hinzugefügt haben, scrollen Sie an das Ende der QUICKREFERENCE. Da es sich um Eigenschaften des options-Objekts handelt, müssen die Eigenschaften in dem Objekt stehen. Klicken Sie auf WRAP unterhalb des Ergebnisfeldes, und das übergeordnete Objekt wird korrekt eingefügt. Jetzt ist noch ein wenig Handarbeit gefordert, um die gewünschten Gruppen freizuschalten. Das fertige TypoScript im TSCONFIG-Feld sollte dann in etwa wie folgt aussehen: options { shortcutGroups { 1=1 } shortcutFrame=1 }
Wenn Sie jetzt einen Backend-Benutzer ausprobieren, dem das TypoScript im TSCONFIG-Feld zugewiesen wurde, dann sollte der Shortcut erscheinen. Der Benutzer kann den Shortcut weder löschen noch bearbeiten.
117
Sandini Bib
3 Administrationsoberflächen konfigurieren
Achtung Wenn Sie einen Shortcut anlegen und den Benutzern zuweisen, dann sollten Sie immer darauf achten, dass der Benutzer auch über entsprechende Rechte verfügt, diesen Shortcut ausführen zu können. Verweist der Shortcut beispielsweise in ein Verzeichnis, muss der Benutzer auch Zugriffsrechte zum Dateiliste-Modul besitzen und über seine Dateifreigabe auf das Verzeichnis zugreifen können.
3.3.6
Befehle zum Bearbeiten von Elementen anlegen
Um Befehle anlegen zu können, ist die Erweiterung sys_action notwendig. Die Erweiterung sys_action installieren Sie über den Ext Manager. Die Erweiterung finden Sie im Bereich BACKEND MODULES. Wenn die Erweiterung installiert ist, müssen Sie in das Liste-Modul wechseln und die Root-Seite aufrufen. Auf der Root-Seite legen Sie einen neuen Datensatz Befehl an. Den Typ müssen Sie auf EDIT RECORD einstellen. Sobald Sie den Typ geändert haben, wird sich das Formular ändern. Geben Sie jetzt einen Titel für die Aktion an. Unter RECORD TO EDIT wählen Sie die Datensätze aus, die zur Bearbeitung geöffnet werden sollen. Damit der Befehl auch anderen Backend-Benutzern zur Verfügung steht, muss unter ASSIGN ACTION TO GROUPS: eine Benutzergruppe zugewiesen werden. Alle Mitglieder dieser Gruppe können dann auch diesen Befehl ausführen, sofern sie Zugriff auf das Modul Benutzer/Aufgaben haben.
Abbildung 3.28: Es können auch mehrere Datensätze einem Befehl zugewiesen werden
118
Sandini Bib
3.3 Arbeiten im Backend
Die Backend-Benutzer, die der Gruppe ONLINE REDAKTION angehören, können jetzt über das Modul AUFGABEN das TASKCENTER öffnen und dort unter BEFEHLE den Befehl zum Bearbeiten der Datensätze finden. Wenn der Befehl aufgerufen wurde, muss der Benutzer nur noch einen der Datensätze auswählen, der sich anschließend zur Bearbeitung öffnet.
Abbildung 3.29: Befehle zum Bearbeiten von Datensätzen erleichtern die Arbeit besonders dann, wenn die Datensätze häufig bearbeitet werden müssen
3.3.7
Per Befehl eine Datensatzliste anzeigen lassen
Legen Sie auf der Root-Seite einen neuen Datensatz Befehl an. Den Typ des Befehls müssen Sie auf RECORD LIST einstellen. Geben Sie dazu dem Befehl einen Titel. Unter ASSIGN ACTION TO GROUPS müssen Sie den Befehl einer oder mehreren Gruppen zuweisen, die den Befehl ausführen dürfen. Jetzt müssen Sie noch die Seite angeben, auf der die Datensätze zu finden sind, von denen eine Liste generiert werden soll. Als Letztes müssen Sie unter LIST ONLY TABLE noch den Datensatz TYP angeben, der gelistet werden soll. Ab Version 3.7.0 können Sie auch einfach auf eines der Icons klicken, die die Datensatz-Typen symbolisieren. Bei älteren TYPO3-Versionen müssen Sie die Auswahl über das Pulldown-Menü tätigen. Der Backend-Benutzer kann jetzt über das Modul AUFGABEN im Taskcenter den neuen Befehl ausführen.
119
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.30: Das Eingabeformular erscheint erst, wenn Sie den Typ des Befehls auf Record List umgestellt haben
Abbildung 3.31: Der Befehl muss über das Taskcenter ausgeführt werden
120
Sandini Bib
3.3 Arbeiten im Backend
Achtung Hat der Benutzer keine Rechte, kann auch der Befehl nicht korrekt ausgeführt werden. Dem Benutzer müssen die folgenden Zugriffsrechte zugewiesen werden: Zugriff auf das Modul WEB>LISTE und BENUTZER>AUFGABEN. Der Benutzer muss wenigstens die Tabelle Adresse betrachten dür-
fen: TABLES (LISTING). Der DB Mount des Benutzers oder seiner Gruppe muss das Ver-
zeichnis sein, welches unter LIST PID im Befehl angegeben wurde oder ein übergeordnetes Verzeichnis. Über das Modul ZUGRIFF muss der Administrator dem Benutzer
wenigsten das Recht ZEIGE SEITE für die Seite mit den Datensätzen einräumen.
3.3.8
Per Befehl eine CSV-Liste exportieren
In diesem Tipp wollen wir beschreiben, wie Sie einen Befehl anlegen, den BackendBenutzer verwenden können, um eine Adressliste in eine CSV-Datei zu exportieren. Als Quelle dienen uns Frontend-User, die sich auf der Website angemeldet haben. Als Erstes muss eine Datenbankabfrage erzeugt werden, die die benötigten Daten ausgibt. Dazu rufen Sie das Modul DB CHECK auf und selektieren SEARCH WHOLE DATABASE. Stellen Sie danach im zweiten Pulldown-Menü ADVANCED QUERY ein und im dritten CSV EXPORT. Jetzt können Sie die Datenbankabfrage zusammenstellen. In unserem Beispiel wollen wir eine Liste von Backend-Benutzern exportieren, also muss als TABLE WEBSITE USER selektiert werden. Jetzt können die Felder ausgewählt werden, die in der Liste aufgeführt werden sollen. In dem grau hinterlegten Bereich können Sie die Abfrage einschränken. Im Anschluss daran können Sie die Ergebnismenge gruppieren und nach beliebigen Feldern in der Datenbank sortieren. Die Datenbankabfrage wird unter SQL QUERY angezeigt. Das Ergebnis der Abfrage können Sei sofort unter RESULT kontrollieren. Geben Sie der Datenbankabfrage noch einen Namen und speichern die Abfrage. Als Nächstes müssen Sie einen Befehl auf der Root-Seite anlegen, dem dann die Datenbank-Abfrage zugeordnet wird. Wechseln Sie also in das Liste-Modul und rufen die Root-Seite im SEITENBAUM auf. Legen Sie einen neuen Datensatz Befehl an. Der Befehl muss vom Typ SQL-QUERY sein. Geben Sie dem Befehl einen Namen und weisen Sie eine Benutzergruppe zu, deren Benutzer den Befehl ausführen dürfen.
121
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.32: Mit dieser Abfrage können Sie beliebige Exporte generieren und diese dann den Benutzern zur Verfügung stellen Wenn der Befehl fertig angelegt und gespeichert ist, wechseln Sie wieder in das Modul DB CHECK. Laden Sie die zuvor gespeicherte Datenbankabfrage. Sie werden feststellen, dass ein weiterer Name im Pulldown-Menü auftaucht, und zwar mit der Zahl in eckigen Klammern am Ende des Namens. Das ist der Befehl, den Sie zuvor angelegt haben. Laden Sie zuerst die Datenbankabfrage, das muss ein Name ohne diese Ziffer sein. Nachdem Sie die Abfrage geladen haben, selektieren Sie den Befehl im Pulldown-Menü, also den Eintrag mit der Ziffer in eckigen Klammern und klicken auf SAVE. Damit ist die Datenbankabfrage jetzt im Befehl gespeichert. Wechseln Sie anschließend in das Modul AUFGABEN und rufen im Taskcenter den neuen Befehl auf. Sie erhalten ein Textfeld mit dem Ergebnis der Abfrage, unter dem sich auch ein Link befindet, über den Sie das Ergebnis als Datei speichern können. Vorteil dieser Methode ist, dass der Benutzer lediglich Zugriffsrecht auf das Modul BENUTZER und BENUTZER>AUFGABEN benötigt. Es sind keine DB Mounts notwendig oder sonstige Zugriffsrechte.
122
Sandini Bib
3.3 Arbeiten im Backend
Abbildung 3.33: Der CSV Export über eine Datenbankabfrage ist zwar etwas aufwendiger, für den Administrator, aber einfacher für die Backend-Benutzer als der CSV Export über das Liste-Modul
3.3.9
Per Befehl Backend-Benutzer anlegen
Backend-Benutzer dürfen nur von Administratoren angelegt werden. Um zum Beispiel dem Radaktionsleiter auch ohne volle Adminrechte das Anlegen von Redakteuren zu ermöglichen, können Sie einen Befehl anlegen, über den Backend-Benutzer verwaltet werden können. Dazu benötigen Sie einen Backend-Benutzer, der als Vorlage für die Erzeugung neuer Benutzer dient. Alle Grundeinstellungen sollten Sie dem Benutzer über eine Benutzergruppe zuweisen. Dieser Gruppe könnten Sie zum Beispiel ein DB Mount zuweisen und Rechte am Seite- und Liste-Modul geben. Alle weiteren Rechte, zum Beispiel über das Dateiliste-Modul, können Sie über eine weitere Benutzergruppe vergeben, die optional die Rechte des Benutzers erweitert. Wenn Sie den Benutzer, der als Vorlage dienen soll angelegt haben, und die Benutzergruppe mit den Grundeinstellungen zugewiesen haben, testen Sie den Benutzer. Jetzt kann der eigentliche Befehl angelegt werden. Erzeugen Sie dazu den neuen Datensatz BEFEHL auf der Root-Seite und stellen den TYP auf CREATE BACKEND USER ein. Geben Sie Ihrem Befehl einen Titel. Als Nächstes muss der Benutzer, der als Vorlage dienen soll, unter TEMPLATE USER angegeben werden. Wenn Sie neben der Benutzergruppe mit den Grundeinstellungen noch weitere optionale Gruppen verwenden möchten, dann können Sie diese im letzten Feld zuordnen. In unserem Beispiel haben wir eine weitere Benutzergruppe angelegt, über die die Rechte zum Dateiliste-Modul und ein File Mount gesetzt werden. Diese Rechte können beim Ausführen des Befehls optional gesetzt werden. Somit kann der Radaktionsleiter selber Backend-Benutzer mit unterschiedlichen Rechten anlegen.
123
Sandini Bib
3 Administrationsoberflächen konfigurieren
Als Letztes müssen Sie noch eine Benutzergruppe festlegen, die diesen Befehl ausführen darf. In unserem Beispiel ist das die Gruppe Redaktionsleitung.
Abbildung 3.34: Damit nicht die komplette Benutzerverwaltung am Administrator hängen bleibt, können Teile der Benutzerverwaltung durch Befehle an andere Backend-Benutzer delegiert werden Wenn der Befehl fertig gestellt ist, speichern Sie ihn ab und testen den Befehl über das Modul AUFGABEN. Wenn Sie den Befehl aufrufen, erhalten Sie einige Eingabefelder, in denen der Login-Name und das Passwort angegeben werden müssen. Alle anderen Angaben sind optional. Wenn kein DB Mount über die Gruppe mit den Grundeinstellungen zugewiesen wurde, sollten Sie dieses unter SEITENBAUM STARTPUNKTE beim Anlegen des Backend-Benutzers über den Befehl nachholen. Besser ist es, Sie setzen einen DB Mount über die Benutzergruppe mit den Grundeinstellungen. Unter MITGLIEDER DER GRUPPEN können Sie dem Benutzer nun zusätzliche Rechte zuweisen. Wenn einmal über den Befehl ein Benutzer angelegt wurde, erhalten Sie eine Liste der Backend-Benutzer, die mit diesem Befehl angelegt wurden. Aus dieser Liste können Sie die Benutzer aufrufen, bearbeiten oder auch löschen.
124
Sandini Bib
3.3 Arbeiten im Backend
Abbildung 3.35: Die über einen Befehl angelegten Benutzer können später auch über den Befehl bearbeitet oder gelöscht werden Durch eine geschickte Rechtevergabe über einzelne Benutzergruppen kann so mit einem Befehl fast die komplette Benutzerverwaltung delegiert werden. Als Letztes bleibt nur noch zu testen, ob der Redaktionsleiter auch den Befehl ausführen kann. Dazu muss im Befehl unter ASSIGN ACTION TO GROUPS die Benutzergruppe der Redaktionsleitung entsprechend gesetzt sein, und der Redaktionsleiter muss natürlich Zugriff auf das Modul AUFGABEN haben.
3.3.10
Element Browser modifizieren
Wenn Sie Bilder mit dem Element Browser in ein Verzeichnis übertragen, in dem bereits Bilder vorhanden sind, werden als Erstes im Element Browser der Verzeichnisbaum und die Dateien geladen. Erst am Ende erscheint das Formular, über das neue Dateien übertragen werden können. Das heißt, es muss immer erst ans Ende der Liste gescrollt werden. Um nicht ständig ans Ende scrollen zu müssen, kann mit wenig TypoScript das Upload-Formular an den Anfang gestellt werden. Diese Funktionalität müssen Sie im TSCONFIG-Feld des Backend-Benutzers oder einer Benutzergruppe einstellen. Öffnen Sie dazu die TypoScript QuickReference. Unter [OPTIONS] finden Sie die Eigenschaft uploadFieldsInTopOfEB, die das Formular an den Anfang des Element Browsers stellt. Der Code im TSCONFIG-Feld muss wie folgt aussehen: options { uploadFieldsInTopOfEB=1 }
125
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.36: Der Element Browser mit dem Upload-Formular am Seitenanfang Dem Administrator steht standardmäßig die Möglichkeit zur Verfügung, auch über den Element Browser neue Verzeichnisse anzulegen. Für Backend-Benutzer ohne volle Adminrechte muss das Feld zum Anlegen neuer Verzeichnisse im Element Browser erst noch aktiviert werden. Auch diese Einstellung wird über das TSCONFIG-Feld des Backend-Benutzers oder einer Benutzergruppe vorgenommen und findet sich in der QuickReference unter [OPTIONS]. Die Eigenschaft heißt createFoldersInEB und muss mit =1 aktiviert werden. Leider kann die Position des Feldes zum Anlegen neuer Verzeichnisse nicht angepasst werden. Zum Anlegen neuer Verzeichnisse muss deshalb immer an das Ende des Element Browsers gescrollt werden. Mit einer weiteren Eigenschaft können Sie das Laden der Thumbnails im Element Browser unterbinden. Dadurch werden Listen besonders von Ordnern mit vielen Bildern schneller geladen. Diese Eigenschaft heißt noThumbsInEB und wird wie die beiden bereits beschriebenen Eigenschaften zugewiesen. Alle drei Eigenschaften im TSconfig sehen dann wie folgt aus. options { createFoldersInEB=1 uploadFieldsInTopOfEB=1 noThumbsInEB=1 }
126
Sandini Bib
3.3 Arbeiten im Backend
Abbildung 3.37: Das Erscheinungsbild des Element Browsers mit allen drei aktivierten Eigenschaften
3.3.11
Inhaltsspalten konfigurieren
Bei vielen TYPO3-Projekten werden Inhalte nur in der Spalte NORMAL angelegt. Werden die anderen Spalten nicht benötigt, können diese auch in der Spalten-Ansicht deaktiviert werden.
Abbildung 3.38: Nicht benutzte Spalten in der Spalten-Ansicht können ausgeblendet werden, um das Backend etwas übersichtlicher zu gestalten
127
Sandini Bib
3 Administrationsoberflächen konfigurieren
Diese Einstellung muss über das TSCONFIG-Feld der Seite vorgenommen werden. So können Sie zum Beispiel auf der Startseite noch alle Spalten anzeigen lassen und erst auf den Unterseiten die nicht verwendeten Spalten ausblenden. Die Einstellung wird an alle Unterseiten vererbt. Öffnen Sie die TypoScript QuickReference durch einen Klick auf das Symbol neben dem TSCONFIG-Feld. Im Objekt mod.web_layout finden Sie die Eigenschaft tt_content. colPos_list. Über diese Eigenschaft bestimmen Sie, welche Spalten in welcher Reihenfolge angezeigt werden sollen. Vorgabe hier ist 1,0,2,3. Spalten-Nummer
Spalten-Name
0
NORMAL
1
LINKS
2
RECHTS
3
RAND
Tabelle 3.3: Die Spalten im Backend und deren Nummern Das folgende TypoScript würde die Spalten LINKS, RECHTS und RAND ausblenden, sodass nur die Spalte NORMAL angezeigt wird. mod.web_layout { tt_content.colPos_list= 1 }
Im Seiteninhaltselement können zwar immer noch die anderen Spalten selektiert werden, aber beim Anlegen im Assistenten stehen nur noch die eingestellten Spalten zur Verfügung.
3.4
Frontend & Admin Panel
3.4.1
Bearbeitungswerkzeuge ohne Admin Panel
Das Admin Panel kann über die USER TSconfig eingestellt werden. Sie können das Admin Panel also für jeden Benutzer oder für jede Gruppe gesondert über deren TSCONFIG-Feld einstellen. Das Admin Panel muss allerdings zuvor noch im Template aktiviert werden, auch wenn nur die Bearbeitungswerkzeuge angezeigt werden sollen. config.admPanel = 1
Wenn Sie ein Frameset verwenden, sollten Sie das PAGE-Objekt voranstellen. page.config.admPanel = 1
128
Sandini Bib
3.4 Frontend & Admin Panel
Die Bereiche im Admin Panel können einzeln aktiviert werden. Die Anzeige der Bearbeitungswerkzeuge auf der Internetseite können Sie mit den Eigenschaften forceDisplayIcons und forceDisplayFieldIcons erzwingen, unabhängig davon, was im Admin Panel für Einstellungen vorgenommen werden. Um den Benutzer nicht mit dem kompletten Admin Panel zu belasten, kann das Admin Panel sogar verborgen werden, indem Sie die Eigenschaft hide=1 setzen. Dadurch wird das Admin Panel nicht deaktiviert, sondern nur versteckt. Dann müssen aber wenigstens die Icons oder die Icon-Felder aktiviert werden, am besten beide. admPanel { module.edit.forceDisplayFieldIcons = 1 module.edit.forceDisplayIcons = 1 hide = 1 }
3.4.2
Backend-Login mit Weiterleitung zum Frontend
Wie die Interfaces beim Login eingestellt werden können, haben wir bereits beschrieben. Dies lässt sich leider nur systemweit einstellen. Wenn nun aber einzelne Benutzer überwiegend im Frontend arbeiten, dann können diese über einen speziellen Link das Login aufrufen. Nach erfolgreicher Anmeldung wird der Benutzer dann auf das Frontend weitergeleitet. http://www.IhreDomain.de/typo3/index.php?redirect_url=../
Der Link kann von dem Benutzer in die Lesezeichen des Browsers aufgenommen werden. So spart sich der Benutzer das ständige Selektieren des Interfaces, wenn das Frontend nicht als erstes und somit als Standard eingestellt wurde. Eine weitere Möglichkeit besteht darin, den Link in das Template zu integrieren, sodass auf jeder Seite ein Link vorhanden ist, über den die Backend-Benutzer das Login mit der Weiterleitung zum Frontend aufrufen können.
3.4.3
Nur Frontend-Bearbeitung erlauben
Um Benutzern das Backend komplett zu deaktivieren, müssen Sie eine Erweiterung installieren. Rufen Sie den Extension Manager auf und wählen im Menü den Punkt IMPORT EXTENSIONS FROM ONLINE REPOSITORY aus. Da das Online Repository mittlerweile hunderte von Erweiterungen enthält, empfiehlt es sich, im Feld LOOK UP einen Suchbegriff einzugeben, damit nicht die komplette Liste aller Erweiterungen geladen wird. Der Extension Key der Erweiterung nach der Sie suchen, lautet FRONTEND_EDIT_ Geben Sie also den Extension Key ein und klicken Sie auf CONNECT TO ONLINE REPOSITORY. Sie erhalten dann die Erweiterung angezeigt. Diese müssen Sie zuerst
ONLY.
129
Sandini Bib
3 Administrationsoberflächen konfigurieren
importieren und anschließend installieren. Bei der Installation werden Sie feststellen, dass die Erweiterung ein zusätzliches Feld in die Tabelle der Backend-Benutzer BE_USERS einfügt. Nach erfolgreicher Installation öffnen Sie einen Backend-Benutzer zur Bearbeitung. Am Ende finden Sie das neue EDIT IN FRONTEND ONLY-Kästchen zwischen dem TSCONFIG-Feld und den ALLGEMEINEN OPTIONEN.
Abbildung 3.39: Ist das Häkchen gesetzt, kann der Backend-Benutzer nur noch auf dem Frontend Inhalte bearbeiten, das Backend lässt sich nicht mehr aufrufen Sie sollten natürlich darauf achten, dass der Benutzer dann auch über entsprechende Rechte verfügt, um auf dem Frontend arbeiten zu können. Das Admin Panel muss also aktiviert sein. Wenn das Admin Panel über die Eigenschaft hide versteckt ist, dann muss wenigstens über die Eigenschaft forceDisplayFieldIcons oder forceDisplayIcons die Bearbeitungsleiste oder die Bearbeitungswerkzeuge aktiviert sein.
3.4.4
Admin Panel frei platzieren
Das Admin Panel wird normalerweise immer unterhalb der Seite angezeigt. Die Erweiterung ADMIN PANEL WRAPPPING/POSITION ermöglicht es, das Admin Panel in ein beliebiges HTML-Konstrukt einzubetten und damit frei auf der Website zu platzieren. Da dann das Admin Panel Teile der Website überlagern könnte, wurde in der Vorgabe das Admin Panel in ein JavaScript eingebettet, welches das Admin Panel jetzt per Drag&Drop frei positionierbar macht.
3.4.5
News im Frontend bearbeitbar machen
Über das Admin Panel können standardmäßig nur Seiteninhalte bearbeitet werden, nicht aber Datensätze. Um nun das Bearbeiten von News im Frontend zu ermöglichen, sind zwei kleine Anpassungen am News-Modul notwendig. Als Erstes muss das Admin Panel für die News aktiviert werden. Dazu fügen Sie in das Setup-Feld Ihres Templates das folgende TypoScript ein: plugin.tt_news.general_stdWrap.editPanel = 1
130
Sandini Bib
3.4 Frontend & Admin Panel
Abbildung 3.40: Das JavaScript kann durch eigenen Code ersetzt werden Über die Eigenschaft allow müssen Sie jetzt noch die Funktionen aktivieren, die zur Verfügung gestellt werden sollen. In unserem Beispiel können Benutzer im Frontend vorhandene News bearbeiten, neue News anlagen oder auch löschen. plugin.tt_news.general_stdWrap.editPanel.allow = edit, new,delete
In der Tabelle erhalten Sie eine Übersicht über die möglichen Funktionen, die über die Eigenschaft allow aktiviert werden können. Beachten Sie dabei, dass der BackendBenutzer entsprechende Zugriffsrechte auf den Datensatz hat. Nicht alle Funktionen sind für die News-Seiten sinnvoll. Da die News nach dem Datum sortiert werden, können die News nicht manuell sortiert werden. Bei den News würden die Symbole zum Sortieren also auch nicht angezeigt werden, wie es ebenfalls im Backend der Fall ist. Werte
Funktionen
toolbar
Aktiviert die Werkzeugleiste
edit
Öffnet den Datensatz
new
Erzeugt einen neuen Datensatz
delete
Löscht den Datensatz
move
Verschiebt den Datensatz
hide
Versteckt den Datensatz
Tabelle 3.4: Die möglichen Funktionen, die Sie über die Eigenschaft allow aktivieren können
131
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.41: Auf dieser News-Seite sind die Bearbeitungswerkzeuge zum Editieren, Erzeugen und Löschen neuer News aktiviert
3.4.6
Logout vom Frontend
Damit Sie Ihren Benutzer aus dem TYPO3-Administrationsbereich abmelden können, müssen Sie im Backend auf die Schaltfläche LOGOUT klicken, oder alle Instanzen Ihres Browsers schließen. Benutzer, die aber ausschließlich auf dem Frontend arbeiten, können sich nicht vom TYPO3-System abmelden, und die Option, den Browser zu schließen, ist auch nicht besonders komfortabel. Das folgende TypoScript ermöglicht es Ihren Benutzern, sich auch vom Frontend abmelden zu können und muss in das SETUP-Feld Ihres Templates eingefügt werden. Achtung Achten Sie unbedingt darauf, dass das TypoScript in geschweiften Klammern steht.
132
Sandini Bib
3.4 Frontend & Admin Panel
Als Erstes muss TYPO3 erkennen, ob die Seite von einem angemeldeten BackendBenutzer aufgerufen wird. Nur dann soll die Möglichkeit zum Abmelden angezeigt werden. Das heißt, Ihren »normalen« Besuchern wird der Befehl nicht angezeigt. [globalVar = TSFE : beUserLogin = 1] [global]
Das TypoScript innerhalb dieser Bedingung wird nur angezeigt, wenn die Seite von einem angemeldeten Backend-Benutzer aufgerufen wird. Wird die Seite von jemandem, der nicht als Backend-Benutzer angemeldet ist, aufgerufen, dann ist die globale Variable beUserLogin gleich null. Damit trifft die Bedingung nicht zu und wird ignoriert. Jetzt folgt der Code, der den Link zum Abmelden erzeugt. page.10.subparts.LOGOUT = TEXT page.10.subparts.LOGOUT.value = Logout
In diesem Beispiel benötigen Sie einen Subpart in Ihrem Template, der LOGOUT heißt. Sie können aber auch vorhandene Elemente benutzen, zum Beispiel das WebsiteLogo oder eine Überschrift, und diese mit dem Abmelde-Link verlinken. In unserem zweiten Beispiel wird im Header einer jeden Seite ein Text generiert, der den subtitle der jeweiligen Seite ausgibt. Dieser Text wird durch die Eigenschaft wrap mit dem A HREF verlinkt, der das Abmelden durchführt. page.10.subparts.SUBTITLE.wrap = |
3.4.7
Bearbeitungsleiste an beliebiger Stelle im Template positionieren
Die Bearbeitungsleiste im Frontend kann frei positioniert und auch im Umfang angepasst werden. Das Ausgangs-TypoScript sieht wie folgt aus: neueSeiteAssistent = COA neueSeiteAssistent { 10 = EDITPANEL 10 { allow = new label = Seite:%s
Neue Seite line = 10 } }
133
Sandini Bib
3 Administrationsoberflächen konfigurieren
Abbildung 3.42: Angemeldete Backend-Benutzer können sich über die Überschrift oben rechts von jeder Seite aus abmelden Über die Eigenschaft allow legen Sie fest, welche Icons in der Bearbeitungsleiste angezeigt werden sollen. Über die Eigenschaft label geben Sie der Bearbeitungsleiste einen Namen. Die Eigenschaft line definiert den Abstand zur schwarzen Linie, die nach der Bearbeitungsleiste angezeigt wird. Dieses Content Objekt (COA) können Sie jetzt einem beliebigen Marker oder Subpart in Ihrem Template zuweisen. In unserem Beispiel haben wir das QuickStart Paket verwendet und das Objekt über die Navigation gestellt. left.96 < neueSeiteAssistent
Den Code müssen Sie in das SETUP-Feld des Templates schreiben.
134
Sandini Bib
3.4 Frontend & Admin Panel
Abbildung 3.43: Die auf das Anlegen neuer Seiten eingeschränkte Bearbeitungsleiste über der Navigation
135
Sandini Bib
Sandini Bib
4
Templates unter TYPO3
4.1
Zum Einsatz von TypoScript
4.1.1
Style Sheets in Projekte integrieren
Normalerweise werden Style Sheets mithilfe der Eigenschaft stylesheet des PAGEObjektes in die Seiten eingebunden. page.stylesheet = fileadmin/css/seiten.css
Auf diese Weise lässt sich aber nur eine Style Sheet-Datei einbinden. Wenn Sie Ihre Style Sheets gerne auf mehrere Dateien verteilen, müssen auch alle diese Dateien im Header der HTML-Dokumente eingebunden sein. Das lässt sich mit der Eigenschaft includeCSS des PAGE-Objektes bewerkstelligen. Dieser Eigenschaft kann bzw. muss ein Array übergeben werden, das mehrere Style Sheet-Dateien beinhalten kann. includeCSS { file1 = fileadmin/css/seiten.css file2 = fileadmin/css/navigation.css file3 = fileadmin/css/formulare.css }
Achten Sie darauf, dass Sie die Eigenschaft includeCSS Ihrem PAGE-Objekt zugewiesen haben. Wenn das PAGE-Objekt page heißt, dann muss das TypoScript wie folgt aussehen: page.includeCSS { file1 = fileadmin/css/seiten.css …
Wenn Sie für unterschiedliche Ausgaben, beispielsweise Bildschirm- und Druckausgabe, Style Sheets definiert haben, können Sie über die Eigenschaft media die entsprechenden Attribute im <style> tag setzen.
Sandini Bib
4 Templates unter TYPO3
page.includeCSS { file1 = fileadmin/css/seiten.css file1.media = print …
4.1.2
Einbinden dynamischer Style Sheets
Wie Sie CSS-Dateien einbinden, haben wir im vorangegangenen Tipp beschrieben. In diesem Tipp wollen wir jetzt ein dynamisches Style Sheet generieren. Legen Sie sich dazu einen neuen Datensatz vom Typ Template an. Dieses Template soll die Style Sheet-Definitionen beinhalten. Sie müssen dieses Template über INCLUDE BASIS TEMPLATE in Ihr Haupt-Template integrieren.
Abbildung 4.1: Das Template mit den Style Sheet-Definitionen muss in das HauptTemplate eingebunden werden In dem Style Sheet-Template wird jetzt zuerst ein neues PAGE-Objekt angelegt. Dieses PAGE-Objekt bekommt eine typeNum, die noch nicht verwendet wird. Die Nummern im Neunziger-Bereich sind für xml, wap und andere Ausgabeformate reserviert und sollten daher nicht verwendet werden. Wir verwenden in unserem Beispiel die Nummer 234. Mithilfe dieser Nummer können Sie dann später Ihr dynamisches Style Sheet aufrufen und überprüfen. Übergeben Sie dazu bei Aufruf den Typ mit der entsprechenden Nummer. http://www.IhreDomain.de/index.php?id=1&type=234
Da TYPO3 HTML-Dokumente generiert und entsprechend automatisch den Header eines jeden Dokumentes generiert, muss dieses für unser dynamisches Style Sheet unterbunden werden. config{ additionalHeaders = Content-type: text/css disableAllHeaderCode = 1 }
Achten Sie darauf, dass Sie die Eigenschaft config Ihrem PAGE-Objekt zugewiesen haben. Wenn das PAGE-Objekt page heißt, dann muss das TypoScript wie folgt aussehen:
138
Sandini Bib
4.1 Zum Einsatz von TypoScript
page.config{ additionalHeaders = Content-type: text/css disableAllHeaderCode = 1 }
Mit der Eigenschaft additionalHeaders wird ein Dokument vom entsprechenden Typ generiert. Die Eigenschaft disableAllHeaderCode unterdrückt die Ausgabe des üblichen Headers. Jetzt wird ein leeres Style Sheet-Dokument generiert, das nur noch mit den Style Sheet-Angaben gefüllt werden muss. Die Style Sheet-Angaben geben Sie über ein einfaches Text-Objekt an. 10 = TEXT 10.value ( p { font-family:Arial, Helvetica, sans-serif; font-size: 12px; color:#333333; line-height:150%; } )
Verwenden Sie bei der Eigenschaft value normale Klammern, um mehrzeiligen Code zu übergeben. Innerhalb der Klammern können Sie dann Ihre Style Sheet-Angaben platzieren. Um das dynamische Style Sheet zu überprüfen, rufen Sie eine TYPO3-Seite auf und übergeben dabei den Seiten-Typ. http://www.IhreDomain.de/index.php?id=1&type=234 Sie sollten dann den im TEXT-Objekt angegebenen Code angezeigt bekommen. Das gesamte TypoScript gehört in das Setup-Feld Ihres Style Sheet-Templates. Eine Ausgangsversion des kompletten TypoScript würde dann wie folgt aussehen: dyn_css = PAGE dyn_css { typeNum = 234 config{ additionalHeaders = Content-type: text/css disableAllHeaderCode = 1 } 10 = TEXT 10.value ( p { font-family:Arial, Helvetica, sans-serif; font-size: 12px; color:#333333;
139
Sandini Bib
4 Templates unter TYPO3
line-height:150%; } ) }
Der Seitenaufruf mit Übergabe des Seiten-Typs machen wir uns jetzt zunutze, um das dynamische Style Sheet in das Haupt-Template zu integrieren. Speichen Sie also Ihr Style Sheet-Template und öffnen Sie Ihr Haupt-Template. Über die Eigenschaft headerData können Inhalte in den Header der von TYPO3 generierten HTML-Dokumente eingefügt werden. Wir wollen jetzt einen Verweis auf ein Style Sheet in den Header integrieren, der auf das dynamische Style Sheet verweist. Den Verweis haben Sie ja schon aufgerufen, um das dynamische Style Sheet zu überprüfen. Ein Style Sheet wird wie folgt in ein HTML-Dokument eingefügt: "; } else { $tConf["marks."]["HEADER."]["value"]=$row[title]; }
242
Sandini Bib
7.7 Kalender tt_calender
Auf diese Art und Weise erhalten Sie schnell die Möglichkeit, Ihren Kalendereinträgen Seiten zuordnen zu können. Auf diesen Seiten stehen Ihnen dann alle Freiheiten des Content Management-Systems zur Verfügung, um weitere Informationen oder Downloads ergänzend zum Kalenderdatensatz anbieten zu können.
Abbildung 7.19: Der Kalendereintrag mit der um den Link zur Infoseite erweiterten Überschrift
7.7.1
Kalendereinträge unterteilen
Kalendereinträge können unterteilt werden. Wenn Sie zum Beispiel ein Event haben und einen Zeitplan dazu festlegen möchten, können Sie die einzelnen Zeiten durch drei Bindestriche unterteilen. Die Eingabe im Feld BEMERKUNG würde dann in etwa so aussehen: Lorem ipsum Vivamus non magna vel odio malesuada condimentum. --6:00 Lorem dolor sit amet, consectetuer adipiscing elit. Cras convallis ultricies massa. --10:30 Suspendisse Lorem ipsum dolor sit amet, consectetuer adipiscing elit. --13:00 Quisque Etiam lobortis rutrum dui.
243
Sandini Bib
7 TYPO3 Extensions
--18:00 Proin Etiam lobortis rutrum dui.
Abbildung 7.20: Termine mit einzelnen Zeiten würden dann entsprechend vom Plugin der Angaben im Template formatiert
7.7.2
Produktbeschreibung in der Produktliste von tt_products automatisch kürzen
Wenn Sie einmal eine etwas längere Produktbeschreibung eingegeben haben, wird diese sowohl in der Listenansicht als auch in der Einzelansicht der Produkte komplett dargestellt. In der Übersicht der Produkte ist das aber eher unschön. Hier reichen ein paar Zeilen Produktbeschreibung, da die komplette Beschreibung ja über die Einzelansicht der Produkte aufgerufen werden kann. Um das zu umzusetzen, legen Sie in der Datei class.tx_ttproducts.php einen neuen Marker an, der eine Kurzbeschreibung beinhalten soll. Die Datei finden Sie in Verzeichnis pi der Erweiterung. In der Zeile 1043 wird der Marker für die Produktbeschreibung angelegt. $markerArray["###PRODUCT_NOTE###"] = nl2br($row["note"]);
244
Sandini Bib
7.8 Abstimmungen mit tt_poll anlegen
Fügen Sie dort eine neue Zeile ein, die wie folgt aussehen sollte: $markerArray["###PRODUCT_SHORTNOTE###"] = nl2br(substr($row["note"]),0,200)." ...";
Diese Zeile hat zur Folge, dass ein neuer Marker mit dem Namen PRODUCT_ SHORTNOTE angelegt wird. Der PHP-Befehl substr liefert einen Teilbereich einer Zeichenkette. Die Parameter geben den Startpunkt an und die Zeichenanzahl, die von einer Zeichenkette zurückgegeben werden sollen. In diesem Beispiel sollen von Beginn der Zeichenkette zweihundert Zeichen zurückgegeben werden. substr($Zeichenkette,0,200)
Als Zeichenkette wird der Code nl2br($row["note"]) eingefügt. Anschließend sollten Sie noch eine Zeichenkette anfügen, sodass deutlich wird, dass der Text hier abgeschnitten wurde. Für den Fall, dass die Produktbeschreibung keine 200 Zeichen lang ist, sollten Sie den neuen Marker in eine Bedingung einbetten. Damit verhindern Sie, dass die angefügte Zeichenkette auch nur dann ausgegeben wird, wenn die Produktbeschreibung auch wirklich gekürzt wurde. if (strlen ($row["note"]) > 200){ $markerArray["###PRODUCT_SHORTNOTE###"] = nl2br(substr($row["note"]),0,200)." ..."; } else $markerArray["###PRODUCT_SHORTNOTE###"] = nl2br($row["note"]);
Nun müssen Sie den neuen Marker noch im HTML-Template products_template.tmpl im Bereich der Listenansicht einfügen. In Zeile 71 des Templates finden Sie die Marker ###GW2B### ###PRODUCT_NOTE### ###GW2E###, der die Produktbeschreibung in der Listenansicht ausliefert. Ändern Sie den mittleren Marker auf ###PRODUCT_SHORTNOTE### und in der Produktübersicht wird die Produktbeschreibung automatisch auf 200 Zeichen gekürzt.
7.8
Abstimmungen mit tt_poll anlegen
Beim Integrieren von Abstimmungen gibt es einen kleinen Trick. Es muss kein Plugin auf der Seite platziert werden, sondern zunächst ein Datensatz Abstimmung. In diesem Datensatz wird die eigentliche Abstimmung angelegt, also die Frage und die Antwortoptionen. Dann muss noch ein Inhaltselement Datensatz einfügen auf der Seite platziert werden. Diesem Inhaltselement müssen über das Feld OBJEKTE alle Abstimmungen zugewiesen werden, die auf der Seite angezeigt werden sollen. Über das Setup-Feld des Templates muss noch die Ausgabe eingestellt werden. Sie müssen also einstellen, ob das Abstimmungsformular oder die Resultate der Abstimmungen angezeigt werden sollen, oder beides, wie in diesem Beispiel. plugin.tt_poll.code = VOTEFORM,RESULT
245
Sandini Bib
7 TYPO3 Extensions
Abbildung 7.21: Das Abstimmungsformular mit den Ergebnissen
7.9
Anmeldeformulare erweitern
Bei der Anmeldung über das Plugin Direct Mail Anmeldung oder auch bei der Registrierung über die Frontend-Benutzeradministration stehen bestimmte Felder zur Verfügung, die der Websitebesucher ausfüllen kann. Oft reichen diese Felder nicht aus, weil für spezielle Bedürfnisse weitere Daten notwendig sind. Wir wollen am Beispiel der Frontend-Benutzeradministration demonstrieren, wie diese um weitere Formularfelder erweitert werden kann. Das Verfahren bei der dmailsubscription ist identisch, da es auf dieselbe Erweiterung aufsetzt. Zunächst muss die Datenbank um die Felder erweitert werden, die im Formular ergänzt werden sollen, damit die Informationen auch gespeichert werden können. Das ist am einfachsten über den Kickstarter-Wizard zu realisieren, der über den Extension Manager aufzurufen ist. Natürlich muss der Kickstarter über den Extension Manager zuvor installiert worden sein, das es sich auch hierbei um eine Erweite-
246
Sandini Bib
7.9 Anmeldeformulare erweitern
rung handelt. Mit dem Kickstarter erzeugen Sie eine neue Erweiterung und erweitern eine vorhandene Tabelle. Es muss je nachdem, wo die Benutzer gespeichert werden, die Tabelle Frontend Users (fe_users) oder Address (tt_address) erweitert werden.
Abbildung 7.22: Mit neuen Erweiterungen können auch vorhandene erweitert werden In diesem Beispiel wollen wir die Datenbank lediglich um ein Feld für den Vornamen erweitern. Wenn das Feld entsprechend eingestellt wurde, kann mit der Schaltfläche VIEW RESULT der Code der Erweiterung generiert werden. Über die Schaltfläche WRITE muss die Erweiterung noch geschrieben werden. Anschließend kann die Erweiterung installiert werden. Bei der Installation wird dann die Tabelle um das neue Feld erweitert. Sie bekommen bei der Installation folgenden SQL-Befehl angezeigt: ALTER TABLE fe_users ADD user_firstname_firstname tinytext NOT NULL;
Jetzt kann das Template angepasst werden. Dazu erweitern wir zunächst das Formular um das Feld für den Vornamen.
Da bei der Anmeldung noch eine Vorschau der Daten erzeugt wird, muss über ein Hidden-Feld im Bereich TEMPLATE_CREATE_PREVIEW auch der Wert für den Vornamen übergeben werden.
247
Sandini Bib
7 TYPO3 Extensions
Abbildung 7.23: Die Ergebnisanzeige der neuen Erweiterung Um den Vornamen in der Vorschau anzeigen zu lassen, kann der Marker ###FIELD_user_firstname_firstname###
in das Template integriert werden. Damit wird nun das neue Feld in der Datenbank mit den Daten aus dem neuen Formularfeld befüllt. Da über die Erweiterung Frontend User Admin die Benutzer ihre Daten auch bearbeiten können, gibt es weitere Formulare, über die die Benutzerdaten editiert werden können. Die Bereiche TEMPLATE_EDIT und TEMPLATE_EDIT_PREVIEW sind dann entsprechend anzupassen.
7.10
AWSTATS
7.10.1
AWSTATS automatisieren
Mit der Erweiterung AWSTATS lassen sich die Logfiles des Webservers auswerten und analysieren. Im Backend werden die Statistiken über die Besucher der Webseite visuell aufbereitet und angezeigt. Das Aktualisieren der Statistik erfolgt über den
248
Sandini Bib
7.10 AWSTATS
Link JETZT AKTUALISIEREN im AWSTATS-Modul. Durch einen Klick auf den Link werden die Logfiles des Webservers von der Erweiterung analysiert und entsprechend angezeigt.
Abbildung 7.24: Über Update now kann die Statistik manuell aktualisiert werden Wurden die Statistiken längere Zeit nicht aktualisiert oder werden die IP-Adressen im Logfile zu Domainnamen aufgelöst, dauert die Erstellung der Statistik unter Umständen eine ganze Weile. Es kann daher sinnvoll sein, die Statistik in regelmäßigen Zyklen, z.B. stündlich oder täglich, automatisch zu aktualisieren. Die Daten, die in einem solchen Zyklus hinzukommen, sind überschaubar und lassen die Aktualisierung relativ schnell vonstatten gehen. Jochen Weiland hat eine kleine Modifikation in die AWSTATS-Erweiterung integriert, mit der ein Skript erzeugt werden kann, das dann über einen cron-Job regelmäßig aufgerufen werden kann. Dazu muss die index.php im Verzeichnis cc_awstats/mod1/ mit der modifizierten index.php ersetzt werden. Es gibt zwei unterschiedliche je nachdem, welche Versionsnummer die AWSTATS-Erweiterung hat. Sicherheitshalber sollten Sie die original index.php vorher sichern. Das können Sie mit dem folgenden Befehl, wenn Sie einen Shell-Zugang auf Ihrem Webserver haben. mv index.php index_original.php
Ist die neue index.php an Ort und Stelle, kann im TYPO3-Backend AWSTATS wie gewohnt aufgerufen und die Aktualisierung durchgeführt werden. Die veränderte index.php schreibt dabei eine neue Datei cron_script.sh im Verzeichnis mod1 der Erweiterung AWSTATS. Dieses Skript beinhaltet alle Anweisungen, über die AWSTATS alle Daten aus den Logfiles aktualisiert. Dieses Skript kann dann auf Linux-Servern durch einen cron-Job regelmäßig aufgerufen werden.
249
Sandini Bib
7 TYPO3 Extensions
Benennen Sie die Skript-Datei um, z.B. in awstats_update.sh: Mv cron_script.sh awstats_update.sh
Anschließend muss die Datei ausführbar gemacht werden: Chmod +x awstats_update.sh
Jetzt kann in crontab die Zeile eingefügt werden, über die die Datei awstats_update.sh regelmäßig aufgerufen wird. In diesem Beispiel wird alle zwei Stunden die Statistik vom Benutzer www-data aktualisiert. 00 */2 * * * www-data /pfad zur TYPO3 installation/TYPO3conf/ext/cc_awstats/mod1/awstats_update.sh > /dev/null
Sie sollten den Benutzer unter dem Ihr Webserver läuft, einsetzen, damit das Skript nicht von root ausgeführt wird.
7.11
Login implementieren
Für ein Login benötigen Sie zunächst eine Website-Benutzergruppe. Diese sollten Sie in einer gesonderten Seite vom Typ SYSORDNER anlegen. In diesem SysOrdner können Sie dann auch die Website-Benutzer verwalten. Nun müssen Sie eine Seite anlegen, auf der das Inhaltselement vom Typ LOGIN platziert wird. Über dieses Login können die Besucher sich an- und abmelden. Sie können jetzt weitere Inhalte oder auch Seiten anlegen, die über die allgemeinen Optionen nur gewissen Website-Benutzergruppen zugängig gemacht werden können.
Abbildung 7.25: Seiten und Inhalte können auf gleichem Weg zugriffsbeschränkt werden Jetzt muss in TYPO3 nur noch eingestellt werden, wo die Website-Benutzer und Benutzergruppen zu finden sind. Sie müssen also die UID des SysOrdners angeben. Dazu rufen Sie das Template-Modul auf und selektieren den Constant Editor. In der Kategorie CONTENT finden Sie im Bereich CONTENT: 'LOGIN' die Einstellung PID OF USER ARCHIVE. Hier müssen Sie die Seiten-UID des SysOrdners angeben. Zusätzlich können Sie noch eine Nachricht einstellen, die sich in einem Hinweisfenster öffnet, wenn der Benutzer sich angemeldet hat.
250
Sandini Bib
7.11 Login implementieren
Abbildung 7.26: Die Einstellungen aus dem Constant Editor werden in das Constants-Feld des Tempates übergeben styles.content.loginform.pid = 186 styles.content.loginform.goodMess = Sie sind jetzt am System angemeldet
Abbildung 7.27: Das Login auf der Website mit der Meldung bei erfolgreicher Anmeldung
251
Sandini Bib
7 TYPO3 Extensions
7.12
Benutzerregistrierung integrieren
Damit Website-Benutzer nicht manuell vom TYPO3-Administrator angelegt werden müssen, kann eine Benutzeranmeldung integriert werden, über die Besucher sich selber anmelden können. Die Freischaltung der so generierten Benutzeraccounts kann automatisch erfolgen oder durch den TYPO3-Administrator nach Prüfung der Daten. Wir wollen das einmal am Beispiel der Erweiterung Front End User Admin demonstrieren. Nachdem die Erweiterung über den Extension Manager installiert wurde, müssen Sie ein Seiteninhaltselement vom Typo Plugin einfügen und auf einer Seite platzieren. Stellen Sie in dem Inhaltselement die Erweiterung FRONTEND BENUTZER ADMINISTRATION ein. Wenn Sie die Seite aufrufen, bekommen Sie bereits das Formular angezeigt, worüber die Besucher einen neuen Benutzer anlegen können oder, wenn ein Frontend User eingeloggt ist, kann über diese Erweiterung der Benutzer seine Daten bearbeiten.
Abbildung 7.28: Die Erweiterung Frontend User Admin generiert das Formular zum Anlegen neuer Benutzer
252
Sandini Bib
7.12 Benutzerregistrierung integrieren
Jetzt müssen noch ein paar Einstellungen vorgenommen werden, damit die Benutzer auch korrekt erzeugt werden. Zunächst sollte der Erweiterung die ID des SysOrdners übergeben werden, damit die Website-Benutzer auf der korrekten Seite erzeugt werden. Das geht am einfachsten über den Constant Editor. Wählen Sie einfach im Constant Editor die CATEGORY PLUGIN.FEADMIN.FE_USERS aus. Im Bereich OTHERS kann die RECORD PID eingestellt werden. Hier tragen Sie die ID des SysOrdners ein. Damit die Website-Benutzer der korrekten Benutzergruppe zugewiesen werden, sollten Sie unter USERGROUP OVERRIDE die ID der gewünschten Website-Benutzergruppe angeben.
Abbildung 7.29: Die Einstellung kann über den Constant Editor vorgenommen werden, der dann das korrekte TypoScript in das Template schreibt Der Constant Editor überträgt die angegebenen Werte in das Constants-Feld des Templates. plugin.feadmin.fe_users.usergroupOverride = 1 plugin.feadmin.fe_users.pid = 186
Wenn jetzt neue Benutzer angelegt werden, sollten diese in der entsprechenden Seite angelegt und auch die Benutzergruppe mit ID=1 zugewiesen werden.
253
Sandini Bib
Sandini Bib
Stichwortverzeichnis A Absätze Formate deaktivieren im Rich Text Editor 228 Funktionen für eigene Klassen im Rich Text Editor 229 verschiedene Formate im Rich Text Editor 228 Abstimmung, einrichten mit tt_poll 245 Accesskeys 174 Übersicht 175 Admin Panel 128 einstellen 128 fehlende Symbole 83 frei platzieren 130 im Frontend konfigurieren 206 Adressen, verwalten mit tt_address 239 Änderungen rückgängig machen 68 Verlaufsliste 68 allow, Übersicht über aktivierbare Funktionen 131 Anmeldeformular, erweitern 246 attribs, Übersicht über mögliche Werte von 144 B Backend Anpassungen 205 deaktivieren für Benutzer 129 Login mit Weiterleitung zum Frontend einrichten 129 mehr Übersichtlichkeit durch Inhaltsspalten-Konfiguration 127 Navigationsframes anpassbar machen 113 Nummer/Name-Zuweisungen für Inhaltsspalten 128 Shortcut-Frame aktivieren für Benutzer 113 Shortcuts auf Dateien einrichten 115
Shortcuts für Benutzer einrichten 115 Shortcuts für Benutzergruppen einrichten 116 Shortcuts zum Bearbeiten einrichten 114 Standard-Zugangsdaten 20 Standardwerte für neue Datensätze modifizieren 205 Suchen 90 Zugriffsrechte vergeben auf Shortcuts 118 Backend-Benutzer, persönliche Notizen anlegen 94 Backend-Login, fehlende Bearbeitungssymbole 83 Backups automatische mit cron 39 einspielen 43 Bearbeitungsleiste, im Frontend frei platzieren und anpassen 133 Bearbeitungsrechte, für Backend-Benutzer setzen 103 Befehle anlegen Backend-Benutzer anlegen 123 CSV-Liste exportieren lassen 121 Datensatzliste anzeigen lassen 119 zum Bearbeiten von Elementen 118 Begrenzungsrahmen 72 Benutzer -Registrierung integrieren 252 Admin Panel einstellen 128 anlegen 97 Ausloggen aus Frontend bei deaktiviertem Backend 132 Backend deaktivieren für 129 Backend-Login mit Weiterleitung zum Frontend einrichten 129 Bearbeitungsrechte für Backend setzen 103 Erben von Mounts 100 für Backend per Befehl anlegen lassen 123
Sandini Bib
Stichwortverzeichnis
Seiteneinstiegspunkte setzen für 100 Session-Timeout für Backend hochsetzen 112 Zeitsteuerung nutzen 104 Zugriff auf Dateisystem erlauben 99 Zugriffsrechte für Befehle 121 Benutzergruppen Admin Panel einstellen 128 anlegen 97 simulieren über Admin Panel 96 Zugriffsrechte 100 Benutzerrechte, zum Löschen von Seiten 52 Betriebssysteme Erkennen mit system 146 Unterscheiden mit system 146 Bilder an PopUp-Fenster anpassen 207 auf jeder Seite andere 172 automatische Korrektur der Proportionen 71 Caption Splitting 105 einfügen in Inhaltselemente 69 Größenbeschränkungen 220 im Rich Text Editor anpassen 72 individuelle Links erstellen für 107 max. Größe einstellen im Constant Editor 220 per Drag‘n‘Drop einfügen 71 über den Rich Text Editor einfügen 70 Unterschriften zuweisen 105 Zugriffsrechte zum Hinzufügen 70 Bildergalerie 76 Breadcrumb-Navigation 190 Browse-Navigation 189 Browser unterscheiden mit browser 145 unterschiedliche Templates 145 browser, Übersicht über unterscheidbare Browser 145 C Caption Splitting 105 Constant Editor 155 max. Bilder-Größe einstellen 220 Template-Einstellungen vornehmen im 160 cron, automatische Backups 39 CSS dynamische Style Sheets in Projekte einbinden 138 in Template Records uploaden und benutzen 168 mehrere Style Sheets in Projekte einbinden 137
256
Style Sheets als Ressource anfügen und bearbeiten 141 Style Sheets über den CSS Styler bearbeiten 142 CSS Styler, Übersicht über mögliche Werte von attribs 144 CSV-Listen, exportieren 94 D date Ausgabe formatieren mit strftime 149 Übersicht über Parameter 147 Datei-Downloads 72 Dateien Anzahl der zu übertragenden festlegen 86 Arbeiten mit 85 löschen 86 über das Kontextmenü löschen 86 über numerische Klemmbretter kopieren oder verschieben 89 über numerische Klemmbretter löschen 86 überschreiben beim Upload 86 übertragen 85 umbenennen 87 verknüpfen 73 verlinken 72 verlinken im Rich Text Editor 73 verschieben oder kopieren 87 Verweise formatieren 210 Datenbank Mount 100 Datensätze, zuletzt bearbeitete aufrufen 92 Datum als Grafik ausgeben 151 anzeigen 147 Übersicht über date-Parameter 147 Datumsfelder 57 DB Mount 100 Debian GNU/Linux Apache-Konfiguration 30ff. APT-Konfiguration 29 Boot-Diskette erstellen 25 Hilfe bei der Installation 25 Installation 25f. MySQL-Konfiguration 30 Namensauflösung testen 26ff. phpMyAdmin 33 SSH-Client 26 System-Aktualisierung mit APT 29f. TYPO3-Installation 34 Zugriffsrechte für Webserver 40
Sandini Bib
Stichwortverzeichnis
Dok. Modul 92 Dokumente-Modul 92 Download-Links einfügen 72 Drag’n’Drop, Bilder einfügen per 71 E E-Mail-Adressen Links einfügen auf 75 verlinken im Rich Text Editor 76 E-Mail-Formular einfügen 78 fehlende Zugriffsrechte beim Erstellen 78 Rollover-Effekt in 214 Eingabehilfen 174 Einladungen, ermöglichen mit tipafriend 240 Einstellungen, allgemeine für TYPO3 105 Element Browser Feld zum Anlegen neuer Verzeichnisse aktivieren 126 Laden von Thumbnails unterbinden 126 modifizieren 125 Elemente Links einfügen auf 74 verschieben 50 Extensions als Datei von TYPO3.org herunterladen 224 als T3X-Datei installieren 224 im Extension Manager installieren 223 Externe URL, Seitentyp 63 F Farben, Funktionen im Rich Text Editor 230 Footer-Navigation 187 Formatierungen, für interne und externe Links 154 Formulare 214 Anmelde-~ erweitern 246 Rollover-Effekt in E-Mail-~ 214 Forum, integrieren mit tt_board 240 Frontend 128 Admin Panel konfigurieren 206 Anpassungen 206 Ausloggen bei deaktiviertem Backend 132 Bearbeitungsleiste frei platzieren und anpassen 133 im Backend anzeigen lassen 61 News bearbeitbar machen 130 Nummer/Name-Zuweisungen für Inhaltsspalten 158 nur Bearbeitung erlauben im 129
Seiten bearbeiten 83 Weiterleitung nach Login im Backend einrichten 129 früheren Bearbeitungsstand wieder herstellen 68 G gleichzeitige Bearbeitung von Inhalten 84 von Nicht-Seiteninhalten 84 Globale Variablen, abfragen 144 GMENU 196 aktive Seiten hervorheben 198 einfach 196 mit Hintergrundgrafiken 196 mit Rollover-Effekt 198 mit unterschiedlich breiten Grafiken 200 Übersicht über verfügbare Zustandsobjekte 200 unterschiedliche Zustände 200 Grafiken, Dateien in Template Records uploaden und benutzen 168 H HMENU 183 I Inhalte 57 als PDF ausgeben 176 auf mehreren Unterseiten automatisch platzieren 212 ausschneiden und einfügen 66 bearbeiten 64 Bearbeiten häufig wiederkehrender 92 Datumsfelder 57 für Drucker optimiert ausgeben 178 im Schnelleingabe-Modus bearbeiten 65 im Spalten-Modus bearbeiten 64 mehrere zur gleichzeitigen Bearbeitung öffnen 84 schnell über die ID öffnen 85 von anderen Seiten verknüpfen 82 Vorschau versteckter und zeitgesteuerter 94 Vorschau zeitgesteuerter 96 Vorschau zugriffsbeschränkter 96 weitere Ausgabeformate 181 Zeitsteuerung von 89 zwischen Seiten verschieben 66 Inhaltselemente bearbeiten 66 Bild einfügen 76
257
Sandini Bib
Stichwortverzeichnis
Bilder einfügen in 69 verschieben 67 Inhaltsspalten Inhalte von LEFT, RIGHT und BORDER verwenden 157 konfigurieren 127 Übersicht über Nummer/NameZuweisung im Backend 128 Übersicht über Nummer/NameZuweisung im Frontend 158 Install Tool Front- und/oder Backend-Interface bei Login anbieten 112 sichern 41 Upload-Limits einstellen 45 Installation 15 Debian GNU/Linux 25f. Namensauflösung unter Windows konfigurieren 17 unter Linux 25 unter Mac OS X mit XAMPP 21 unter Windows mit WAMP Quickstart 15 weitere Komponenten 28 J JSMENU, in Dropdown-Menüs 202 K Kalender einrichten mit tt_calender 241 Einträge Seiten zuordnen 241 Einträge unterteilen 243 Klemmbretter 51, 67 aktivieren im Liste-Modus 84 Dateien kopieren oder verschieben über numerische 89 Dateien löschen über numerische 86 Verzeichnisse kopieren oder verschieben über numerische 89 Konfiguration 15 L Layout 171 Links auf E-Mail-Adressen einfügen 75 auf E-Mail-Adressen im Rich Text Editor einfügen 76 auf Seiten und Elemente einfügen 74 automatische Generierung durch TYPO3 91 einfügen 76 interne und externe verschieden formatieren 154
258
löschen im Rich Text Editor 58f. zum Download einfügen 72 Linktypen mailto 75 Seite 74 Linux, Installation von TYPO3 25 Liste-Modul, Benutzer und Benutzergruppen anlegen 97 Logfiles, des Webservers auswerten mit AWSTATS 248 Login Front- und/oder Backend-Interface anbieten 112 implementieren 250 Interfaces 111 Lupe-Icon, aktivieren 62 M Mac OS X, Installation von TYPO3 mit XAMPP 21 Menüs ASCII-Werte für Trennzeichen in Text- 194 Bereichsüberschriften 192 Dropdown- 202 Dropdown-~ mit JSMENU 202 Dropdown-~ mit TMENU 202 GMENU-Objekt 196 Haupt- mit Untermenüs erweitern 184 Haupt- und Untermenüs räumlich trennen 186 HMENU-Objekt 183 Navigationszustände aktivieren 183 TMENU-Objekt 193 Trennzeichen in Text- 194 Meta-Tags 215 Module, Zugriff freigeben auf 98 Mounts, Erben von 100 MySQL 42 Backup einspielen 43f. Konfiguration unter Debian GNU/Linux 30 root-Passwort setzen 42 MySQL Commander 42 Backups einspielen 43 Zugriffsrechte anpassen 42 mysqldump, Backup erstellen 43 N Navigation Breadcrumb- 190 Browse- 189 Footer- 187
Sandini Bib
Stichwortverzeichnis
GMENU-Objekt 196 Haupt- mit Unternavigation erweitern 184 Haupt- und Unternavigation räumlich trennen 186 HMENU-Objekt 183 TMENU-Objekt 193 Zustände aktivieren 183 Navigationstitel 59 neue Seiten 53 Neuerstellungs-Assistent 53 News archivieren 234 auf der Seite integrieren 234 Autorennamen voreintragen 236 im Frontend bearbeitbar machen 130 tt_news 234 Übersicht auf jeder Seite 237 Übersicht über via allow aktivierbare Funktionen 131 Notizen anlegen, Backend-Benutzer 94 P PHP-Konfiguration 44 Safe Mode einstellen 45 Speicherlimit erhöhen 44 Upload-Limits einstellen 45 phpMyAdmin 42 Backups einspielen 43 Installation unter Debian GNU/Linux 33 Konfiguration 33 PopUp-Fenster, Bilder anpassen an 207 Produktbeschreibungen, in tt_products automatisch kürzen 244 Putty 26 R rekursives Löschen 52 Rich Text Editor 58, 225 Absatzformate deaktivieren 228 auf E-Mail-Adressen verlinken 76 Bilder einfügen 70 Dateien verlinken 73 Links löschen im 58f. Schriftarten 226 Schriftarten-Werkzeug aktivieren 226 Toolbar modifizieren 110 Übersicht über Schriftarten 227 um Schriftarten erweitern 227 verfügbare Icons für Toolbar 110 Rich Text Editor-Funktionen für Absatzformate 228 für eigene Absatzklassen 229 für Farben 230
für Schaltflächen 233 Tabellen 233 zum Anpassen des Erscheinungsbildes 232 Rollover-Effekt, in E-Mail-Formular 214 S Safe Mode, einstellen 45 Schnelleingabe-Modus 65 Schriftarten, Rich Text Editor 226 Schriftarten-Werkzeug, im Rich Text Editor aktivieren 226 Seiten Alias für einprägsamere HTTP-Adressen 92 Alias setzen 91 alternative Navigationstitel für 59 anzeigen lassen 61 anzeigen lassen über Liste-Modul 61 anzeigen lassen über Seite-Modul 61 bearbeiten im Frontend 83 Benutzerrechte zum Löschen von 52 Cache löschen 90 ID 91 kopieren 48 kopieren über Liste-Modul 50 kopierte einfügen 48 Links einfügen auf 74 mehrere kopieren 51 mehrere löschen 52 mehrere schnell erzeugen 55 mehrere verschieben 51 neue anlegen 53 neue automatisch erstellen 108 Neuerstellungsassistent 53 schnell über die Seiten-ID öffnen 85 sortieren 56 Titel-/Untertitel in Templates hinzufügen 170 unterschiedliche Startseiten je nach Domain 217 verschieben 50 verschieben über Liste-Modul 51 verschieben über Seite-Modul 51 verstecken 47 Vorschau von versteckten und zeitgesteuerten 94 Vorschau von zeitgesteuerten 96 Vorschau von zugriffsbeschränkten 96 Zeitsteuerung von 89f. zuletzt bearbeitete aufrufen 92 Seiten sortieren 56 Seiten verstecken 47
259
Sandini Bib
Stichwortverzeichnis
Seiten-Alias, für einprägsamere HTTPAdressen 92 Seiten-Verknüpfungen 82 Seitenalias setzen 91 Seitencache löschen 90 Seiteneinstiegspunkt, setzen 100 Seitenrechte setzen 100 Übersicht über 102 Seitentyp Externe URL 63 Sessions, Timeout hochsetzen 112 Shortcut-Frame, aktivieren für BackendBenutzer 113 Shortcut-Modus 62 Shortcut-Seiten 62 Shortcuts auf Dateien im Backend einrichten 115 für Benutzer im Backend einrichten 115 für Benutzergruppen im Backend einrichten 116 im Backend Zugriffsrechte vergeben auf 118 zum Bearbeiten im Backend einrichten 114 Sichtbarkeitseinstellungen 47 Simulation statischer Dokumente 91 Spalten-Modus 64 SSH-Client, Putty 26 Startseiten, unterschiedliche je nach Domain 217 Steuerzeiten 89 strftime, Übersicht über Parameter zur Formatierung der date-Ausgabe 149 Style Sheets als Ressource anfügen und bearbeiten 141 dynamische in Projekte einbinden 138 mehrere in Projekte einbinden 137 über den CSS Styler bearbeiten 142 Subdomains 217 Suchen einfügen als Funktion 80 im Backend 90 Seitenelemente durchsuchen 80 system Betriebssysteme erkennen mit 146 Übersicht über unterscheidbare Betriebssysteme 146 T Tabelle pages, Übersicht über Datenbankfelder 108 Tabellen, Funktionen im Rich Text Editor 233
260
Tastaturkürzel 174 Übersicht 175 Template Records, Ressourcen uploaden und benutzen in 168 Templates Bearbeitungsleiste frei platzieren und anpassen 133 browserabhängige 145 BUG 160 Business 161 CANDIDATE 162 CrCPH 162 Einstellungen im Constant Editor vornehmen 160 FIRST 163 GLUECK 163 GREEN 164 HYPER 164 in Template Records uploaden und benutzen 168 MM 159, 161, 167 NEWSLETTER 165 RE 165 Seiten-/Untertitel hinzufügen 170 Standard-Templates bearbeiten 159 TU 166 Text-Menüs ASCII-Werte für Trennzeichen 194 Trennzeichen 194 Thumbnails, Laden im Element Browser unterbinden 126 Timeout, für Sessions hochsetzen 112 TMENU 193 in Dropdown-Menüs 202 Toolbar im Rich Text Editor verfügbare Icons 110 vom Rich Text Editor modifizieren 110 TYPO3 1-2-3-Install Tool 36 Absicherung nach Installation 37, 41 allgemeine Einstellungen 105 Benutzer anlegen 97 Benutzergruppen anlegen 97 Cache-Einstellungen 153 Caching-Problem 214 die in index.php auskommentieren 35, 41 Grafik-Erzeugung und Cache 153 Install Tool 35 Installation unter Debian GNU/Linux 34 Konfiguration 205 Standard Install Tool 37 Strukturen 212 Übersicht über Seiten-Zugriffsrechte 102 Upload-Limits einstellen 45
Sandini Bib
Stichwortverzeichnis
Zugriffsrechte auf Seiten 100 Zugriffsrechte nach Installation a npassen 35 TYPO3 Element Browser 72 U Überschriften clear.gif als Abstandhalter 171 korrekt mit Header-Tags auszeichnen 171 Menüs als Bereichs- 192 URLs, suchmaschinenfreundliche 218 V Variablen, Abfragen globaler 144 Verknüpfungen 58 Verlaufsliste 68 Verzeichnisse löschen samt Inhalten 87 über numerische Klemmbretter kopieren oder verschieben 89 umbenennen 87 verschieben oder kopieren 87 Zugriffsrechte zum Kopieren 88 Zugriffsrechte zum Löschen 87 Vorschau versteckter und zeitgesteuerter Seiten und Inhalten 94 von zugriffsbeschränkten Seiten und Inhalten 96 zeitgesteuerter Seiten und Inhalte 96 Votum, einrichten mit tt_poll 245
W WAMP Quickstart, Installation unter Windows 15 Websites getrennte Bereiche mit Subdomains 217 neue basierend auf Standard-Templates erstellen 158 Statistiken automatisieren mit AWSTATS 248 Suchmaschinen-Optimierung 215 unterschiedliche Startseiten je nach Domain 217 Windows, Installation von TYPO3 mit WAMP Quickstart 15 X XAMPP, Installation unter Mac OS X 21, 23 Z Zauber-Bilder, über den Rich Text Editor einfügen 70 Zeitsteuerung für Benutzer 104 von Seiten und Inhalten 89f. Zeit-Schnelleingabe 89 Zugriffsrechte auf Seiten in TYPO3 100 auf Seiten in TYPO3, Übersicht 102 korrekt setzen 40 zum Kopieren von Verzeichnisssen 88 zum Löschen von Verzeichnisssen 87
261
Sandini Bib
... aktuelles Fachwissen rund, um die Uhr – zum Probelesen, Downloaden oder auch auf Papier. www.InformIT.de
InformIT.de, Partner von Addison-Wesley, ist unsere Antwort auf alle Fragen der IT-Branche. In Zusammenarbeit mit den Top-Autoren von Addison-Wesley, absoluten Spezialisten ihres Fachgebiets, bieten wir Ihnen ständig hochinteressante, brandaktuelle Informationen und kompetente Lösungen zu nahezu allen IT-Themen.
wenn Sie mehr wissen wollen ...
www.InformIT.de
Sandini Bib
Copyright Daten, Texte, Design und Grafiken dieses eBooks, sowie die eventuell angebotenen eBook-Zusatzdaten sind urheberrechtlich geschützt. Dieses eBook stellen wir lediglich als persönliche Einzelplatz-Lizenz zur Verfügung! Jede andere Verwendung dieses eBooks oder zugehöriger Materialien und Informationen, einschliesslich •
der Reproduktion,
•
der Weitergabe,
•
des Weitervertriebs,
•
der Platzierung im Internet, in Intranets, in Extranets,
•
der Veränderung,
•
des Weiterverkaufs
•
und der Veröffentlichung
bedarf der schriftlichen Genehmigung des Verlags. Insbesondere ist die Entfernung oder Änderung des vom Verlag vergebenen Passwortschutzes ausdrücklich untersagt! Bei Fragen zu diesem Thema wenden Sie sich bitte an:
[email protected] Zusatzdaten Möglicherweise liegt dem gedruckten Buch eine CD-ROM mit Zusatzdaten bei. Die Zurverfügungstellung dieser Daten auf unseren Websites ist eine freiwillige Leistung des Verlags. Der Rechtsweg ist ausgeschlossen. Hinweis Dieses und viele weitere eBooks können Sie rund um die Uhr und legal auf unserer Website
http://www.informit.de herunterladen