Как получить страну в соответствии с определенным IP?

голоса
57

Кто-нибудь знает простой способ извлечения страны для данного IP-адреса? Предпочтительно в формате ISO_3166-1?

Задан 04/08/2008 в 06:15
источник пользователем
На других языках...                            


14 ответов

голоса
38

Есть два подхода: с помощью Интернета-службу и с помощью какого-то локального списка (возможно, завернутого в библиотеке). То, что вы хотите, будет зависеть от того, что вы строите.

За услуги:

Для списков:

Ответил 15/09/2008 в 20:45
источник пользователем

голоса
35

Много людей (в том числе и моей компании), кажется, используют Maxmind GeoIP.

Они имеют бесплатную версию керамзита , которая не является столь же точным , как платную версию, но если вы только после того, как что - то простое, что может быть достаточно хорошим.

Ответил 04/08/2008 в 07:26
источник пользователем

голоса
10

Вот хороший бесплатный сервис с открытым API: http://www.hostip.info/use.html

Ответил 04/08/2008 в 06:21
источник пользователем

голоса
8

ipinfodb предоставляет бесплатную базу данных и API для IP в стране , и наоборот. Они используют свободные данные из MaxMind. Данные обновляется каждый месяц, и это отличная бесплатная альтернатива с приличной точностью.

Ответил 13/01/2010 в 14:13
источник пользователем

голоса
5

Я не знаю, насколько точны, что hostip.info сайт. Я просто посещаемый этот сайт, и он сообщил, что моя страна Канада. Я нахожусь в США и ISP, который использует мой офис работает только в США. Это действительно позволяет исправить это предположение, но если вы используете эту услугу, чтобы отслеживать Vistors веб-сайт по стране, вы не будете иметь никакого способа знать, если данные верны. Конечно, я только один пункт данных. Я скачал базу данных GeoLite Страна, которая является просто .csv файл, и мой IP-адрес был правильно идентифицирован как США.

Еще одно преимущество линейки MaxMind (платного или бесплатного) является то, что у вас есть данные, вы не понести потери производительности изготовления службы вызова веб-другую систему.

Ответил 04/08/2008 в 15:02
источник пользователем

голоса
2

Вы можете использовать мою службу, http://ipinfo.io , для этого. API возвращает целую кучу различных деталей о качестве IP - адреса:

$ curl ipinfo.io/8.8.8.8
{
  "ip": "8.8.8.8",
  "hostname": "google-public-dns-a.google.com",
  "loc": "37.385999999999996,-122.0838",
  "org": "AS15169 Google Inc.",
  "city": "Mountain View",
  "region": "CA",
  "country": "US",
  "phone": 650
}

Если вы только после того, как код страны, вам просто нужно добавить / страну к URL-адресу:

$ curl ipinfo.io/8.8.8.8/country
US

Вот общая функция PHP вы можете использовать:

function ip_details($ip) {
    $json = file_get_contents("http://ipinfo.io/{$ip}");
    $details = json_decode($json);
    return $details;
}

$details = ip_details("8.8.8.8");

echo $details->city;     // => Mountain View
echo $details->country;  // => US
echo $details->org;      // => AS15169 Google Inc.
echo $details->hostname; // => google-public-dns-a.google.com

Я использовал IP 8.8.8.8 в этих примерах, но если вы хотите детали для IP пользователя просто передать $_SERVER['REMOTE_ADDR']вместо этого. Более подробная информация доступна на http://ipinfo.io/developers

Ответил 26/08/2014 в 05:49
источник пользователем

голоса
2

Попробуйте этот код PHP

  <?php  $ip = $_SERVER['REMOTE_ADDR'];
    $json = file_get_contents("http://api.easyjquery.com/ips/?ip=".$ip."&full=true");
    $json = json_decode($json,true);
    $timezone = $json[localTimeZone];?>
Ответил 30/07/2012 в 09:07
источник пользователем

голоса
2

Вы можете использовать решение , предусмотренное этот вопрос .

Но она возвращает код страны 2 цифры.

Ответил 19/10/2011 в 15:04
источник пользователем

голоса
2

Google, clientlocation возвращает ( мой пример )

latlng = new google.maps.LatLng(google.loader.ClientLocation.latitude, google.loader.ClientLocation.longitude);
location = "IP location: " + getFormattedLocation();
document.getElementById("location").innerHTML = location;
Ответил 13/01/2010 в 14:25
источник пользователем

