• Jetzt anmelden. Es dauert nur 2 Minuten und ist kostenlos!

Suchmaschine mit MySQL

Joma

Neues Mitglied
Hallo,
Ich probiere momentan anhand eines Tutorials
eine Suchmaschine mit MySQL und PHP zu programmieren. Mein Code weicht etwas vom Originalcode im Video ab, da ich auf die Verlinkungsmethode im Video verzichte und stattdessen meine HTML bzw. PHP Seiten klassich ohne PHP verlinkt habe (also statt z.B. ?page=test einfach nur test; ist doof zu erklären :)).

Das konkrete Problem, dass ich habe, liegt darin, dass der Begriff, welcher in den Input eingegeben wird, nicht als Variable abgespeichert wird (dass habe ich daran erkannt, dass der Code bei der betroffenen Variable, wenn ich sie in einen echo Befehl schreibe, nichts ausgibt).

Anschließend werde ich nun die Codes meiner index.php, search.php und connect.php hinterlegen.

index.php
HTML:
<!doctype html>
<html>

<head>
    <title>test</title>
</head>

<body>

<header>
<img src="img/logo.jpg" alt="logo" id="logo" />

<!-- SUCHE -->
<div id="searchform">
   <form action="search.php" method="get">
   <input type="text" placeholder="suchen..." name="search" id="suchbegriff" />
   <input type="submit" id="search_submit" value="suchen" />
   </form>
</div>

<nav>
<ul>
<a href="#">startseite</a><br /> <!-- Links sind bis jetzt absichtlich tot gelassen -->
<a href="#">archiv</a><br />
</ul>
</nav>
</header>
<div id="content">
<h1>Lorem ipsum</h1>
<h2>19.09.2014</h2>
<p>bla</p>
</div>

</body>
</html>

search.php
HTML:
<!doctype html>
<html>

<head>
    <title>test</title>
</head>

<body>

<header>
<img src="img/logo.jpg" alt="logo" id="logo" />

<!-- SUCHE -->
<div id="searchform">
   <form action="search.php" method="get">
   <input type="text" placeholder="suchen..." name="search" id="suchbegriff" />
   <input type="submit" id="search_submit" value="suchen" />
   </form>
</div>

<nav>
<ul>
<a href="#">startseite</a><br /> <!-- Links sind bis jetzt absichtlich tot gelassen -->
<a href="#">archiv</a><br />
</ul>
</nav>
</header>
<div id="content">

<?php
    require_once("connect.php");
    $keywords = $_POST["search"];
    $query = mysql_query("SELECT * from search WHERE keywords like '%".$keywords."%' or title like '%".$keywords."%'");
    echo 'Ihre Suche nach <i>'.$keywords.'</i> ergab:<br/>';
    while($d = mysql_fetch_assoc($query)) {
        echo '<fieldset><legend><a href="http://bla.com/projects/seite/'.$d['link'].'">'.$d['title'].'</a></legend>'.$d["description"].'</fieldset>';
    }
?>

</div>
</body>
</html>

connect.php

PHP:
<?php
$hs = "db1234567890.db.1and1.com";
$us = "db1234567890";
$ps = "passwort";
$db = "db1234567890";

mysql_connect($hs, $us, $ps);
mysql_select_db($db);
?>

Ich habe den Macher des Videos bereits angeschrieben, jedoch bis jetzt keine Antwort erhalten.

Vielen Dank im Voraus!
 
Werbung:
ok, jetzt wird die variable ausgeben. trotzdem zeigt er mir trotz richtig eingegebener stichworte kein ergebnis an
 
Werbung:
search.php
PHP:
<?php
    require_once("connect.php");
    $keywords = $_GET["search"];
    $query = mysqli_query("SELECT * from search WHERE keywords like '%".$keywords."%' or title like '%".$keywords."%'");
    echo 'Ihre Suche nach <i>'.$keywords.'</i> ergab:<br/>';
    while($d = mysqli_fetch_assoc($query)) {
        echo '<fieldset><legend><a href="http://bla.com/projects/seite/'.$d['link'].'">'.$d['title'].'</a></legend>'.$d["description"].'</fieldset>';
    }
?>

connect.php
PHP:
<?php
$hs = "bla";
$us = "bla";
$ps = "bla";
$db = "bla";

mysqli_connect($hs, $us, $ps);
mysqli_select_db($db);
?>

ich erhalte immernoch denselben fehler wie zuvor
 
Siehe http://de1.php.net/mysqli_query

Richtig debuggen

1. Man bemerkt, dass ein Skript nicht das tut, was es soll.
2. Man schreibt an den Anfang des Scriptes die Zeile: error_reporting(-1);
3. Man verwendet ini_set('display_errors', true); damit die Fehler auch angezeigt werden.
4. Man versucht, die Stelle die daran Schuld sein kann, schonmal einzugrenzen. Falls dies nicht geht, wird zunächst das komplette Skript als fehlerhaft angesehen.
5. An markanten Stellen im Skript lässt man sich wichtige Variableninhalte ausgeben und ggf. auch in bedingten Anweisungen eine kurze Ausgabe machen, um zu überprüfen, welche Bedingung ausgeführt wurde. Wichtig bei MySQL Fehlern (...not a valid MySQL result resource...): mysqli_error() verwenden oder Abfrage ausgeben und zb mit phpmyadmin testen.
6. Schritt 5 wird so lange wiederholt, bis Unstimmigkeiten im Skript auffallen
7. Damit hat man das Problem (Unstimmigkeit) gefunden und kann versuchen diese zu beheben. Hierzu dienen dann die PHP-Dokumentation und andere Quellen als Ratgeber.
8. Lässt sich das konkrete Problem trotzdem nicht beheben, kann man in Foren um Rat fragen.
9. Das Programm läuft und man kann die Debug-Ausgaben wieder entfernen.
 
Werbung:
Danke für die Anleitung, habe die connect.php soweit gefixt:
PHP:
<?php
$hs = "bla";
$us = "bla";
$ps = "bla";
$db = "bla";
$link = mysqli_connect($hs, $us, $ps);
mysqli_select_db($link, $db);
?>

EDIT: Bei der search.php habe ich nun noch zwei Fehler in Zeile 4 und 6.
 
Zurück
Oben