Home Backend Development PHP Tutorial 一个IP地址搜索引擎的设想_PHP

一个IP地址搜索引擎的设想_PHP

Jun 01, 2016 pm 12:34 PM
ip information address submit search engine database this

IP地址

这个想法一两年前就有了,不过当时几位朋友在谈话中觉得IP地址搜索这种东西早已做滥了,没有必要再做,所以把这个想法搁置在一边。
但是一两年过去了,现在还是常常无法找到好的IP地址数据库,觉得这个想法还是值得一试,反正写这样一个程序也不费事。

现在的IP地址分配是由电信这些网络运营商来做的,他们没有公布子网分配的信息,所以现在搜集IP地址信息只有从民间发起,这是个艰巨的工作,IP子网实在是太多了,而且IP地址本身也会变化,造成已经收集的IP地址信息过时,另外还有一个信息真实性的问题。所有这些会产生巨大的工作量,靠人工来实现是很麻烦的事情,特别是在没有报酬的情况下去维护这样一批数据使人望而却步。
在我的设想中,这个IP地址搜索引擎会是这样的:

  • 提供和普通的IP地址搜索一样的搜索框(最最普通的)
  • 在页面上显示你的当前IP地址信息,如果没有找到或者错误,可以通过链接来提交正确的信息
  • 提供IP地址数据库下载,但是在下载之前必须提交你的当前IP地址信息
  • 所有来自用户提交的IP地址信息提交至临时数据库内
  • 如果有n条临时数据库内的IP地址信息表明某子网属于同一地区,并且在正式数据库内的对应子网地址信息错误或者不存在,则提交进入正式数据库内
从前两条来看,和普通IP搜索都是一样的,但是我希望可以通过后3条来解决收集和维护的问题。
每个人都可以来无偿的获取这里的IP地址数据库,但是必须以自己当前的IP地址信息作为回报
将来自不同用户的IP地址信息进行对比来判断信息的真实性,这个机制还有一些细节需要考虑,不过基本上我已经想好了,其实主要是防止某些心理不健康的人恶意的提交大量虚假信息欺骗系统,另外这种机制也节约大量人工,让数据自行增长
长期的用户IP地址信息提交保持IP地址信息不过时

这种机制的成功与否取决于用户使用数量是否达到一个基数,如果人多,提交的信息多,这个IP地址数据库就会越来越好,进入良性循环。
近期把这个东西写出来,早期的IP地址数据库只有从网上现有的来了。
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How does Go language implement the addition, deletion, modification and query operations of the database? How does Go language implement the addition, deletion, modification and query operations of the database? Mar 27, 2024 pm 09:39 PM

Go language is an efficient, concise and easy-to-learn programming language. It is favored by developers because of its advantages in concurrent programming and network programming. In actual development, database operations are an indispensable part. This article will introduce how to use Go language to implement database addition, deletion, modification and query operations. In Go language, we usually use third-party libraries to operate databases, such as commonly used sql packages, gorm, etc. Here we take the sql package as an example to introduce how to implement the addition, deletion, modification and query operations of the database. Assume we are using a MySQL database.

How does Hibernate implement polymorphic mapping? How does Hibernate implement polymorphic mapping? Apr 17, 2024 pm 12:09 PM

Hibernate polymorphic mapping can map inherited classes to the database and provides the following mapping types: joined-subclass: Create a separate table for the subclass, including all columns of the parent class. table-per-class: Create a separate table for subclasses, containing only subclass-specific columns. union-subclass: similar to joined-subclass, but the parent class table unions all subclass columns.

iOS 18 adds a new 'Recovered' album function to retrieve lost or damaged photos iOS 18 adds a new 'Recovered' album function to retrieve lost or damaged photos Jul 18, 2024 am 05:48 AM

Apple's latest releases of iOS18, iPadOS18 and macOS Sequoia systems have added an important feature to the Photos application, designed to help users easily recover photos and videos lost or damaged due to various reasons. The new feature introduces an album called "Recovered" in the Tools section of the Photos app that will automatically appear when a user has pictures or videos on their device that are not part of their photo library. The emergence of the "Recovered" album provides a solution for photos and videos lost due to database corruption, the camera application not saving to the photo library correctly, or a third-party application managing the photo library. Users only need a few simple steps

Detailed tutorial on establishing a database connection using MySQLi in PHP Detailed tutorial on establishing a database connection using MySQLi in PHP Jun 04, 2024 pm 01:42 PM

How to use MySQLi to establish a database connection in PHP: Include MySQLi extension (require_once) Create connection function (functionconnect_to_db) Call connection function ($conn=connect_to_db()) Execute query ($result=$conn->query()) Close connection ( $conn->close())

An in-depth analysis of how HTML reads the database An in-depth analysis of how HTML reads the database Apr 09, 2024 pm 12:36 PM

HTML cannot read the database directly, but it can be achieved through JavaScript and AJAX. The steps include establishing a database connection, sending a query, processing the response, and updating the page. This article provides a practical example of using JavaScript, AJAX and PHP to read data from a MySQL database, showing how to dynamically display query results in an HTML page. This example uses XMLHttpRequest to establish a database connection, send a query and process the response, thereby filling data into page elements and realizing the function of HTML reading the database.

How to check the MAC address on a mobile phone (simple operation allows you to easily obtain the MAC address of the device) How to check the MAC address on a mobile phone (simple operation allows you to easily obtain the MAC address of the device) Apr 19, 2024 pm 06:19 PM

We may need to check the MAC address of the mobile phone in some specific situations, such as setting up wireless network filtering or device management. This article will teach you how to easily obtain the MAC address of your device through your mobile phone. 1. What is a MAC address 2. Mobile phone system: Android and iOS 3. How to check the MAC address in the Android system 4. How to check the MAC address in the iOS system 5. Use the device management application to check the MAC address 6. Check the connected devices through the wireless router 7. View the MAC address through a third-party application 8. View the MAC address through the developer options in the phone settings 9. View the MAC address using a network analysis tool 10. View the MAC address through the command line

How to handle database connection errors in PHP How to handle database connection errors in PHP Jun 05, 2024 pm 02:16 PM

To handle database connection errors in PHP, you can use the following steps: Use mysqli_connect_errno() to obtain the error code. Use mysqli_connect_error() to get the error message. By capturing and logging these error messages, database connection issues can be easily identified and resolved, ensuring the smooth running of your application.

Analysis of the basic principles of MySQL database management system Analysis of the basic principles of MySQL database management system Mar 25, 2024 pm 12:42 PM

Analysis of the basic principles of the MySQL database management system MySQL is a commonly used relational database management system that uses structured query language (SQL) for data storage and management. This article will introduce the basic principles of the MySQL database management system, including database creation, data table design, data addition, deletion, modification, and other operations, and provide specific code examples. 1. Database Creation In MySQL, you first need to create a database instance to store data. The following code can create a file named "my

See all articles