1 <?xml version=
"1.0" encoding=
"iso-8859-1" ?>
2 <!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
5 <html xmlns=
"http://www.w3.org/1999/xhtml">
7 <title>Versionshistorie
</title>
8 <meta name=
"author" content=
"Patrick Canterino" />
9 <style type=
"text/css">
11 a:link, a:visited, a:active, a:focus
14 text-decoration: none;
17 a:link:hover, a:visited:hover, a:active:hover, a:focus:hover
20 text-decoration: underline;
25 font-family: Verdana, Tahoma, Arial, Helvetica, sans-serif;
28 background-color: #FFFFFF;
32 font-family: 'Courier New', Courier, monospace;
69 <body bgcolor=
"#FFFFFF" text=
"#000000" link=
"#0000FF" vlink=
"#0000FF" alink=
"#0000FF">
71 <h1>Versionshistorie
</h1>
73 <p><b>Neu in Version
3.5</b> (vom
3.3.2012)
</p>
76 <li><b>Individuelle Formularfelder:
</b><br />
77 Es ist nun m
öglich, individuelle Formularfelder zu definieren.
</li>
78 <li><b>E-Mails als Datei abspeichern:
</b><br />
79 <i>Form E-Mail
</i> kann nun die E-Mails nach dem Versenden auch noch auf dem Server als Datei abspeichern.
</li>
80 <li><b><code>$only_post
</code> entfernt:
</b><br />
81 Die Konfigurations-Variable
<code>$only_post
</code> wurde entfernt, da ich dahinter keinen Sinn mehr sehe.
<i>Form E-Mail
</i> kann damit nur noch
über die HTTP-Zugriffsmethode
<tt>POST
</tt> aufgerufen werden.
</li>
82 <li><b>Andere E-Mail-Adressen-
Überpr
üfung:
</b><br />
83 Die E-Mail-Adressen werden jetzt mit den
<a href=
"http://de.php.net/manual/de/book.filter.php" target=
"_blank">Filter-Funktionen
</a> von PHP gepr
üft. Damit f
ällt auch die Konfigurations-Variable
<code>$no_tld
</code> weg.
<br />
84 <i>Form E-Mail
</i> ben
ötigt damit mindestens
<b>PHP
5.2.0</b>, um zu funktionieren!
<b>Ältere PHP-Versionen werden nicht mehr unterst
ützt!
</b></li>
85 <li><b>URL-Vervollst
ändigungscode funktioniert richtig:
</b><br />
86 Der URL-Vervollst
ändigungscode funktioniert nun bei relativen URLs ohne Verzeichnisangabe so, wie es urspr
ünglich gedacht war.
</li>
87 <li><b>Template-Klasse aktualisiert:
</b><br />
88 Die
<a href=
"http://www.patshaping.de/redirector/redirect.php?page=template-class" target=
"_blank">Template-Klasse
</a> wurde auf Version
2.5 aktualisiert.
</li>
89 <li><b>Verschiedene
Änderungen am Quellcode:
</b><br />
90 Es wurden am Quellcode verschiedene
Änderungen durchgef
ührt. Diese sind zwar f
ür den normalen Anwender nicht sichtbar, sollen aber trotzdem erw
ähnt werden:
92 <li>Der Programmierstil wurde ge
ändert.
</li>
93 <li>Es wurden verschiedene Variablenreferenzen aufgel
öst.
</li>
94 <li><code>htmlentities()
</code> wurde durchgehend durch
<code>htmlspecialchars()
</code> ersetzt.
</li>
97 <li><b>Neue Lizenz:
</b><br />
98 <i>Form E-Mail
</i> ist nun unter den Bedingungen der
<a href=
"http://www.opensource.org/licenses/artistic-license-2.0.php">Artistic License
2.0</a> lizenziert.
</li>
101 <p><b>Neu in Version
3.4.1</b> (vom
27.2.2011)
</p>
104 <li><b>Captcha-Probleme bei aktiviertem
<code>register_globals
</code>:
</b><br />
105 Bei aktiviertem
<code>register_globals
</code> war der Captcha-Schutz nutzlos. Es wurde jeder Wert akzeptiert. Danke an Stefan K
örner f
ür den Hinweis!
</li>
106 <li><b>Beispiel-Formular:
</b><br />
107 Es wurde eine Datei beigelegt, die ein Beispiel-Formular zur Nutzung mit
<i>Form E-Mail
</i> darstellt.
</li>
110 <p><b>Neu in Version
3.4</b> (vom
25.1.2009)
</p>
113 <li><b>Captchas:
</b><br />
114 Es ist nun m
öglich, im Mail-Formular sog.
<a href=
"http://de.wikipedia.org/wiki/CAPTCHA">Captchas
</a> anzuzeigen. Es handelt sich hierbei um einen zuf
älligen Text in einem Bild, der in ein Formularfeld eingegeben werden muss, um das Formular zu versenden.
</li>
115 <li><b>Copyright und Lizenz:
</b><br />
116 Im Kopf der PHP-Dateien befindet sich nun eine Copyright-Angabe sowie ein Hinweis, dass f
ür
<i>Form E-Mail
</i> die Artistic License
1.0 gilt.
</li>
119 <p><b>Neu in Version
3.3a
</b> (vom
14.4.2007)
</p>
122 <li><b><code>date_default_timezone_set()
</code> unter PHP
4:
</b><br />
123 Unter PHP
4 existiert
<code>date_default_timezone_set()
</code> nicht, weshalb
<i>Form E-Mail
</i> dort nicht lauff
ähig war. Jetzt wird vor der Anwendung dieser Funktion gepr
üft, ob sie auch existiert.
</li>
126 <p><b>Neu in Version
3.3</b> (vom
11.4.2007)
</p>
129 <li><b>Umgebungsvariablen im Mailtext:
</b><br />
130 Man kann jetzt Server-Umgebungsvariablen im Mailtext unterbringen. Welche Variablen das sein d
ürfen, l
ässt sich über das neue Konfigurations-Array
<code>$allowed_envs
</code> festlegen. In der Mail-Template kann man dann Variablen unterbringen, die mit
<code>ENV_
</code> beginnen und dann durch die entsprechende Umgebungsvariable ersetzt werden.
</li>
131 <li><b>Zeichensatz konfigurierbar:
</b><br />
132 Der Zeichensatz, mit dem die Mails codiert werden, kan nnun durch die neue Konfigurationsvaraible
<code>$charset
</code> eingestellt werden.
</li>
133 <li><b>Zeitzonen konfigurierbar:
</b><br />
134 Neuere Versionen von PHP geben immer (bei entsprechender Einstellung zumindest) eine Fehlermeldung aus, wenn keine Standard-Zeitzone definiert wurde.
<i>Form E-Mail
</i> definiert jetzt als Standard-Zeitzone
<tt>Europe/Berlin
</tt>, das l
ässt sich aber durch die neue Konfigurationsvariable
<code>$timezone
</code> beliebig anpassen.
</li>
135 <li><b>Template-Klasse aktualisiert:
</b><br />
136 Die
<a href=
"http://www.patshaping.de/redirector/redirect.php?page=template-class" target=
"_blank">Template-Klasse
</a> wurde auf die aktuelle Version
2.0 aktualisiert. Von den neuen Methoden wird Gebrauch gemacht.
</li>
137 <li><b><i>patShaping
</i> gestrichen:
</b><br />
138 Im Mailheader und in den Kopfkommentaren der Scripts steht jetzt nur noch
<i>Form E-Mail
</i>, das Wort
<i>patShaping
</i> wurde entfernt.
</li>
141 <p><b>Neu in Version
3.2.2</b> (vom
9.6.2006)
</p>
144 <li><b>Zeilenumbr
üche ersetzen:
</b><br />
145 S
ämtliche Zeilenumbr
üche im Header und im Text der E-Mail werden nun durch die Zeilenumbruchsfolge des Betriebssystems ersetzt, um Anzeigeprobleme in manchen E-Mail-Programmen (z.B. bei
<i>The Bat!
</i>) zu beheben (eigentlich sind es keine Probleme, die Zeilenumbr
üche werden so dargestellt, wie das Programm sie zu Gesicht bekommt).
</li>
146 <li><b>Anderer Statuscode bei Redirect nach Versand:
</b><br />
147 Wenn nach dem Versand einer E-Mail ein Redirect ausgel
öst werden soll, wird nun der Status-Code
<tt>303</tt> an den Client zur
ückgegeben, damit dieser mit
<tt>GET
</tt> auf die URL zugreift.
</li>
148 <li><b><code>{}
</code> vs.
<code>[]
</code>:
</b><br />
149 Eigentlich planten ja die PHP-Entwickler, dass man mit
<code>{}
</code> auf einzelne Zeichen einer Zeichenkette zugreifen kann und
<code>[]
</code> nicht mehr verwendet werden soll. Da das aber keiner gemacht hat, soll
<code>{}
</code> in PHP
6 wieder rausfliegen (siehe
<a href=
"http://www.php.net/~derick/meeting-notes.html#cleanup-for-vs" target=
"_blank">http://www.php.net/~derick/meeting-notes.html#cleanup-for-vs
</a>) und man soll wieder
<code>[]
</code>.
<i>Form E-Mail
</i> wurde entsprechend angepasst, die
Änderung nach
<code>{}
</code> war ohnehin unvollst
ändig.
</li>
152 <p><b>Neu in Version
3.2.1</b> (vom
18.6.2005)
</p>
155 <li><b>Keine
"Notices
" mehr:
</b><br />
156 <i>Form E-Mail
</i> sollte nun auch ordnungsgem
äß funktionieren, wenn f
ür
<code>error_reporting
</code> der Wert
<code>E_ALL
</code> eingestellt wurde.
</li>
157 <li><b>Template-Klasse aktualisiert:
</b><br />
158 Die
<a href=
"http://www.patshaping.de/redirector/redirect.php?page=template-class" target=
"_blank">Template-Klasse
</a> wurde auf Version
1.5a aktualisiert.
</li>
159 <li><b>Verschiedene
Änderungen:
</b><br />
160 Es wurden verschiedene kleine
Änderungen durchgef
ührt:
162 <li>Die Funktion
<code>sizeof()
</code> wurde durch
<code>count()
</code> ersetzt.
<code>sizeof()
</code> ist n
ämlich ein Alias -
und von der Verwendung von Aliasen wird abgeraten.
</li>
163 <li>PHP bietet aus Gr
ünden der Abw
ärtskompatibilit
ät an, auf einzelne Zeichen einer Zeichenkette wie auf die Elemente eines Arrays zuzugreifen. Das wird jetzt nicht mehr gemacht, stattdessen wird die moderne Variante mit geschweiften Klammern verwendet.
</li>
164 <li>Wo es angebracht war, wurden doppelte Anf
ührungszeichen durch einfache ersetzt.
</li>
169 <p><b>Neu in Version
3.2</b> (vom
29.8.2004)
</p>
172 <li><b>Redirect nach Versand:
</b><br />
173 <i>Form E-Mail
</i> l
ässt sich jetzt wahlweise so einstellen, dass es nach dem Versand der Mail per HTTP-Redirect auf eine andere Seite umleitet.
<br />
174 <b style=
"color:#FF0000">Achtung:
</b> Ich habe zwar etwas eingebaut, was hier relative URLs in absolute umwandelt, um dem HTTP-Standard gerecht zu werden, aber ich garantiere nicht, dass diese Umwandlung immer einwandfrei funktioniert. Seien Sie bei relativen URLs also sehr vorsichtig und verwenden Sie im Fehlerfall absolute.
</li>
175 <li><b>Maximall
ängen:
</b><br />
176 Zus
ätzlich zu den Mindestl
ängen aus Version
3.1 lassen sich f
ür Name, Betreff und Text auch Maximall
ängen angeben.
</li>
177 <li><b>Absender-Adressen ohne Top-Level-Domain:
</b><br />
178 Wenn man die neue Option
<code>$no_tld
</code> auf
"1" setzt, kann man nun als Absender auch eine E-Mail-Adresse angeben, die keine Top-Level-Domain hat.
</li>
179 <li><b>Konfiguration abgespalten:
</b><br />
180 Die Konfigurationsvariablen wurden in die Datei
<i>config.php
</i> ausgelagert, was f
ür etwas mehr
Übersicht sorgt.
</li>
181 <li><b>Template-Klasse aktualisiert:
</b><br />
182 Die
<a href=
"http://www.patshaping.de/redirector/redirect.php?page=template-class" target=
"_blank">Template-Klasse
</a> wurde auf die aktuelle Version
1.3 aktualisiert.
</li>
183 <li><b>Kleine Korrekturen:
</b><br />
184 Am Quelltext wurden kleinere Korrekturen vorgenommen.
</li>
187 <p><b>Neu in Version
3.1</b> (vom
20.1.2004)
</p>
190 <li><b>Immer noch Bug in E-Mail-Adressen-
Überpr
üfung:
</b><br />
191 Der regul
äre Ausdruck, der die E-Mail-Adressen auf syntaktische G
ültigkeit
überpr
üft, war immer noch fehlerhaft. Es gab immer noch E-Mail-Adressen, die das Script
überlasten konnten.
</li>
192 <li><b>Mindestl
ängen:
</b><br />
193 Es ist jetzt m
öglich, f
ür Name, Betreff und Text Mindestl
ängen anzugeben.
</li>
194 <li><b>Alias-Empf
änger:
</b><br />
195 Es ist nun m
öglich,
über die Formulardaten einen einer oder mehreren Adressen zugeordneten Wert an
<i>Form E-Mail
</i> zu
übergeben. An die dem Wert zugeordneten Adressen wird die Mail dann gesendet.
</li>
196 <li><b>Template-Klasse:
</b><br />
197 <i>Form E-Mail
</i> verwendet nun auch die
<a href=
"http://www.patshaping.de/redirector/redirect.php?page=template-class" target=
"_blank">Template-Klasse
</a>. Das sorgt f
ür
Übersicht und f
ür eine bessere Erweiterbarkeit.
</li>
200 <p><b>Neu in Version
3.0</b> (vom
1.9.2003)
</p>
203 <li><b>Komplett neu programmiert:
</b><br />
204 <i>Form E-Mail
3.0</i> wurde von Grund auf neu programmiert, damit m
öglichst viele Fehler, die ich anfangs machte (
<i>Form E-Mail
</i> war eines meiner ersten Scripts) ausgemerzt werden konnten.
</li>
205 <li><b><code>$friendly_sender
</code> erweitert:
</b><br />
206 Die Option
<code>$friendly_sender
</code> kann jetzt den Wert
"2" annehmen. Dadurch erscheint zus
ätzlich der Name des Absenders im E-Mail-Programm. Sollte der Name Zeichen enthalten, die nicht aus dem ASCII-Zeichensatz stammen, wird er mit Base64 codiert (s.u.).
</li>
207 <li><b>Betreffcodierung erneuert:
</b><br />
208 Die Betreffcodierung arbeitet nun hoffentlich endlich zuverl
ässig, da sie nun Base64 verwendet. Mit der urspr
ünglichen Quoted-Printable-Codierung gab es Probleme.
</li>
209 <li><b>Mehrere Empf
änger:
</b><br />
210 Es ist nun m
öglich, mehrere Empf
änger f
ür die Mail anzugeben.
</li>
211 <li><b>Referer-
Überpr
üfung:
</b><br />
212 Der HTTP-Referer (also sozusagen die Seite, von der das Script aufgerufen wurde) kann nun auf Wunsch einem einfachen Test unterzogen werden: Wenn sich die Host-Angabe nicht in einer im Script definierten Positiv-Liste befindet, wird
<i>Form E-Mail
</i> mit einer Fehlermeldung beendet. Das ist n
ützlich, um daf
ür zu sorgen, dass
<i>Form E-Mail
</i> nicht von fremden Homepages ausgenutzt wird.
</li>
213 <li><b>Auf Wunsch nur
<tt>POST
</tt>:
</b><br />
214 <i>Form E-Mail
</i> l
ässt sich mit der neuen Option
<code>$only_post
</code> so einstellen, dass es nur mit der HTTP-Zugriffsmethode
<tt>POST
</tt> aufgerufen werden kann.
</li>
215 <li><b>Vorlagen:
</b><br />
216 Es wird nun mit Vorlagen gearbeitet. So kann man jetzt den Text der Mail mit einer Vorlage steuern und die Formularfelder bei einem Fehler mit den bereits eingegebenen Daten vorbelegen lassen.
</li>
217 <li><b>Neue Zeitformatierung:
</b><br />
218 Die Uhrzeit wird nun mit
<code>strftime()
</code> formatiert, was mehr Freiheiten zul
ässt. Leider gibt es hier bei neueren PHP-Versionen Probleme, da die Wochentage und Monatsnamen trotz deutscher Spracheinstellungen englisch werden.
</li>
221 <hr width=
"80%" noshade=
"noshade" />
223 <p align=
"center">Die Liste der
Änderungen bis zur Version
3.0 finden Sie auf der
<a href=
"http://www.patshaping.de/redirector/redirect.php?page=form-email"><i>Form E-Mail
</i>-Infoseite
</a>!
</p>
225 <hr width=
"80%" noshade=
"noshade" />
227 <p><a href=
"readme.htm">ReadMe-Datei
</a></p>
229 <hr width=
"80%" noshade=
"noshade" />
231 <p style=
"font-size:8pt">© 2002-
2012 Patrick Canterino
</p>
233 <table border=
"0" cellspacing=
"0" style=
"font-size:8pt">
236 <td><a href=
"http://www.patshaping.de/" target=
"_blank">http://www.patshaping.de/
</a></td>
240 <td><a href=
"mailto:patrick@patshaping.de">patrick@patshaping.de
</a></td>