wordpress 蜘蛛记录插件的功能记录网站的所有访问记录

要在 WordPress 网站上实现类似的功能,通常你需要开发一个 WordPress 插件。以下是一步步创建一个插件的指南,它可以记录访问者的访问记录,区分搜索引擎蜘蛛,并保存访客的 IP 地址。

1. 创建插件目录和文件

  1. 进入你的 WordPress 插件目录。路径通常是:
wp-content/plugins/
  1. plugins 文件夹中创建一个新目录,例如:visitor-tracker
  2. visitor-tracker 目录中创建一个 PHP 文件,例如:visitor-tracker.php

2. 插件文件结构

插件的文件结构大概如下:

wp-content/
    plugins/
        visitor-tracker/
            visitor-tracker.php

3. 编写插件代码

visitor-tracker.php 文件中,添加以下代码:

<?php
/**
 * Plugin Name: Visitor Tracker
 * Plugin URI: https://yourwebsite.com
 * Description: A simple plugin to track visitors and identify search engine bots.
 * Version: 1.0
 * Author: Your Name
 * Author URI: https://yourwebsite.com
 */

// 确保 WordPress 已加载
if (!defined('ABSPATH')) {
    exit; // 禁止直接访问
}

// 定义数据库表名
global $visitor_tracker_table;
$visitor_tracker_table = 'wp_visitor_logs';

// 插件激活时创建数据库表
function vt_create_table() {
    global $wpdb, $visitor_tracker_table;
    $charset_collate = $wpdb->get_charset_collate();
    
    // 创建数据库表
    $sql = "CREATE TABLE IF NOT EXISTS $visitor_tracker_table (
        id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
        timestamp DATETIME DEFAULT CURRENT_TIMESTAMP,
        visitor_type VARCHAR(50),
        user_agent TEXT,
        ip_address VARCHAR(100),
        spider_name VARCHAR(100)
    ) $charset_collate;";
    
    require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
    dbDelta($sql);
}
register_activation_hook(__FILE__, 'vt_create_table');

// 插件停用时删除数据库表
function vt_remove_table() {
    global $wpdb, $visitor_tracker_table;
    $sql = "DROP TABLE IF EXISTS $visitor_tracker_table";
    $wpdb->query($sql);
}
register_deactivation_hook(__FILE__, 'vt_remove_table');

// 访问记录处理函数
function vt_log_visitor() {
    global $wpdb, $visitor_tracker_table;
    
    // 获取访客的 IP 地址
    $ip_address = $_SERVER['REMOTE_ADDR'];
    
    // 获取 User-Agent
    $user_agent = $_SERVER['HTTP_USER_AGENT'];
    
    // 判断是否为搜索引擎蜘蛛
    $spiders = ['Googlebot', 'Bingbot', 'Slurp', 'DuckDuckBot', 'Baiduspider', 'YandexBot', 'Sogou', 'Exabot'];
    $is_spider = false;
    $spider_name = '';
    
    foreach ($spiders as $spider) {
        if (strpos($user_agent, $spider) !== false) {
            $is_spider = true;
            $spider_name = $spider;
            break;
        }
    }
    
    // 记录访客或蜘蛛
    $visitor_type = $is_spider ? 'Spider' : 'Visitor';
    
    // 将访问记录保存到数据库
    $wpdb->insert(
        $visitor_tracker_table,
        [
            'visitor_type' => $visitor_type,
            'user_agent' => $user_agent,
            'ip_address' => $ip_address,
            'spider_name' => $is_spider ? $spider_name : null
        ]
    );
}

// 捕获所有页面请求
add_action('wp_head', 'vt_log_visitor');

// 创建管理页面以查看记录
function vt_add_admin_menu() {
    add_menu_page(
        'Visitor Tracker Logs', // 页面标题
        'Visitor Tracker', // 菜单标题
        'manage_options', // 权限要求
        'visitor-tracker-logs', // 菜单 slug
        'vt_display_logs', // 回调函数
        'dashicons-visibility', // 图标
        30 // 位置
    );
}
add_action('admin_menu', 'vt_add_admin_menu');

// 显示日志的回调函数
function vt_display_logs() {
    global $wpdb, $visitor_tracker_table;
    
    $logs = $wpdb->get_results("SELECT * FROM $visitor_tracker_table ORDER BY timestamp DESC LIMIT 20");
    
    echo '<div class="wrap">';
    echo '<h1>Visitor Tracker Logs</h1>';
    
    if ($logs) {
        echo '<table class="wp-list-table widefat fixed striped">';
        echo '<thead><tr><th>ID</th><th>Timestamp</th><th>Visitor Type</th><th>IP Address</th><th>Spider Name</th><th>User Agent</th></tr></thead>';
        echo '<tbody>';
        
        foreach ($logs as $log) {
            echo '<tr>';
            echo '<td>' . $log->id . '</td>';
            echo '<td>' . $log->timestamp . '</td>';
            echo '<td>' . $log->visitor_type . '</td>';
            echo '<td>' . $log->ip_address . '</td>';
            echo '<td>' . ($log->spider_name ? $log->spider_name : '-') . '</td>';
            echo '<td>' . $log->user_agent . '</td>';
            echo '</tr>';
        }
        
        echo '</tbody>';
        echo '</table>';
    } else {
        echo '<p>No logs available.</p>';
    }
    
    echo '</div>';
}

