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

相关推荐

  • 在 Go 语言中,对文件的基础操作介绍

    在 Go 语言中,文件操作是基础技能之一,主要通过 os、io 和 io/ioutil 等标准库完成。以下是对文件操作的全面介绍,帮助你在 Go 语言的“成神之路”上迈出关键一步! 1. 创建文件使用 os.Create 创建文件,如果文件已存在会被清空。示例代码 2. 打开文件使用 os.Open 打开文件(只读模式),使用 os.OpenFile 可以指…

    2024年12月2日
    00
  • Python与Jupyter Notebook中的数据可视化实现

    数据可视化是分析和展示数据的重要手段,而 Python 与 Jupyter Notebook 是构建交互式数据可视化的重要工具组合。以下是如何在 Python 和 Jupyter Notebook 中实现数据可视化的详细介绍。 1. 常用数据可视化库Python 中有多个强大的可视化库,以下是几个常用的:1.1 Matplotlib特点:功能强大、灵活,但语…

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

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

    2024年11月25日
    00
  • 在 Mac 上,Google Chrome 无法打开网页的问题

    在 Mac 上,Google Chrome 无法打开网页可能由多个因素引起。以下是一些常见的原因及解决方法: 1. 检查网络连接 确保你的 Mac 已连接到互联网,尝试使用其他设备(如手机或其他电脑)打开相同的网页,确认问题是否出在设备本身或网络。 2. 清除浏览器缓存和历史记录 长期积累的缓存和浏览数据可能导致加载问题。尝试清除缓存和历史记录: 3. 禁用…

    2024年11月23日
    00
  • 远程仓库 ,从GitHub拉取代码失败的解决办法

    从GitHub拉取代码失败通常由以下几种原因引起:网络问题、认证失败、远程仓库配置错误等。以下是常见的失败场景及解决办法。 1. 网络问题症状连接超时。报错如:fatal: unable to access ‘https://github.com/…’: Failed to connect to github.com port 443: Connecti…

    2024年11月28日
    00
  • uni-app 一个使用 Vue.js 开发所有前端应用的框架跨端开发的优势

    uni-app 是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到 iOS、Android、Web(响应式)、以及各种小程序(微信 / 支付宝 / 百度 / 头条 / QQ / 钉钉)等多个平台,其跨端开发具有以下优势: 开发效率高 跨平台兼容性好 性能优化 生态丰富 学习成本低

    2024年12月22日
    00
  • 在微信服务号中,通过设置自动回复,可以在新用户关注时引导其进入小程序

    在微信服务号中,通过设置自动回复,可以在新用户关注时引导其进入小程序。以下是实现的方法和建议: 1. 使用文本自动回复引导在服务号后台设置关注自动回复,可以通过一段欢迎语并附带小程序链接,引导用户点击进入。示例文案: 小程序链接格式: 设置路径:进入 微信公众平台 > 自动回复 > 关注后自动回复,添加以上文案。 2. 使用卡片自动回复引导你可以直接在自动回…

    2024年12月3日
    00
  • 使用 Webpack 5 优化构建减少生成文件的体积提升前端性能

    在使用 Webpack 5 时,优化构建以减少生成文件的体积是提升前端性能的重要一步。以下是一些常见的优化方法和策略: 1. 开启生产模式 确保构建时使用生产模式,Webpack 会自动应用多种优化(如代码压缩、Tree Shaking 等): 或在配置文件中明确设置: 2. 启用 Tree Shaking Tree Shaking 是 Webpack 内置…

    2024年12月3日
    00
  • Redis中如何使用lua脚本redis与lua的相互调用方法

    在 Redis 中,Lua 脚本 提供了一种强大的方式来执行原子操作,可以在 Redis 服务器上直接执行 Lua 代码,从而避免了多次网络往返和保证操作的原子性。Redis 内置了对 Lua 脚本的支持,通过 EVAL 命令来执行脚本,EVALSHA 则用于执行已经加载到 Redis 服务器的脚本。1. Redis 与 Lua 脚本的基本交互1.1 基本的…

    2024年11月28日
    00
  • 在使用 PHP 抓取 HTTPS 资源时,会遇到一些常见问题

    在使用 PHP 抓取 HTTPS 资源时,可能会遇到一些常见问题。这些问题通常与 SSL 配置、证书验证或 PHP 设置相关。以下是常见问题及其解决方法的汇总: 1. SSL 证书验证失败问题描述当使用 file_get_contents、cURL 等方法访问 HTTPS 资源时,可能会遇到类似以下错误: 解决方法更新 cacert.pem 文件下载最新的根…

    2024年12月2日
    00
  • 微信小程序错误提示 does not have a method “onShareTimeline”

    当在微信小程序中尝试实现分享到朋友圈功能时,如果你在控制台遇到 does not have a method “onShareTimeline” 错误,这通常是由于以下原因之一: 1. 检查基础库版本 onShareTimeline 是在小程序基础库 2.11.3 及以上版本支持的。如果当前开发者工具的基础库版本较低,会导致方法无法找到。 解决方法: 2. …

    2024年11月26日
    00
  • Windows 系统中使用 VSCode 配置 C/C++ 开发环境教程

    在 Windows 系统中使用 VSCode 配置 C/C++ 开发环境,可以高效编写和调试代码。以下是详细步骤: 1. 安装必要工具 1.1 安装 VSCode 1.2 安装 C/C++ 编译器 推荐使用 MinGW-w64: 验证是否安装成功: 2. 安装 VSCode 插件 打开 VSCode 的扩展市场(Ctrl+Shift+X),搜索并安装以下插件…

    2024年11月26日
    00
  • 在IOS中使用WebView内嵌H5页面,使用a标签点击跳转无效的问题

    在 iOS 中,使用 WebView 嵌入 H5 页面时,可能会遇到点击 <a> 标签跳转无效的问题。这个问题通常是由于 iOS WebView 的默认行为或配置导致的,特别是在使用 UIWebView 或 WKWebView 时。以下是几种解决方法,可以帮助解决这个问题。 1. 使用 WKWebView 替代 UIWebView 首先,确保你使…

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

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

    2024年12月7日
    00
  • Docker快速部署Nginx、Redis、MySQL、Tomcat以及制作镜像方法

    使用 Docker 快速部署 Nginx、Redis、MySQL、Tomcat 以及制作镜像 通过 Docker,开发者可以快速部署和管理各种服务。本文介绍如何快速使用 Docker 部署 Nginx、Redis、MySQL 和 Tomcat,以及如何制作自定义镜像。 1. Docker 基础准备 安装 Docker 如果还未安装 Docker,可按照以下步…

    2024年11月26日
    00

发表回复

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

联系我们

在线咨询: QQ交谈

邮件:723923060@qq.com

关注微信