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

Auslesen, ändern und dann zählen

the_real_at_m

Neues Mitglied
Moin,

ich bins mal wieder, jetzt mit folgendem problem:

Ich lese per mysqli aus einer tabelle IP's aus und finde mit einem tool raus, aus welchem land diese ips stammen, muss diese nun als variable in javascript speichern. zusätzlich muss dann noch gezählt werden wie oft ips aus einem bestimmten land vorhanden sind und das dann hinter dem jeweiligen land in js gespeichert werden.

folglich so:

tabelle -> phpscripts -> js
127.0.0.1 -> DE -> DE ist insgesamt 1x vorhanden -> "DE": 1,

nun habe ich das problem, dass ich aber die ips ja praktisch pro reihe auslese und deren länder festlege, somit kommt beim zählen immer die 1 raus, wie kann ich das beheben?


Code:

http://pastebin.com/uPq1PiBW



hoffe um hilfe, mfg At-M
 
Werbung:
Wo ist da ein Problem?
PHP:
<?php
   $sql = 'SELECT `ip_address` FROM `X` ';
   if(!$result = $db->query($sql))
      die('There was an error running the query [' . $db->error . ']');

   require_once('widgets/IP2Location.php');

   $data = array();

   while($row = $result->fetch_assoc())
   {
     // Standard lookup with no cache
     $loc = new IP2Location('widgets/IP-COUNTRY-SAMPLE.BIN');
     $ip = $row['ip_address'];
     $record = $loc->lookup($ip, IP2Location::ALL);
     $countrycode = $record->countryCode ;
 
     if (isset($data[$countrycode])
        $data[$countrycode]++;
     else
        $data[$countrycode] = 1;
   }

   ksort($data);
  
   foreach ($data as $key => $value)
     echo "$key ist $value mal vorhanden<br />";
?>
 
Werbung:
ich gehe mal stark von einer denkblockade aus :D

Vielen dank! :)

Es funktioniert nun bis auf eine kleinigkeit, undzwar dass er nicht

"DE": 2,"US": 1,

sondern dashier:

"-": 2,"US": 1,

ausgibt, hängt das mit dem eingebundenen iplookup script zusammen?


grüße
 
Keine Ahnung, da hilft wohl nur

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.
 
Zurück
Oben