解释:

  1. 插件头部信息Plugin NameDescriptionVersion 等字段描述了插件的基本信息。
  2. 数据库表创建
    • 插件激活时会创建一个名为 wp_visitor_logs 的表,存储访问记录。表中包括字段 idtimestampvisitor_type(访客类型)、user_agent(用户代理)、ip_address(IP 地址)、spider_name(蜘蛛名称)。
  3. 访问记录
    • 通过 wp_head 钩子函数,每次访问页面时会记录访问者的信息。如果访问者是搜索引擎蜘蛛,则会记录蜘蛛的名称;否则,记录访客的 IP 地址。
  4. 管理界面
    • 插件创建了一个 WordPress 后台菜单项,允许管理员查看最近的访问日志。显示的字段包括访问时间、访客类型、IP 地址、蜘蛛名称和用户代理。

4. 启用插件

  1. visitor-tracker 文件夹上传到你的 WordPress 插件目录中:wp-content/plugins/
  2. 登录到 WordPress 后台,进入 插件 页面,启用 Visitor Tracker 插件。

5. 查看访问记录

启用插件后,后台会出现一个新的菜单项 Visitor Tracker,点击该菜单可以查看最近的访问日志,包括访客的 IP 地址、蜘蛛名称和用户代理。

总结

这个插件实现了以下功能:

  • 捕获并记录访问网站的访客和搜索引擎蜘蛛。
  • 对于蜘蛛,记录蜘蛛类型(如 Googlebot、Bingbot 等)。
  • 对于访客,记录 IP 地址。
  • 提供一个后台界面,让管理员可以查看记录的日志。

如果你有任何进一步的定制要求,或者需要帮助解决其他问题,请随时告诉我!

发布者:myrgd,转载请注明出处:https://www.object-c.cn/4411

Like (0)
Previous 2024年11月22日 下午4:05
Next 2024年11月22日 下午5:54

