當前位置:首頁 » 數據倉庫 » 純真ip資料庫php
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

純真ip資料庫php

發布時間: 2023-04-01 03:56:13

『壹』 我做的php 網站,我在網上下載了ip 純真版資料庫,能顯示地區 比如 「吉林省四平市」,我想把它提取出來

<?php

//第一步:透過代理獲取用戶真實的IP地址

$theip=getip();

function getIP()
{
static $realip;
if (isset($_SERVER)){
if (isset($_SERVER["HTTP_X_FORWARDED_FOR"])){
$realip = $_SERVER["HTTP_X_FORWARDED_FOR"];
} else if (isset($_SERVER["HTTP_CLIENT_IP"])) {
$realip = $_SERVER["HTTP_CLIENT_IP"];
} else {
$realip = $_SERVER["REMOTE_ADDR"];
}
} else {
if (getenv("HTTP_X_FORWARDED_FOR")){
$realip = getenv("HTTP_X_FORWARDED_FOR");
} else if (getenv("HTTP_CLIENT_IP")) {
$realip = getenv("HTTP_CLIENT_IP"碼晌吵);
} else {
$realip = getenv("REMOTE_ADDR");
}
}

return $realip;
}

//第二步:通過讀取IP地址庫,找到所屬地區
//假設表名為ip,欄位有begin(起始),end(結束),area(地區代號)

$dblink=@mysql_connect("數遲侍據庫伺服器名","資料庫用戶名","資料庫密碼");
$dbselect=@mysql_select_db(資料庫名謹塌);
if (!$dbselect){
die("資料庫無法讀取");
}

$result=mysql_query("select * from `ip` where `begin`<=`$theip` and `end`>=`$theip`");
$num=mysql_num_rows($result);

