Einfaches News-Script
Das hier ist ein kleines Tutorial, um zu zeigen wie so ein News-Script aussehen kann. Im Grunde ist es nichts anderes als ein Gästebuch, in welches jedoch nur der Webmaster (oder sonstige authorisierte Personen) etwas eintragen kann. Natürlich kann man
2014-01-03 01:16:31 2014-01-03 01:16:31 pik
- eine Ausgabeseite (im Beispiel start.php)
- eine Formularseite (im Beispiel newsform.html)
- eine Seite zum Auswerten der Formulareingaben (im Beispiel newsneu.php)
Kommen wir nun zur newsform.html:
Ein gewöhnliches Formular mit Betreff, dem Verfasser und Eintrag.
1
2 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
3 <html>
4 <head>
5 <title>News schreiben</title>
6 <link rel="stylesheet" href="css/main.css">
7 </head>
8 <body>
9 <form action="newsneu.php" method="post">
10 <table id="news_tab">
11 <tr>
12 <td>Betreff</td>
13 <td>Eintrag</td>
14 </tr>
15 <tr>
16 <td id="input"><input type="text" name="betreff" id="inputarea" maxlength="30"></td>
17 <td id="textarea" rowspan="3"><textarea name="text" id="area" cols="40" rows="10" ></textarea></td>
18 </tr>
19 <tr>
20 <td>Absender</td>
21 </tr>
22 <tr>
23 <td id="verfasser"><p id="verfasserradio"><input type="radio" name="verfasser" value="Webmaster" checked>Webmaster<br>
24 <input type="radio" name="verfasser" value="Max Mustermann">Max Mustermann<br>
25 <input type="radio" name="verfasser" value="Gerold Gelb">Gerold Gelb<br>
26 <input type="radio" name="verfasser" value="Rosa Rot">Rosa Rot</p>
27 </td>
28 </tr>
29 <tr>
30 <td id="button1"><input type="submit" name="submit" value="News eintragen"></td>
31 <td id="button2"><input type="reset" name="reset" value="Abbrechen"></td>
32 </tr>
33 </table>
34 </form><br>
35 <div id="info">Info: Lassen Sie den Betreff und das Textfeld frei, um den Inhalt der Textdatei zu löschen</div>
36 </body>
37 </html>
38
Nun, die HTML-Seite war bestimmt nicht so schwer :) Kommen wir zu unserer newsneu.php, wo wir unsere Daten auswerten.
Jetzt wird es etwas schwerer:
1
2 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
3 <html>
4 <head>
5 <title>Auswerten</title>
6 <link rel="stylesheet" href="css/main.css">
7 </head>
8 <body>
9 <?php
10 error_reporting(E_ALL);
11 # Wenn der Submit-Button nicht gedrückt wurde, wird man automatisch
12 # auf die start.php weitergeleitet.
13 if(!isset($_POST['submit']))
14 {
15 header('location: start.php');
16 exit;
17 }
18 else
19 {
20 # Festlegung der Variablen aus dem POST-Formular
21 $betreff = $_POST['betreff'];
22 $betreff = htmlentities($betreff);
23 $betreff = strtoupper($betreff);
24 $text = $_POST['text'];
25 $text = htmlentities($text);
26 $text = str_replace("n", "<br>", $text);
27 $verfasser = $_POST['verfasser'];
28 $datum = date("d.m.Y");
29 $zeit = date("H:i");
30 # Die Variable $eintrag besteht aus den nachfolgenden Variablen
31 $eintrag = "$betreff|$text|$verfasser|$datum|$zeit";
32 if($text == "")
33 {
34 $datei = fopen("news.txt", "w+");
35 fwrite($datei, $eintrag);
36 fclose($datei);
37 echo "<p id="phplink">Der Inhalt wurde gelöscht.<br><a href="start.php" id="phpref">Zurück zur Webseite!</a></p>";
38 }
39 else
40 {
41 # Die Datei, die als Datenbank dient, wird geöffnet
42 # $eintrag wird geschrieben
43 $datei = fopen("news.txt", "w+");
44 fwrite($datei, $eintrag);
45 fclose($datei);
46 echo "<p id="phplink">Der Eintrag wurde gespeichert.<br><a href="start.php" id="phpref">Zurück zur Webseite!</a></p>";
47 }
48 }
49 ?>
50 </body>
51 </html>
52
Zuerst deklarieren wir unsere Variablen, die wir zur weiteren Verarbeitung benötigen.
Mit htmlentities() werden alle Sonderzeichen und HTML-Tags in den dafür vorgesehenen HTML-Code umgewandelt.
Mit strtoupper() erzwingen wir, dass der Betreff komplett groß geschrieben wird.
Mit str_replace() erzeugen wird einen Zeilenumbruch aus n, der bei der späteren Ausgabe in HTML als Zeilenumbruch ausgegeben wird. Alles Weitere steht in den PHP-Kommentaren.
Unsere Daten wurde übernommen, in die Variable $eintrag gespeichert und in die Textdatei $datei geschrieben. Getrennt sind die einzelnen Werte durch den "|" und spielt eine kleine Rolle später bei der Ausgabe.
Wir sind schon fast fertig. Alles was wir machen müssen, nur noch die Datei auslesen und auf den Bildschirm bringen.
Den folgenden Code schreiben wir in unsere start.php
1
2 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
3 <html>
4 <head>
5 <title>Startseite</title>
6 <link rel="stylesheet" href="css/main.css">
7 </head>
8 <body>
9 <div id="news">
10 <?php
11 error_reporting(E_ALL);
12 # Auslesen der Textdatei
13 $eintrag = file("news.txt");
14 # $eintrag wird als $anzeige definiert
15 # $anzeige wird als $teile definiert
16 # $teile werden in einen Array geteilt
17 foreach($eintrag as $anzeige)
18 {
19 $anzeige = stripslashes($anzeige);
20 $teile = explode("|", $anzeige);
21 }
22 if($teile[1] == "")
23 {
24 echo "<p id="phpp">Keine Neuigkeiten vorhanden!</p>";
25 }
26 else
27 {
28 echo "<table id="phptab">
29 <tr>
30 <td id="phptd">$teile[0] <br> von $teile[2], am $teile[3], $teile[4] Uhr</td>
31 </tr>
32 <tr>
33 <td id="phptdt">$teile[1]</td>
34 </tr>
35 </table>";
36 }
37 ?>
38 </div>
39 <div id="link"><a href="newsform.html"><button type="button" value="News eintragen" name="news">News eintragen</button></a></div>
40 </body>
41 </html>
42
Wir lesen unsere Datei in die Variable $eintrag ein. Die Variable $eintrag wird nun in einen Array umgewandelt und heißt $anzeige. Mit explode() geben wir an, mit welchem Trennzeichen wir die in der Textdatei eingetragenen Daten teilen. Nun ist $teile ein Array:
$teile[0] = Betreff
$teile[1] = Eintrag
$teile[2] = Verfasser
$teile[3] = Datum
$teile[4] = Uhrzeit
Somit haben wir unsere Textdatei ausgelesen, die einzelnen Werte in einen Array geschrieben.
Und so einfach kann ein News-Bereich erstellt werden.
Ich hoffe, dieses Script konnte euch eine Hilfestellung bieten. Jetzt könnt ihr den Code wie euch lieb ist verändern und anpassen.
Die CSS-Datei darf natürlich nicht fehlen.
@charset "ISO-8859-1"; body { font-family: Calibri; background-color: #000000; color: white; } #news { margin: 0; padding: 0; width: 450px; min-height: 200px; border-top: 1px solid #FFFFFF; border-bottom: 1px solid #FFFFFF; border-left: 0; border-right: 0; text-align: center; } #phpp { color: #FFFFFF; font-weight: bold; text-align: center; } #phptab { width: 100%; text-align: center; } #phptd { background-color: #FFFFFF; font-weight: bold; color: #000000; } #news_tab { margin: 0; padding: 0; width: 39%; height: auto; border-top: 1px solid #FFFFFF; border-bottom: 1px solid #FFFFFF; border-left: 0; border-right: 0; text-align: center; } #info { width: 39%; border: 1px solid #FF0000; color: #FF0000; text-decoration: none; text-align: center; } #input,#textarea,#verfasser { vertical-align: top; } #inputarea,#area { border: 1px solid #FFFFFF; } #area { resize: none; } #verfasserradio { text-align: left; margin-left: 100px; } td { width: 400px; } #phplink { color: #FFFFFF; font-weight: bold; text-align: center; } #phpref { text-decoration: none; color: #FFFFFF; } #phplink a:hover { text-decoration: underline; color: #C6C6C6; }
Related topics
Counter auf MySQL Basis
Neben der Möglichkeitet, einen Counter per Textfiles zu programmieren, besteht auch die Möglichkeit, MySQL zu verwenden. ...
Autor :
Lukas Beck
Category:
PHP-Tutorials
Umfragenscript
Dieses Tutorial zeigt wie man mit eine Umfragescript mit einen TXT-Datenbank erstellen kann. ...
Autor :
kiliandreissig@
Category:
PHP-Tutorials
PHP-Scripte offline testen unter Windows
Wenn Sie sich schon mit der Erstellung von dynamischen Websiten beschäftigt haben, wissen Sie vielleicht wie umständlich es ist, die Scripte immer auf den Server Ihres Hosters zu laden um diese testen zu können. ...
Autor :
webmaster116@
Category:
Linux & Server Tutorials
Webseite empfehlen
PHP ermöglicht es dem Besucher mit Hilfe der eigenen mail() Funktion mit wenig Aufwand die eigene Webseite Bekannten oder Freunden weiterzuempfehlen ...
Autor :
Lukas Beck
Category:
PHP-Tutorials
Definition of stored procedures - an introduction
Stored procedures are predefined SQL code blocks that are stored in a database and can be called up as required. ...
Autor :
ebiz-consult GmbH & Co. KG
Category:
mySQL-Tutorials
Konfiguration eines Linux-Rechners als DSL-Router
Dieser Artikel beschreibt wie man unter LINUX einen DSL-Rooter für Windows konfiguriert. ...
Autor :
tschiesser@
Category:
Linux & Server Tutorials