голоса
2

Наиболее точным является Digital Elements NetAcuity ... не бесплатно , но вы получите то , что вы платите за большую часть времени .... Digital Element

Ответил 27/09/2008 в 04:04
источник пользователем

голоса
1

Вы можете использовать веб-сервис API, которые делают эту работу, как:

see example of service: http://ip-api.com and usage: http://whatmyip.info
Ответил 26/05/2014 в 15:59
источник пользователем

голоса
1

использовать функцию ipToCountry ($ IP) от http://www.mmtutorialvault.com/php-ip-to-country-function/

Ответил 27/06/2013 в 18:54
источник пользователем

голоса
0

Вы можете попробовать бесплатную базу данных IP2Location LITE

Чтобы создать таблицу в MySQL

CREATE DATABASE ip2location;
USE ip2location;
CREATE TABLE `ip2location_db1`(
    `ip_from` INT(10) UNSIGNED,
    `ip_to` INT(10) UNSIGNED,
    `country_code` CHAR(2),
    `country_name` VARCHAR(64),
    INDEX `idx_ip_to` (`ip_to`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

Для импорта данных

LOAD DATA LOCAL
    INFILE 'IP2LOCATION-LITE-DB1.CSV'
INTO TABLE
    `ip2location_db1`
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\r\n'
IGNORE 0 LINES;

PHP код для запроса MySQL

<?php
// Replace this MYSQL server variables with actual configuration
$mysql_server = "mysql_server.com";
$mysql_user_name = "UserName";
$mysql_user_pass = "Password";

// Retrieve visitor IP address from server variable REMOTE_ADDR
$ipaddress = $_SERVER["REMOTE_ADDR"];

// Convert IP address to IP number for querying database
$ipno = Dot2LongIP($ipaddress);

// Connect to the database server
$link = mysql_connect($mysql_server, $mysql_user_name, $mysql_user_pass) or die("Could not connect to MySQL database");

// Connect to the IP2Location database
mysql_select_db("ip2location") or die("Could not select database");

// SQL query string to match the recordset that the IP number fall between the valid range
$query = "SELECT * FROM ip2location_db1 WHERE $ipno <= ip_to LIMIT 1";

// Execute SQL query
$result = mysql_query($query) or die("IP2Location Query Failed");

// Retrieve the recordset (only one)
$row = mysql_fetch_object($result);

// Keep the country information into two different variables
$country_code = $row->country_code;
$country_name = $row->country_name;

echo "Country_code: " . $country_code . "<br/>";
echo "Country_name: " . $country_name . "<br />";

// Free recordset and close database connection
mysql_free_result($result);
mysql_close($link);

// Function to convert IP address (xxx.xxx.xxx.xxx) to IP number (0 to 256^4-1)
function Dot2LongIP ($IPaddr) {
 if ($IPaddr == "")
 {
   return 0;
 } else {
   $ips = explode(".", $IPaddr);
   return ($ips[3] + $ips[2] * 256 + $ips[1] * 256 * 256 + $ips[0] * 256 * 256 * 256);
 }
}
?>
Ответил 27/02/2018 в 05:32
источник пользователем

голоса
0

См ipdata.co , который дает вам несколько точек данных из адреса IP.

API довольно быстро, с 10 глобальных конечных точек каждый способен обрабатывать> 800M звонки ежедневно.

Вот завиток пример;

curl https://api.ipdata.co/78.8.53.5
{
    "ip": "78.8.53.5",
    "city": "G\u0142og\u00f3w",
    "region": "Lower Silesia",
    "region_code": "DS",
    "country_name": "Poland",
    "country_code": "PL",
    "continent_name": "Europe",
    "continent_code": "EU",
    "latitude": 51.6461,
    "longitude": 16.1678,
    "asn": "AS12741",
    "organisation": "Netia SA",
    "postal": "67-200",
    "currency": "PLN",
    "currency_symbol": "z\u0142",
    "calling_code": "48",
    "flag": "https://ipdata.co/flags/pl.png",
    "emoji_flag": "\ud83c\uddf5\ud83c\uddf1",
    "time_zone": "Europe/Warsaw",
    "is_eu": true,
    "suspicious_factors": {
        "is_tor": false
    }
}⏎  
Ответил 18/02/2018 в 19:05
источник пользователем

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more