if($num>0){
$info=mysql_fetch_array($result);
$page=$info['area'];
else{
$page='default'; //如果IP不在資料庫中,則用預設的頁面
}

//第三步:轉到相關頁面,如代號為"js",轉到"js.php"頁面
$page.='.html'; //後綴你可以自己取
echo "<script language=\"javascript\">window.location.replace(\"$page\")</script>";

?>

『貳』 什麼叫純真IP資料庫

純真IP資料庫是純真網路(一個企業或網路團體)收集的關於全國的固定IP地址的一個資料庫,會不斷的隨著變化或增加而進行更新,通過這個資料庫,你就可以通過QQ或其他網路軟體知道某個IP是歸屬於哪個省哪個市哪個地區,比如你可以知道你的QQ好友是哪個省哪個地區的。

『叄』 如何根據ip查對應的公司

只有申請了固定IP的公司,才有可能根據IP反查得到公司信息,但這個信息是非公開的,只有ISP比如電信才有這種信息。
但民間有一個資料庫是用來解決這一問題,就是純真資料庫,
目前網路等很多網站也使用了隱困這個庫,
原理是通過網友自己填寫所在地或公司資料與自己的IP來對資料庫進行完善
,由於多數的IP是動態分配的,所以准確性不能保證;如果使用固定IP的公司有人填了公司資料,你就有可能查得到。
具體可以在網路直接輸入IP,或在使用了這個庫的網站比如 123cha.com 來輸入IP反查。
(3)純真ip資料庫php擴展閱讀:
IP是Internet Protocol(網際互連協議)的縮寫,是敬攜培TCP/IP體系中的網路層協議。
設計IP的目的是提高網路的可擴展性:
一是解決互聯網問題,實現大規模、異構網路的互聯互通;
二是分割頂層網路應用和底層網路技術之間的耦合關系,以利於兩者的獨立發展。
根據端到端的設計原則,IP只為主機提供一種無連接、不可靠的、盡力而為的數據包傳輸服務。
IP地址是用來識別網路上的設備,因此,IP地址是由網路地址與主機地址兩部分所組成。
網路地址
網路地址可用來識別設備所在的網路,網路地址位於IP地址的前段。
當組織或企業申請IP地址時,所獲得的並非IP地址,而是取得一個唯一的、能夠識別的網路地址。
同一網路上的所有設備,都有相同的網路地址。
IP路由的功能是根據IP地址中的網路地址,決定要將IP信息包送至所指明的那個網路。
主機地址
主機地址位於IP地址的後段,可用來識別網路上設備。
同一網路上的設備都會有相同的網路地亮唯址,而各設備之間則是以主機地址來區別。
由於各個網路的規模大小不一,大型的網路應該使用較短的網路地址,以便能使用較多的主機地址;
反之,較小的網路則應該使用較長的網路地址。
為了符合不同網路規模的需求,IP在設計時便根據網路地址的長度,設計與劃分IP地址。

『肆』 php獲取了ip地址,用php怎麼獲取ip的地理位置請大蝦賜教!

通過純真QQip地址庫文件查詢IP地理位置
2009-02-26 14:11
一、下載純真IP地址庫文件QQWry.Dat (網上有很多,並且吵雹御可以定期升級)

二、創建類文件 IPLocation.php ,將下面代碼直接拷貝到php文件中

<?php
/**
* IP 地理位置查詢類
*
* @author 馬秉堯
* @version 1.5
* @right 2005 CoolCode.CN
*/
class IpLocation
{
/**
* QQWry.Dat文件指針(使用以前珊瑚蟲QQ的IP)
*
* @var resource
*/
var $fp;

/**
* 第一條IP記錄的偏移地址
*
* @var int
*/
var $firstip;

/**
* 最後一條IP記錄的偏移地址
*
* @var int
*/
var $lastip;

/**
* IP記錄的總條數(不包含版本信息記錄)
*
* @var int
*/
var $totalip;

/**
* 返回讀取的長肆伏整型數
*
* @access private
* @return int
*/
function getlong()
{
//將讀取的little-endian編碼的4個位元組轉化升岩為長整型數
$result = unpack('Vlong', fread($this->fp, 4));
return $result['long'];
}

/**
* 返回讀取的3個位元組的長整型數
*
* @access private
* @return int
*/
function getlong3()
{
//將讀取的little-endian編碼的3個位元組轉化為長整型數
$result = unpack('Vlong', fread($this->fp, 3).chr(0));
return $result['long'];
}

/**
* 返回壓縮後可進行比較的IP地址
*
* @access private
* @param string $ip
* @return string
*/
function packip($ip)
{
// 將IP地址轉化為長整型數,如果在PHP5中,IP地址錯誤,則返回False,
// 這時intval將Flase轉化為整數-1,之後壓縮成big-endian編碼的字元串
return pack('N', intval(ip2long($ip)));//intaval 獲取變數的整數值
}

/**
* 返回讀取的字元串
*
* @access private
* @param string $data
* @return string
*/
function getstring($data = "")
{
$char = fread($this->fp, 1);
while (ord($char) > 0)
{ // 字元串按照C格式保存,以\0結束 ord()得到字元的ASCII碼
$data .= $char; // 將讀取的字元連接到給定字元串之後
$char = fread($this->fp, 1);
}
return $data;
}

/**
* 返回地區信息
*
* @access private
* @return string
*/
function getarea()
{
$byte = fread($this->fp, 1); // 標志位元組
switch (ord($byte)) {
case 0: // 沒有區域信息
$area = "";
break;
case 1:
case 2: // 標志位元組為1或2,表示區域信息被重定向
fseek($this->fp, $this->getlong3());
$area = $this->getstring();
break;
default: // 否則,表示區域信息沒有被重定向
$area = $this->getstring($byte);
break;
}
return $area;
}

/**
* 根據所給 IP 地址或域名返回所在地區信息
*
* @access public
* @param string $ip
* @return array
*/
function getlocation($ip)
{
if (!$this->fp) return null; // 如果數據文件沒有被正確打開,則直接返回空
$location['ip'] = gethostbyname($ip); // 將輸入的域名轉化為IP地址
$ip = $this->packip($location['ip']); // 將輸入的IP地址轉化為可比較的IP地址
// 不合法的IP地址會被轉化為255.255.255.255
// 對分搜索
$l = 0; // 搜索的下邊界
$u = $this->totalip; // 搜索的上邊界
$findip = $this->lastip; // 如果沒有找到就返回最後一條IP記錄(QQWry.Dat的版本信息)
while ($l <= $u)
{ // 當上邊界小於下邊界時,查找失敗
$i = floor(($l + $u) / 2); // 計算近似中間記錄
fseek($this->fp, $this->firstip + $i * 7);
$beginip = strrev(fread($this->fp, 4)); // 獲取中間記錄的開始IP地址
// strrev函數在這里的作用是將little-endian的壓縮IP地址轉化為big-endian的格式
// 以便用於比較,後面相同。
if ($ip < $beginip)
{ // 用戶的IP小於中間記錄的開始IP地址時
$u = $i - 1; // 將搜索的上邊界修改為中間記錄減一
}
else
{
fseek($this->fp, $this->getlong3());
$endip = strrev(fread($this->fp, 4)); // 獲取中間記錄的結束IP地址
if ($ip > $endip)
{ // 用戶的IP大於中間記錄的結束IP地址時
$l = $i + 1; // 將搜索的下邊界修改為中間記錄加一
}
else
{ // 用戶的IP在中間記錄的IP范圍內時
$findip = $this->firstip + $i * 7;
break; // 則表示找到結果,退出循環
}
}
}

//獲取查找到的IP地理位置信息
fseek($this->fp, $findip);
$location['beginip'] = long2ip($this->getlong()); // 用戶IP所在范圍的開始地址
$offset = $this->getlong3();
fseek($this->fp, $offset);
$location['endip'] = long2ip($this->getlong()); // 用戶IP所在范圍的結束地址
$byte = fread($this->fp, 1); // 標志位元組
switch (ord($byte))
{
case 1: // 標志位元組為1,表示國家和區域信息都被同時重定向
$countryOffset = $this->getlong3(); // 重定向地址
fseek($this->fp, $countryOffset);
$byte = fread($this->fp, 1); // 標志位元組
switch (ord($byte))
{
case 2: // 標志位元組為2,表示國家信息又被重定向
fseek($this->fp, $this->getlong3());
$location['country'] = $this->getstring();
fseek($this->fp, $countryOffset + 4);
$location['area'] = $this->getarea();
break;
default: // 否則,表示國家信息沒有被重定向
$location['country'] = $this->getstring($byte);
$location['area'] = $this->getarea();
break;
}
break;
case 2: // 標志位元組為2,表示國家信息被重定向
fseek($this->fp, $this->getlong3());
$location['country'] = $this->getstring();
fseek($this->fp, $offset + 8);
$location['area'] = $this->getarea();
break;
default: // 否則,表示國家信息沒有被重定向
$location['country'] = $this->getstring($byte);
$location['area'] = $this->getarea();
break;
}
if ($location['country'] == " CZ88.NET")
{ // CZ88.NET表示沒有有效信息
$location['country'] = "未知";
}
if ($location['area'] == " CZ88.NET")
{
$location['area'] = "";
}
return $location;
}

/**
* 構造函數,打開 QQWry.Dat 文件並初始化類中的信息
*
* @param string $filename
* @return IpLocation
*/
function IpLocation($filename = "QQWry.Dat")
{
if (($this->fp = @fopen($filename, 'rb')) !== false)
{
$this->firstip = $this->getlong();
$this->lastip = $this->getlong();
$this->totalip = ($this->lastip - $this->firstip) / 7;
//注冊析構函數,使其在程序執行結束時執行
register_shutdown_function(array(&$this, '_IpLocation'));
}
}

/**
* 析構函數,用於在頁面執行結束後自動關閉打開的文件。
*
*/
function _IpLocation()
{
fclose($this->fp);
}
}
?>

三、程序部分

require_once("includes/IPLocation.php") ; //這里引用剛創建的類文件
$ipLocation = new IpLocation("includes/QQWry.Dat") ; //這里引用ip地址庫

$ips = $ipLocation->getlocation($userIP) ; //$ips 就是所得到的物理地址,$userIP是傳入的IP ,例如(202.106.12.23)

來源:http://hi..com/yang_bd/blog/item/7b44f830b8764e1eebc4afd1.html

下面是一個實例,獲取IP並且檢索出該IP地理位置

<?
//獲取IP
error_reporting (E_ERROR | E_WARNING | E_PARSE);
if($HTTP_SERVER_VARS["HTTP_X_FORWARDED_FOR"])
{
$ip = $HTTP_SERVER_VARS["HTTP_X_FORWARDED_FOR"];

}
elseif($HTTP_SERVER_VARS["HTTP_CLIENT_IP"])
{
$ip = $HTTP_SERVER_VARS["HTTP_CLIENT_IP"];

}
elseif ($HTTP_SERVER_VARS["REMOTE_ADDR"])
{
$ip = $HTTP_SERVER_VARS["REMOTE_ADDR"];

}
elseif (getenv("HTTP_X_FORWARDED_FOR"))
{
$ip = getenv("HTTP_X_FORWARDED_FOR");

}
elseif (getenv("HTTP_CLIENT_IP"))
{
$ip = getenv("HTTP_CLIENT_IP");

}

elseif (getenv("REMOTE_ADDR"))
{
$ip = getenv("REMOTE_ADDR");

}

else
{
$ip = "Unknown";

}

require_once("includes/IPLocation.php") ; //這里引用剛創建的類文件
$ipLocation = new IpLocation("includes/QQWry.Dat") ; //這里引用ip地址庫

$ips = $ipLocation->getlocation($ip) ; //$ips 就是所得到的物理地址

var_mp($ips);
?>

效果如下(我使用本地測試):
array(5) { ["ip"]=> string(9) "127.0.0.1" ["beginip"]=> string(9) "127.0.0.1" ["endip"]=> string(9) "127.0.0.1" ["country"]=> string(8) "本機地址" ["area"]=> string(0) "" }

『伍』 純真ip資料庫怎麼用

騰訊QQ IP資料庫是一個收集了包括最全的網吧數據在內的中國電信、中國網通、長城寬頻、網通寬頻、聚友寬頻等 ISP 的最新准確 IP 地址數據的軟體。

使用方法如下:

下載後直接點開就會出現軟體頁面,界面如圖:

『陸』 什麼是純真ip段資料庫

就是一個可以查詢ip地址的軟體,可以裝在QQ中,讓你查詢ip地址很方便。但是不怎麼好用。實用性不大。他那個資料庫里包含了大部分ip地址的歸屬地。

『柒』 php如何實現根據IP自動跳轉首頁

既然你的公司已經做到全國各地了,還稀罕伺服器,做個分流就可以了。

『捌』 網站怎麼限制某個地區訪問

限制地區訪問有兩種方式。一、IP判斷法。二、伺服器限製法。
IP判斷法:網站用ASP或者PHP代碼調用IP資料庫進行判斷,網站設置好哪些城市可以訪問,哪些城市不可以訪問,比如說,網站不能讓北京的來的訪客訪問,那麼如果北京來的Ip的話,網站進行ip判斷,如果是北京來的就讓他訪問其它的頁面,如果不是北京來的訪客就讓他正常訪問,要求是ip資料庫用IP純真資料庫查詢地區的IP段時保存成TXT格式,或者資料庫格式,這樣代碼調用時侯就會快一些,不能採用直接到淘寶IP資料庫或者IP的網站對比IP數據,那樣的話網站打開很慢,可以把他們的IP資料庫下載下來放到網站的根目錄裡面,這樣網站打開會提高打開速度。
伺服器限製法:伺服器限制某城市訪問,在伺服器上面設置黑名單城市,如果是黑名單城市來的訪問就讓他拒絕訪問,如果不是黑名單來的城市訪客,就讓他正常訪問。

『玖』 怎麼製作BS(比特精靈)的IPDATA文件

工具:電腦win11,比特精靈3.6.0

怎麼製作BS(比特精靈)的IPDATA文件方法這個問題我之前遇到過,挺容易解決的,接下來就跟大家講講應該怎麼操作:

第一步,打開比特精靈(BitSpirit)軟體,打開軟體後點擊頂部的【功能】在彈出的選項中點擊【製作種子文件】。(逗桐如下圖所示)

以上就是解決怎麼製作BS(比特精靈)的IPDATA文件的所有步驟啦,對你有用的話記得幫忙點贊點關注呀~。

『拾』 Discuz、Phpwind和Spacebuilder,哪一個好用

discuz缺點:

不能批量編輯用戶,如不能批量移動到指定用戶組。

帖間隨機廣告代碼不能「每條隨機廣告一行,用回車分開」。

沒有「沉底」功能。

沒有道具,用戶不能自行改名。

不能批量刪除某個用戶若干天內的所有回復或主題。

優點:

discuz免費。

使用快速回復框時不會說「您提交的參數錯誤。請仔細閱讀論壇幫助文件,確保您有相應的操作許可權。」

不會因為css代碼下載不完全而導致版面格式混亂。

積分、用戶組、發帖數級別設置更靈活。

比asp+access版論壇更節約空間。轉換後資料庫大小隻有動網Access資料庫的三分之一。

速度快。

可以匿名發帖。

可以設置昵稱。

可以直接使用純真IP庫。

後台設置簡單明了。

可以「用戶欄目定製」。

可以「合並用戶」。

可以在後台直接更改用戶名。

頁面上下都有頁碼,方便翻頁。

可以前台批量操作。

不會多重引用。

用戶編輯帖子可以自己更改主題分類。

phpwind特點:

獨創、成熟

phpwind獨創的技術架構和程序設計,獲得國家專利認證,從根基著手塑造快速、穩健、可擴展的論壇程序。7年礪煉,在用戶需求基礎上進行不斷創新與完善,無論企業還是娛樂,全面滿足論壇建設。

安全

高效防護演算法、程序監控技術、注入式入侵過濾技術、防CC攻擊技術、安全驗證機制構築的站點安全體系,將風險防患於未然

快捷、穩定、高效

核心參數的合理配置、負載均衡處理技術、資料庫分表技術、文件讀寫穩定性演算法幫助您最大限仿帆慧度地節省硬體資源,保障站點在伺服器繁忙時快速穩定運行。

不僅為站長而設計

站長建站,影響的卻是網民。PHPWind「不僅為站長而設計」的設計理念,將人性化融入論壇功能的點點滴滴。清晰的用戶等級與許可權設置,便捷完整的論壇功能與管理操作,詳細地日誌與統計記錄,集成交易與支付,輕松備份/恢復數據給予站長和每一位會員良好的用戶體驗。

可擴展

開源、規范化的代碼編寫、標准化的插件介面和清晰簡潔的模板體系理念,讓站點無限延伸至未來。

完美整合

PHPWind所取得的同業合作,為您提供更多建站軟體選擇和無間隙的軟體服務,幫助站點多面需求。查看詳情

豐富的第三方資源

近千款風格,近百款插件,仍在不斷豐富。查看詳情

操作系統要求

PHPWind具備跨平台特性,支持 Linux/Unix及Windows 2000/2003/ XP等操作系統。

針對上述操作系統,我們隊軟體做了大量的測試和實地檢驗,保證PHPWind可以安全穩定的運行,但您仍需做好伺服器操作系統的安全防備措施,例轎枝如Windows用戶需更改MYSQL的初始密碼,使用較新的穩定的軟體版本等。

語言及資料庫支撐環境要求可用的 web 伺服器(如 Apache、Zeus、IIS 等)

php 5.2.x及以上

MySQL5.1.x及以上

Zend Optimizer 3.x及以上(可以不用)

如果您租用虛擬主機,請咨詢虛擬主機提供商,您的空間伺服器是否已安裝了上述軟體。

由於
PHPWind的數據表具有前綴設計,因此通常情況下可以將PHPWind與其他軟體安裝在同一個資料庫中,或採用不同的前綴名在同一個資料庫中安裝多個PHPWind
論壇而不產生沖突。

您的 MySQL 資料庫賬號應當擁有 CREATE、DROP、ALTER 等執行許可權。

安裝可能用到的工具軟體

PHPWind論壇系統的安裝使用非常簡單,因此您可能需要用到的工具軟體也非常少。

1)您可能需要一個FTP客戶端軟體來上傳PHPWind程序文件;

