GeoIP的使用 - PHP版

GeoIP介绍:

什么是GepIP ?

所谓GeoIP,就是通过来访者的IP, 定位他的经纬度,国家/地区,省市,甚至街道等位置信息。这里面的技术不算难题,关键在于有个精准 的数据库。有了准确的数据源就奇货可居赚点小钱,可是发扬合作精神,集体贡献众人享用是我们追求的。

 

GeoIP如 何使用?

首先我们需要数据信息,所以先获取一个免费的数据库://sjolzy.cn/php/GeoIP/bak/GeoIP.dat.gz ,接着解压得到:GeoIP.dat, 然后就是对数据文件的按需操作,这边范例使用的是PHP。

 

GeoIP + PHP的使用

方法一:

下载 GeoIP 的 PHP 文件geoip.inc,保存为 geoip.inc.php

//sjolzy.cn/php/GeoIP/bak/geoip.inc

php使用代码


include("geoip.inc.php");

// 打开数据文件
$gi = geoip_open("GeoIP.dat",GEOIP_STANDARD);

// 获取国家代码
$country_code = geoip_country_code_by_addr($gi, $_SERVER['REMOTE_ADDR']);
echo "Your country code is: $country_code ";

// 获取国家名称
$country_name = geoip_country_name_by_addr($gi, $_SERVER['REMOTE_ADDR']);
echo "Your country name is: $country_name ";

// 关闭文件
geoip_close($gi);

注:在本地测试的话因 为$_SERVER['REMOTE_ADDR']和$_SERVER['REMOTE_ADDR']可能是127.0.0.1,所 以输出的内容为空。可以自己带入IP测试

 

方法二:

把 GeoIP 安装成 PHP 扩展
yum install GeoIP GeoIP-data GeoIP-devel

 

下载 GeoIP 数据库
wget http://geolite.maxmind.com/download/geoip/database/GeoLiteCity.dat.gz
gzip -d GeoLiteCity.dat.gz
mv GeoLiteCity.dat /var/lib/GeoIP/GeoIPCity.dat

 

下载 GeoIP 的 PECL 扩展
下载地址 http://pecl.php.net/package/geoip
wget -c http://pecl.php.net/get/geoip-1.0.7.tgz
tar -zxvf geoip-1.0.7.tgz

 

安 装 GeoIP 的 PECL 扩展
cd geoip-1.0.7
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config --with-geoip
make
make install

 

在 php.ini 里加上
extension=geoip.so

接着重启一下 php 就行了
现在,你可以使用 php 手册里的 GeoIP 部份函数了
http://cn.php.net/manual/en/book.geoip.php

 

本 文地址://sjolzy.cn/post-612.html

文本操作类

 

<?php 