相关推荐

  • Flutter 在 PC 端多窗口支持方面的进展备受关注的功能,已在 Ubuntu/Canonical 展示

    Flutter 在 PC 端多窗口支持方面的进展是一个备受关注的功能,它的目标是进一步提升 Flutter 的跨平台能力。最近,Flutter 团队与 Canonical 合作,在 Ubuntu 平台上展示了多窗口功能的新成果。这一进展对开发者和终端用户来说都有重要意义,以下是相关细节分析: 展示细节多窗口功能亮相Flutter 的多窗口支持在 Ubuntu…

    2024年12月2日
    00
  • 多方面的优化包括启动时间、React Native 速度提升 550% 运行时性能以及渲染效率的提升

    React Native 速度提升 550% 可能涉及多方面的优化,包括启动时间、运行时性能以及渲染效率的提升。这通常是通过框架改进、代码优化和工程实践的结合来实现的。以下是实现 React Native 性能大幅提升的一些关键方法和策略: 1. 启动时间优化 1.1 减少 JS Bundle 大小 1.2 预加载资源 1.3 使用优化的原生模块 2. 渲染…

    2024年12月7日
    00
  • 实现微信支付提现api接口教程

    微信支付的提现功能,通常是通过调用 企业付款到零钱 API 或 企业付款到银行卡 API 来实现的。以下是如何使用微信支付提现 API 的详细教程,包括其前置条件、接口调用以及注意事项。 1. 准备工作 1.1. 开通微信支付商户号 1.2. 配置证书 将这些文件保存在你的服务器上,用于发起 HTTPS 请求。 1.3. 获取 API 密钥 2. 企业付款到…

    2024年11月24日
    00
  • 在使用 uni-app 开发小程序或移动端应用时 title image失效问题

    在使用 uni-app 开发小程序或移动端应用时,若发现 分享的标题(title) 和 图片(image) 配置无效,可能是由于配置错误、平台限制或代码逻辑问题。以下是排查和解决问题的详细指南: 1. 确保正确使用分享 API onShareAppMessage(自定义转发) 确保在 pages 的页面代码中正确使用了 onShareAppMessage 方…

    2024年11月25日
    00
  • 微信小程序配置onShareTimeline分享到朋友圈的问题

    在微信小程序中使用 onShareTimeline 来实现分享到朋友圈的功能时,可能会遇到开发者工具中的功能灰色不可用或真机调试时无法分享的问题。下面是一些可能的原因和解决方法: 1. 检查小程序的分享功能是否已经启用 确保你在小程序的 app.json 或者页面的 json 配置文件中正确配置了分享功能。 在 app.json 或页面的 json 文件中添…

    2024年11月24日
    00
  • 微信小程序的 RequestTask.onChunkReceived 接口接收二进制数据流

    微信小程序的 RequestTask.onChunkReceived 接口允许接收分块的二进制数据流(如视频或音频流),但在小程序环境中,由于不支持 TextDecoder,处理这些数据时需要采用其他方法。 解析数据流的方案 模拟 TextDecoder 功能 如果需要将 ArrayBuffer 转换为字符串(如 UTF-8 编码),可以通过自定义方法模拟 …

    2024年11月26日
    00
  • 如何使用uni-app-qrcode插件生成二维码?

    以下是使用uni-app-qrcode插件生成二维码的详细步骤: 安装插件 或者使用yarn进行安装: 引入插件 使用插件生成二维码 上述代码中,首先定义了要编码到二维码中的内容content和生成二维码的配置选项options,然后通过this.$refs.qrcodeCanvas获取页面中的canvas元素,最后调用QRCode.make方法生成二维码。…

    2024年12月22日
    00
  • 安卓用微信作为第三方登录,登录授权界面调用

    在 Android 应用中实现微信第三方登录,可以通过调用微信提供的开放平台 SDK 来完成。以下是实现微信登录授权界面的完整步骤: 1. 准备工作 注册微信开放平台应用 下载微信 SDK 2. 项目配置 引入微信 SDK 将 SDK 文件添加到项目的 libs 和 jniLibs 目录下: 在 build.gradle 中添加依赖: 配置权限 在 Andr…

    2024年12月3日
    00
  • 在 uni-app 小程序中,使用 uni.getLocation 获取用户位置信息等

    在 uni-app 小程序 中,使用 uni.getLocation 获取用户位置后,可以通过 腾讯地图 API 将经纬度转化为详细的地址信息(如省、市、区、街道等)。以下是完整的操作流程: 1. 前置准备:开通腾讯地图 API 服务注册腾讯位置服务账号:登录 腾讯位置服务官网。创建项目并获取 Key:进入 控制台,创建新应用,选择 小程序。获取生成的 ke…

    2024年11月26日
    00
  • Web实时通信和 @microsoft/signalr 微软开发的一款基于 SignalR 的实时通信库

    Web实时通信和 @microsoft/signalr@microsoft/signalr 是微软开发的一款基于 SignalR 的实时通信库,专为 Web 应用提供强大的实时通信功能。SignalR 的主要特点包括支持双向通信、自动选择传输协议(WebSockets、Server-Sent Events 或 Long Polling)以及简化的服务器与客户…

    2024年12月1日
    00
  • 微信小程序中,通过Node.js连接本地 MySQL 实现数据的增删改查

    在微信小程序中,通过Node.js连接本地 MySQL 实现数据的增删改查的过程,可以分为以下几个步骤: 1. 准备工作 必要工具: 2. 搭建 Node.js 后端服务 安装依赖 在 Node.js 项目中,使用 npm init 初始化项目,并安装以下依赖: express: 用于搭建 Web 服务。 mysql: 用于连接和操作 MySQL 数据库。 …

    2024年12月9日
    00
  • 在Java中 ArrayList 和 LinkedList 实现 List 接口类

    在Java中,ArrayList 和 LinkedList 都是实现了 List 接口的类,但它们在底层实现和使用场景上有显著的区别。以下是它们的主要区别: 1. 底层实现ArrayList基于动态数组实现。元素是连续存储的,每个元素都可以通过索引直接访问。LinkedList基于双向链表实现。每个元素由节点(Node)存储,节点包含数据和前后节点的引用。 …

    2024年12月2日
    00
  • 微信小程序使用 map 组件实现拖动地图并获取当前地图中心的经纬度

    在微信小程序中,使用 map 组件可以轻松实现拖动地图并获取当前地图中心的经纬度。以下是实现步骤和代码示例: 实现思路 代码实现 1. 页面 WXML 添加 map 组件并设置属性。 2. 页面 WXSS 定义地图样式和中心点标记样式。 3. 页面 JS 初始化地图中心点的经纬度,并监听地图拖动。 4. 中心点图标 将一个中心标记图标放置在地图中间。可以在小…

    2024年11月25日
    00
  • Solving the Makefile Missing Separator Stop Error in VSCode ……

    在 VSCode 中处理 Makefile 的 missing separator. Stop 错误,通常是因为 Makefile 中的命令行前没有用Tab 键缩进,而使用了空格。Makefile 规定,配方(recipe)中的每个命令行必须以Tab 键开头,而不是空格。 解决方法1. 检查 Makefile 的缩进打开报错的 Makefile 文件。找到出…

    2024年12月2日
    00
  • Python 的 json模块序列化数据从文件里读取出来或存入文件

    Python 的 json 模块用于处理 JSON 格式的数据,可以将 JSON 数据与 Python 数据结构之间相互转换。以下是具体用法,包括从文件读取 JSON 数据以及将数据写入文件: 1. 将 JSON 数据从文件中读取到 Python 数据结构 代码示例: 解析过程: 2. 将 Python 数据结构写入到文件中(序列化为 JSON) 代码示例:…

    2024年11月26日
    00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

在线咨询: QQ交谈

邮件:723923060@qq.com

关注微信