2)PHPWind是一個開源系統,您可以按自己的想法來修改程序代碼,從而得到自己想要的社區呈現效果,或者社區系統某些配置文件的參數需要修改,此時您可能需要一個簡單的文本文件編輯軟體,一般操作系統自帶的如Windows的記事本或第三方軟體如備答EditPlus,都可以。

Spacebuilder - 特色

1.產品架構:採用「平台+應用」的設計思想,可以方便及快捷的擴展新的應用;

2. Ajax:表現層採用大量的jQuery技術,使用戶獲得良好的用戶體驗;

3. asp.net mvc:採用微軟最新的asp.net
mvc(c#)進行表現層開發。徹底消除了ViewState可以萬全控制html代碼的輸出;Controller與View完全分離充分避免了皮膚機制的性能損失;原生態的url
routing更利於urlrewrite。

4. 數據存儲:目前採用SQL Server2000/SQLServer2005/SQL
Server2008進行數據存儲,由於數據訪問層採用了Provide設計模式所以可以方便的移植到其他關系型資料庫;

5. 數據訪問:為了提升性能以及資料庫安全性,數據訪問全部採用存儲過程;

6. 高效緩存:使用可分區的緩存技術,並且具有優秀的緩存過期策略,使站點獲得性能提升的同時,保證緩存與資料庫數據同步;

7. 全文檢索:以Lucene為核心實現全文檢索功能,實現索引庫自動更新,並提供企業級的全文檢索性能;

8. 擴展機制:優秀的皮膚實現機制,使客戶可以方便的對現有皮膚進行修改或開發新的皮膚;核心模塊提供了全局事件,客戶可以開發自己的Mole;

9. 配置文件:配置信息均採用XML格式,易於管理設置;

10. 所有頁面均採用xhtml+css進行設計,符合web標准,兼容所有主流瀏覽器(IE、Firefox),降低頁面流量,提高載入速度;