0

以下のコードで親切に助けてください。ボタンをクリックすると、場所の名前の緯度と経度が取得されます。しかし、最近、それは機能していません。「住所 x のジオコーディングに失敗しました。ステータスを受け取りました」と出力されます。x は指定された住所であり、ステータス コードは指定されていないことに注意してください。

    $id=$_REQUEST['id'];
    define("MAPS_HOST", "maps.googleapis.com");
    define("KEY", "xxxxxxx");

    $query = "SELECT * FROM markers WHERE mid = $id LIMIT 1";
    $result = mysql_query($query);
    if (!$result) {
      die("Invalid query: " . mysql_error());
    }

    // Initialize delay in geocode speed
    $delay = 0;
    $base_url = "http://" . MAPS_HOST . "/maps/api/geocode/xml?address=";

    if($row = @mysql_fetch_assoc($result)){
     $geocode_pending = true;
     $address = $row["address"];
     while ($geocode_pending) {
     $request_url = $base_url . urlencode($address) . "&sensor=false&key=" . KEY;
        $xml = simplexml_load_file($request_url) or die("url not loading");

        $status = $xml->Response->Status->code;
        if (strcmp($status, "200") == 0) {
          // Successful geocode
          $geocode_pending = false;
          $coordinates = $xml->Response->Placemark->Point->coordinates;
          //$coordinatesSplit = split(",", $coordinates);
          // Format: Longitude, Latitude, Altitude
          //$lat = $coordinatesSplit[1];
          //$lng = $coordinatesSplit[0];
          list($lat,$lng) = explode(",",$coordinates);
          $query = sprintf("UPDATE markers " .
                 " SET lat = '%s', lng = '%s' " .
                 " WHERE mid = '%s' LIMIT 1;",
                 mysql_real_escape_string($lng),
                 mysql_real_escape_string($lat),
                 mysql_real_escape_string($id));
          $update_result = mysql_query($query);
          if (!$update_result) {
            die("Invalid query: " . mysql_error());
          }else{
                echo "$lat;$lng";
          }
        } else if (strcmp($status, "620") == 0) {
          // sent geocodes too fast
          $delay += 100000;
        } else {
          // failure to geocode
          $geocode_pending = false;
          echo "Address " . $address . " failed to geocode. ";
          echo "Received status " . $status . "
    \n";
        }
        usleep($delay);
     }
    }
4

1 に答える 1