class CtbClass { 

var $file; 

var $index; 

//建立一个文件并写入输入 

function null_write($new) 

$f=fopen($this->file,"w"); 

flock($f,LOCK_EX); 

fputs($f,$new); 

fclose($f); 

// 添加数据记录到文件末端 

function add_write($new) { 

$f=fopen($this->file,"a"); 

flock($f,LOCK_EX); 

fputs($f,$new); 

fclose($f); 

// 配合readfile()的返回一起使用,把一行数据转换为一维数组 

function make_array($line) { 

$array = explode("\x0E",$line); 

return $array; 

//把为一维数组转换一行数据 

function join_array($line) { 

$array = join("\x0E",$line); 

return $array; 

// 返回数据文件的总行数 

function getlines() { 

$f=file($this->file); 

return count($f); 

// 返回下一行的数据记录(备用) 

function next_line() { 

$this->index=$this->index++; 

return $this->get(); 

// 返回上一行的数据记录(备用) 

function prev_line() { 

$this->index=$this->index--; 

return $this->get(); 

// 返回当前行的数据记录数据较小 

function get() { 

$f=fopen($this->file,"r"); 

flock($f,LOCK_SH); 

for($i=0;$i<=$this->index;$i++) { 

$rec=fgets($f,1024); 

$line=explode("\x0E",$rec); 

fclose($f); 

return $line; 

// 返回当前行的数据记录数据较大 

function get_big_file() { 

$f=fopen($this->file,"r"); 

flock($f,LOCK_SH); 

for($i=0;$i<=$this->index;$i++) { 

$rec=fgets($f,1024*5); 

$line=explode("\x0E",$rec); 

fclose($f); 

return $line; 

// 打开数据文件---以一维数组返回文件内容 

function read_file() { 

if (file_exists($this->file)) { 

$line =file($this->file); 

return $line; 

// 打开数据文件---以二维数组返回文件内容 

function openFile() { 

if (file_exists($this->file)) { 

$f =file($this->file); 

$lines = array(); 

foreach ($f as $rawline) { 

$tmpline = explode("\x0E",$rawline); 

array_push($lines, $tmpline); 

return $lines; 

// 传入一个数组,合并成一行数据,重写整个文件 

function overwrite($array){ 

$newline = implode("\x0E",$array); 

$f = fopen($this->file,"w"); 

flock($f,LOCK_EX); 

fputs($f,$newline); 

fclose($f); 

// 添加一行数据记录到文件末端 

function add_line($array,$check_n=1) { 

$s=implode("\x0E",$array); 

$f=fopen($this->file,"a"); 

flock($f,LOCK_EX); 

fputs($f,$s); 

if ($check_n==1) fputs($f,"\n"); 

fclose($f); 

// 插入一行数据记录到文件最前面 

function insert_line($array) { 

$newfile = implode("\x0E",$array); 

$f = fopen($this->file,"r"); 

flock($f,LOCK_SH); 

while ($line = fgets($f,1024)) { 

$newfile .= $line; 

fclose($f); 

$f = fopen($this->file,"w"); 

flock($f,LOCK_EX); 

fputs($f,$newfile); 

fclose($f); 

// 更新所有符合条件的数据记录,适用于每行字节数据较大的情况 

function update($column,$query_string,$update_array) { 

$update_string = implode("\x0E",$update_array); 

$newfile = ""; 

$fc=file($this->file); 

$f=fopen($this->file,"r"); 

flock($f,LOCK_SH); 

for ($i=0;$i<count($fc);$i++) { 

$list = explode("\x0E",$fc[$i]); 

if ($list[$column] != $query_string) { 

$newfile = $newfile.chop($fc[$i])."\n"; 

} else { 

$newfile = $newfile.$update_string; 

fclose($f); 

$f=fopen($this->file,"w"); 

flock($f,LOCK_EX); 

fputs($f,$newfile); 

fclose($f); 

// 更新所有符合条件的数据记录,适用于每行字节数据较小的情况 

function update2($column,$query_string,$update_array) { 

$newline = implode("\x0E",$update_array); 

$newfile = ""; 

$f = fopen($this->file,"r"); 

flock($f,LOCK_SH); 

while ($line = fgets($f,1024)) { 

$tmpLine = explode("\x0E",$line); 

if ($tmpLine[$column] == $query_string) { 

$newfile .= $newline; 

} else { 

$newfile .= $line; 

fclose($f); 

$f = fopen($this->file,"w"); 

flock($f,LOCK_EX); 

fputs($f,$newfile); 

fclose($f); 

// 删除所有符合条件的数据记录,适用于每行字节数据较大的情况 

function delete($column,$query_string) { 

$newfile = ""; 

$fc=file($this->file); 

$f=fopen($this->file,"r"); 

flock($f,LOCK_SH); 

for ($i=0;$i<count($fc);$i++) { 

$list = explode("\x0E",$fc[$i]); 

if ($list[$column] != $query_string) { 

$newfile = $newfile.chop($fc[$i])."\n"; 

fclose($f); 

$f=fopen($this->file,"w"); 

flock($f,LOCK_EX); 

fputs($f,$newfile); 

fclose($f); 

// 删除所有符合条件的数据记录,适用于每行字节数据较小的情况 

function delete2($column,$query_string){ 

$newfile = ""; 

$f = fopen($this->file,"r"); 

flock($f,LOCK_SH); 

while ($line = fgets($f,1024)) { 

$tmpLine = explode("\x0E",$line); 

if ($tmpLine[$column] != $query_string) { 

$newfile .= $line; 

fclose($f); 

$f = fopen($this->file,"w"); 

flock($f,LOCK_EX); 

fputs($f,$newfile); 

fclose($f); 

//取得一个文件里某个字段的最大值 

function get_max_value($column) { 

$tlines = file($this->file); 

for ($i=0;$i<=count($tlines);$i++) { 

$line=explode("\x0E",$tlines[$i]); 

$get_value[]=$line[$column]; 

$get_max_value = max($get_value); 

return $get_max_value; 

 

// 根据数据文件的某个字段是否包含$query_string进行查询,以二维数组返回所有符合条件的数据 

function select($column, $query_string) { 

$tline = $this->openfile(); 

$lines = array(); 

foreach ($tline as $line) { 

if ($line[$column] == $query_string) { 

array_push($lines, $line); 

return $lines; 

// 功能与function select()一样,速度可能略有提升 

function select2($column, $query_string) { 

if (file_exists($this->file)) { 

$tline = $this->read_file(); 

foreach ($tline as $tmpLine) { 

$line = $this->make_array($tmpLine); 

if ($line[$column] == $query_string) { 

$lines[]=$tmpLine; 

return $lines; 

// 根据数据文件的某个字段是否包含$query_string进行查询,以一维数组返回第一个符合条件的数据 

function select_line($column, $query_string) { 

$tline = $this->read_file(); 

foreach ($tline as $tmpLine) { 

$line = $this->make_array($tmpLine); 

if ($line[$column] == $query_string) { 

return $line; 

break; 

// select next/prev line(next_prev ==> 1/next, 2/prev) by cx 

function select_next_prev_line($column, $query_string, $next_prev) { 

$tline = $this->read_file(); 

$line_key_end = count($tline) - 1; 

$line_key = -1; 

foreach ($tline as $tmpLine) { 

$line_key++; 

$line = $this->make_array($tmpLine); 

if ($next_prev == 1) { // next? 

if ($line[$column] == $query_string) { 

if ($line_key == 0) { 

return 0; 

} else { 

$line_key_up = $line_key - 1; 

return $up_line; 

} else { 

$up_line = $line; 

} elseif ($next_prev == 2) { // prev? 

if ($line[$column] == $query_string) { 

if ($line_key == $line_key_end) { 

return 0; 

} else { 

$line_key_down = $line_key + 1; 

break; 

} else { 

return 0; 

$down_line = $this->make_array($tline[$line_key_down]); 

return $down_line; 

 

?>