PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
php + mysql: bildupload in ext. verzeichnis + bildnamen in datenbank speichern, wie?
Beitrag
<blockquote data-quote="sphinxxx" data-source="post: 1878686" data-attributes="member: 322469"><p><strong>AW: php + mysql: bildupload in ext. verzeichnis + bildnamen in datenbank speichern, w</strong></p><p></p><p>hallo dlogic,</p><p> </p><p>kurz vorweg: euer hinweis bzgl. der schreibrechte war völlig richtig. mein prof. hatte vergessen, das verzeichnis für die bilder mit den entsprechenden rechten zu versehen. allerdings klappt mein script dennoch nicht...zumindest was den bilderupload betrifft. mein prof. meint, er habe nun den usernamen für das bild-verzeichnis (images) geändert. nennen wir den usernamen hier mal xxx. muss xxx denn irgendwo im script eingetragen werden? (xxx ist nicht identlisch mit dem usernamen für die datenbank - das ist aber wohl, denke ich, in dem fall egal, oder?). </p><p> </p><p>hier mein script für das komplette formular mit bilder-upload:</p><p> </p><p>[PHP]</p><p><?php</p><p>if (isset($_POST['tierart']) && isset($_POST['tiername']) && isset($_POST['merkmale']) && $_POST['tierart'] != '' && $_POST['tiername'] != '' && $_POST['merkmale'] != '') {</p><p>try {</p><p>$db = new MySQLi ('Hostname', 'User', 'Passwort', 'Datenbankname');</p><p>$sql = sprintf('INSERT INTO Tiere (Tierart, Tiername, Merkmale) VALUES (\'%s\', \'%s\', \'%s\')',</p><p>$db->real_escape_string($_POST['tierart']),</p><p>$db->real_escape_string($_POST['tiername']),</p><p>$db->real_escape_string($_POST['merkmale']));</p><p>$db->query($sql);</p><p>echo '<p>' . 'Vielen Dank. Ihr Text wurde versendet!' . '<br /><br />' . 'Was m&ouml;chten Sie als n&auml;chstes tun?' . '<br /><br />' . '<a href="index.php">Neuen Text eingeben</a>' . '<br /><br />' . '<a href="../index.html">Zur&uuml;ck zur Startseite</a>' . '</p>';</p><p>} catch (Exception $e) {</p><p>echo 'Fehler' . htmlspecialchars($e->getMessage());</p><p> }</p><p> }</p><p>?></p><p><?php</p><p>$db = @mysql_connect('Hostname', 'User', 'Passwort');</p><p>if (!$db) {</p><p>exit('<p>Verbindungsaufbau zum Datenbankserver ' .</p><p>' zurzeit nicht möglich.</p>');</p><p> }</p><p>// Datenbank auswählen</p><p>if (!@mysql_select_db('Datenbankname')) {</p><p>exit('<p>Auswahl der Tierdatenbank' .</p><p>'zurzeit nicht möglich.</p>');</p><p>}</p><p>$query_tierart = "SELECT Tierart FROM Tiere";</p><p>$tierart = mysql_query($query_tierart) or die(mysql_error());</p><p>$row_tierart = mysql_fetch_assoc($tierart);</p><p>$totalRows_tierart = mysql_num_rows($tierart);</p><p>// Bilder hochladen - File upload</p><p>if (isset($_POST["abschicken"])) {</p><p> $dateiname = $_FILES['dateiname']['name'];</p><p> $tmp_name = $_FILES['dateiname']['tmp_name'];</p><p> if (!isset($dateiname)) {exit;}</p><p> // Definition unterschiedlicher Fehlermeldungen</p><p> if(!is_uploaded_file($tmp_name)) {</p><p> echo 'Fehler!<br><ul>';</p><p> switch ($_FILES['dateiname']['error']) {</p><p> case 1: echo "<li>Die Datei überschreitet die</p><p> maximale Größe von 1 Megabyte.";</p><p> break;</p><p> case 2: echo "<li>Die Datei überschreitet die</p><p> maximale Größe von $_POST[MAX_FILE_SIZE] Bytes.";</p><p> break;</p><p> case 3: echo "<li>Die Datei wurde nur</p><p> teilweise übertragen.";</p><p> break;</p><p> case 4: echo "<li>Sie haben vergessen,</p><p> die zu überspielende Datei anzugeben.";</p><p> break;</p><p> }</p><p> echo "</li></ul>";</p><p> exit;</p><p> }</p><p>// Festlegen des Pfades mit Dateinamen.</p><p> $uploadname ="http://www.URL = Datenbank-Hostname.de/images/$dateiname";</p><p> move_uploaded_file($tmp_name,$uploadname);</p><p> // Ausgabe auf dem Bildschirm zur Bestätigung.</p><p> printf("Die Datei <b>%s</b> befindet sich auf dem Webserver im Ordner</p><p> <b>%s</b>!<br>\n",</p><p> $_FILES['dateiname']['name'], $uploadname);</p><p> printf("Sie ist <b>%s Bytes</b> groß und vom Typ <b>%s</b>.</p><p> <br>\n", $_FILES['dateiname']['size'],</p><p> $_FILES['dateiname']['type']);</p><p> // Einfügen des Datensatzes</p><p> $sql = "insert into Tiere (Tierbild)</p><p> Values ('$dateiname')"</p><p> or die ("SQL-Fehler = ".mysql_error());</p><p> $rs = mysql_query($sql);</p><p> mysql_close($verbindung);</p><p>}</p><p>?></p><p> [/PHP]</p><p> </p><p>was den upload-pfad betrifft, habe ich es auch schon mit den von euch genannten varianten probiert, klappte aber trotzdem nicht.</p><p> </p><p>Hier mein HTML-Formular:</p><p> </p><p>[HTML]</p><p><div id="inhalt"></p><p> <form action="formular.php" method="post" enctype="multipart/form-data"></p><p> <table></p><p> <tr></p><p> <td>Tierart</td></p><p> <td><select name="tierart"><?php do { ?></p><p> <option value="<?php echo $row_tierart['Tierart']; ?>"><?php echo $row_tierart['Tierart']; ?></option></p><p> <?php } while ($row_tierart = mysql_fetch_assoc($tierart)); ?></td></p><p> </tr></p><p> <tr></p><p> <td>Tiername</td></p><p> <td><input type="text" name="tiername" size="30" /></td></p><p> </tr></p><p> <tr></p><p> <td>Merkmale</td></p><p> <td><textarea name="merkmale" cols="30" rows="10"></textarea></td></p><p> </tr></p><p> <tr></p><p> <td><input type="hidden" name="MAX_FILE_SIZE" value="1024"></td></p><p> <td><input type="file" name="dateiname"></td></p><p> </tr></p><p> </table></p><p> <table></p><p> <tr></p><p> <td><input type="hidden" name="abschicken" value="1"></td></p><p> <td><input type="image" name="submit" src="../images/sendebutton.jpg" /></td></p><p> </tr></p><p> </table></p><p> </form></p><p> </div><!-- Ende Inhalt --></p><p>[/HTML]</p><p> </p><p>bitte nicht meckern, wenn das script allzu chaotisch aussieht. bin gerade erst beim erlernen der basics von php... schaffe es daher noch nicht, die aufgaben selbstständig zu lösen.</p><p> </p><p>vielen dank für eure hilfe.</p><p> </p><p>grüße,</p><p> </p><p>lara</p></blockquote><p></p>
[QUOTE="sphinxxx, post: 1878686, member: 322469"] [b]AW: php + mysql: bildupload in ext. verzeichnis + bildnamen in datenbank speichern, w[/b] hallo dlogic, kurz vorweg: euer hinweis bzgl. der schreibrechte war völlig richtig. mein prof. hatte vergessen, das verzeichnis für die bilder mit den entsprechenden rechten zu versehen. allerdings klappt mein script dennoch nicht...zumindest was den bilderupload betrifft. mein prof. meint, er habe nun den usernamen für das bild-verzeichnis (images) geändert. nennen wir den usernamen hier mal xxx. muss xxx denn irgendwo im script eingetragen werden? (xxx ist nicht identlisch mit dem usernamen für die datenbank - das ist aber wohl, denke ich, in dem fall egal, oder?). hier mein script für das komplette formular mit bilder-upload: [PHP] <?php if (isset($_POST['tierart']) && isset($_POST['tiername']) && isset($_POST['merkmale']) && $_POST['tierart'] != '' && $_POST['tiername'] != '' && $_POST['merkmale'] != '') { try { $db = new MySQLi ('Hostname', 'User', 'Passwort', 'Datenbankname'); $sql = sprintf('INSERT INTO Tiere (Tierart, Tiername, Merkmale) VALUES (\'%s\', \'%s\', \'%s\')', $db->real_escape_string($_POST['tierart']), $db->real_escape_string($_POST['tiername']), $db->real_escape_string($_POST['merkmale'])); $db->query($sql); echo '<p>' . 'Vielen Dank. Ihr Text wurde versendet!' . '<br /><br />' . 'Was möchten Sie als nächstes tun?' . '<br /><br />' . '<a href="index.php">Neuen Text eingeben</a>' . '<br /><br />' . '<a href="../index.html">Zurück zur Startseite</a>' . '</p>'; } catch (Exception $e) { echo 'Fehler' . htmlspecialchars($e->getMessage()); } } ?> <?php $db = @mysql_connect('Hostname', 'User', 'Passwort'); if (!$db) { exit('<p>Verbindungsaufbau zum Datenbankserver ' . ' zurzeit nicht möglich.</p>'); } // Datenbank auswählen if (!@mysql_select_db('Datenbankname')) { exit('<p>Auswahl der Tierdatenbank' . 'zurzeit nicht möglich.</p>'); } $query_tierart = "SELECT Tierart FROM Tiere"; $tierart = mysql_query($query_tierart) or die(mysql_error()); $row_tierart = mysql_fetch_assoc($tierart); $totalRows_tierart = mysql_num_rows($tierart); // Bilder hochladen - File upload if (isset($_POST["abschicken"])) { $dateiname = $_FILES['dateiname']['name']; $tmp_name = $_FILES['dateiname']['tmp_name']; if (!isset($dateiname)) {exit;} // Definition unterschiedlicher Fehlermeldungen if(!is_uploaded_file($tmp_name)) { echo 'Fehler!<br><ul>'; switch ($_FILES['dateiname']['error']) { case 1: echo "<li>Die Datei überschreitet die maximale Größe von 1 Megabyte."; break; case 2: echo "<li>Die Datei überschreitet die maximale Größe von $_POST[MAX_FILE_SIZE] Bytes."; break; case 3: echo "<li>Die Datei wurde nur teilweise übertragen."; break; case 4: echo "<li>Sie haben vergessen, die zu überspielende Datei anzugeben."; break; } echo "</li></ul>"; exit; } // Festlegen des Pfades mit Dateinamen. $uploadname ="http://www.URL = Datenbank-Hostname.de/images/$dateiname"; move_uploaded_file($tmp_name,$uploadname); // Ausgabe auf dem Bildschirm zur Bestätigung. printf("Die Datei <b>%s</b> befindet sich auf dem Webserver im Ordner <b>%s</b>!<br>\n", $_FILES['dateiname']['name'], $uploadname); printf("Sie ist <b>%s Bytes</b> groß und vom Typ <b>%s</b>. <br>\n", $_FILES['dateiname']['size'], $_FILES['dateiname']['type']); // Einfügen des Datensatzes $sql = "insert into Tiere (Tierbild) Values ('$dateiname')" or die ("SQL-Fehler = ".mysql_error()); $rs = mysql_query($sql); mysql_close($verbindung); } ?> [/PHP] was den upload-pfad betrifft, habe ich es auch schon mit den von euch genannten varianten probiert, klappte aber trotzdem nicht. Hier mein HTML-Formular: [HTML] <div id="inhalt"> <form action="formular.php" method="post" enctype="multipart/form-data"> <table> <tr> <td>Tierart</td> <td><select name="tierart"><?php do { ?> <option value="<?php echo $row_tierart['Tierart']; ?>"><?php echo $row_tierart['Tierart']; ?></option> <?php } while ($row_tierart = mysql_fetch_assoc($tierart)); ?></td> </tr> <tr> <td>Tiername</td> <td><input type="text" name="tiername" size="30" /></td> </tr> <tr> <td>Merkmale</td> <td><textarea name="merkmale" cols="30" rows="10"></textarea></td> </tr> <tr> <td><input type="hidden" name="MAX_FILE_SIZE" value="1024"></td> <td><input type="file" name="dateiname"></td> </tr> </table> <table> <tr> <td><input type="hidden" name="abschicken" value="1"></td> <td><input type="image" name="submit" src="../images/sendebutton.jpg" /></td> </tr> </table> </form> </div><!-- Ende Inhalt --> [/HTML] bitte nicht meckern, wenn das script allzu chaotisch aussieht. bin gerade erst beim erlernen der basics von php... schaffe es daher noch nicht, die aufgaben selbstständig zu lösen. vielen dank für eure hilfe. grüße, lara [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ★ = 12, ◇ = 4 und die Hälfte von ★ zu ◇ addiert wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
php + mysql: bildupload in ext. verzeichnis + bildnamen in datenbank speichern, wie?
Oben