<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>CZDB相关文章列表 | 皇家元林</title>
	<atom:link href="https://hjyl.org/tags/czdb/feed/" rel="self" type="application/rss+xml" />
	<link>https://hjyl.org</link>
	<description>刘元林的个人博客</description>
	<lastBuildDate>Sun, 25 Aug 2024 13:34:34 +0000</lastBuildDate>
	<language>zh-Hans</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.9.4</generator>

<image>
	<url>https://img.hjyl.org/uploads/2019/10/cropped-about-me-32x32.png</url>
	<title>CZDB相关文章列表 | 皇家元林</title>
	<link>https://hjyl.org</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>WordPress接入纯真IP库CZDB版本</title>
		<link>https://hjyl.org/wordpress-cz88-czdb/</link>
					<comments>https://hjyl.org/wordpress-cz88-czdb/#comments</comments>
		
		<dc:creator><![CDATA[皇家元林]]></dc:creator>
		<pubDate>Sun, 25 Aug 2024 13:33:06 +0000</pubDate>
				<category><![CDATA[元林手札]]></category>
		<category><![CDATA[CZDB]]></category>
		<category><![CDATA[IP归属地]]></category>
		<category><![CDATA[WordPress]]></category>
		<category><![CDATA[纯真IP]]></category>
		<guid isPermaLink="false">https://hjyl.org/?p=5288</guid>

					<description><![CDATA[之前，本站基于纯真IP库实现评论者IP归属地，用的好好的，突然官方又改变策略了，推出czdb数据格式，并在10 [&#8230;]]]></description>
										<content:encoded><![CDATA[
<p>之前，本站<a href="https://hjyl.org/qqwry-ip-location/">基于纯真IP库实现评论者IP归属地</a>，用的好好的，突然官方又改变策略了，推出czdb数据格式，并在10月1日开始停止dat格式和exe格式的发布（详情见<a href="https://hjyl.org/go/aHR0cHM6Ly9tcC53ZWl4aW4ucXEuY29tL3M/X19iaXo9TXpnM016YzBOVEEzTkE9PSZhbXA7bWlkPTIyNDc0ODUzMjImYW1wO2lkeD0yJmFtcDtzbj02OWI3M2RiZTkxNjYwMmY0ODE2YzY5ZTJkYWJjNzE1ZiZhbXA7Y2hrc209Y2VkYTE4NTdmOWFkOTE0MWRiYmU0ZTU0MzE3ZjA3NTQ1YmQ0ZmQ2YzVjNTJiNDczZWI4MDYyMzA4ZjNlM2I4ZjUxYjRkYmE5ZmRmZCZhbXA7c2NlbmU9MjEjd2VjaGF0X3JlZGlyZWN0" rel="nofollow" target="_blank">官方公众号</a>）。</p>



<p>新版本的要求就多了，首先你得在官方注册登录，其次根据它的要求帮它宣传（我是在本博客底部加上他们网站的链接），并截图给他审核，通过之后你才会有授权，你才能得到key。有了这个key你才能使用czdb格式数据库。我个人是不太喜欢需要通过这种方式才能得到的一些东西，吃相有点难看了。但是没办法，好像也找不到更好的选择了。</p>



<p>CZDB目前官方已支持JAVA、C语言和PHP解析程序，我们直接拿来用就可以了。下面主要说说咱们WordPress的食用方法，也就是PHP的解析程序。</p>



<p>PHP解析程序的GitHub地址：<a href="https://hjyl.org/go/aHR0cHM6Ly9naXRodWIuY29tL3RhZ3BoaS9jemRiX3NlYXJjaGVyX3BocA==" rel="nofollow" target="_blank">czdb_searcher_php</a></p>



<p>在项目目录下运行以下命令来安装 CZDB Searcher：</p>



<pre class="wp-block-code"><code lang="bash" class="language-bash line-numbers">composer require czdb/searcher</code></pre>



<p>如果找不到包，可能是因为你没有使用composer 2.x版本，可以使用以下命令来安装composer 2.x版本：</p>



<pre class="wp-block-code"><code lang="bash" class="language-bash line-numbers">composer self-update --2</code></pre>



<p>然后将下面代码扔进functions.php文件里：</p>



<pre class="wp-block-code"><code lang="php" class="language-php line-numbers">//解析纯真IP获取评论者ip归属地 开始

require_once __DIR__ . '/vendor/autoload.php';

use Czdb\DbSearcher;

//评论作者归属地函数
//Code by HJYL.ORG
//IP数据库由纯真CZ88提供
function getCity($ip){
    $dbSearcher = new DbSearcher("cz88_public_v4.czdb的路径", "BTREE", "key");
    // get_template_directory() . "/czdb/cz88_public_v4.czdb" 这是某主题目录下的文件夹
    // 默认BTREE，搜索模式（例如，"BTREE" 少量查询 或者 "MEMORY" 大量查询）。
    // key，即密钥，从https://cz88.net/geo-public获取
    
    $region = $dbSearcher-&gt;search($ip);
    // 将字符串拆分成各个部分
    if(strpos($region, "\t")){
        $region = preg_replace('/\t+/','–',$region);

    }elseif(strpos($region, " ")){
        $region = str_replace(' ','–',$region);
    }

    $region = explode("–", $region);

    //分别获取国家、省、市字段
    $country = $region[0] ?? "";
    $province = $region[1] ?? "";
    $city = $region[2] ?? "";

    $dbSearcher-&gt;close();

    //优先显示城市，其次省，最后国家
    if($ip == '127.0.0.1'){
        $data = '小黑屋';
    }elseif($city == "" || false !== strpos($city, '移动') || false !== strpos($city, '电信') || false !== strpos($city, '联通')){
        $data = $province;
    }elseif($province == "" || false !== strpos($province, '移动') || false !== strpos($province, '电信') || false !== strpos($province, '联通')){
        $data = $country;
    }else{
        $data = $city;
    }
    
    return $data;
}

//解析纯真IP获取评论者ip归属地 结束</code></pre>



<p>调用方法：</p>



<pre class="wp-block-code"><code lang="php" class="language-php line-numbers">echo getCity(get_comment_author_IP());</code></pre>



<p>结束撒花~~~</p>



<p>花絮：</p>



<p>这个版本的数据库支持IPv4和IPv6，其实之前的那个itbdw/ip-database也是支持IPv4和IPv6的，只是纯真没有IPv6数据库。这次发布了IPv6数据库，但是我也用不上。</p>



<p>这段代码的解析思路是这样的：根据IP查询数据库，得到的格式是这样的——“中国–安徽–合肥  移动”，然后将其拆解，分别得到国家、省、市。别看这格式很简单，我测试了很久，才发现移动前的空格不仅有空格，还有制表符“\t”，这是目前我遇到的，不知道还有没有其他看不见的符号了。</p>



<p>最让人吐槽的是纯真社区版IP库在地级市的准确率上不是很高。所以不必较真，仅供娱乐而已。</p>
<div id="content-copyright"><span style="font-weight:bold;text-shadow:0 1px 0 #ddd;font-size: 13px;">版权声明: </span><span style="font-size: 13px;">本文采用 <a href="https://hjyl.org/go/aHR0cHM6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL2xpY2Vuc2VzL2J5LW5jLXNhLzMuMC8=" rel="nofollow" target="_blank">BY-NC-SA</a> 协议进行授权，如无注明均为原创，转载请注明转自 <a href="https://hjyl.org">皇家元林</a><br>本文链接: <a rel="bookmark" title="WordPress接入纯真IP库CZDB版本" href="https://hjyl.org/wordpress-cz88-czdb/">WordPress接入纯真IP库CZDB版本</a></span></div>]]></content:encoded>
					
					<wfw:commentRss>https://hjyl.org/wordpress-cz88-czdb/feed/</wfw:commentRss>
			<slash:comments>16</slash:comments>
		
		
			</item>
	</channel>
</rss>
