Nginx防护配置,wordpress子比主题Nginx防攻击配置!

28 次浏览次阅读
没有评论

Nginx配置留档,防止对data:image/svg的无用请求直接444,增加了后台访问限制和登陆限制,每个ip的请求次数限制等等。

Apache
# 每个 IP 每秒最多 5 次 /wp-admin/admin-ajax.php
limit_req_zone $binary_remote_addr zone=ajax_limit:10m rate=5r/s;

# 每个 IP 每秒最多 2 次 /user-sign
limit_req_zone $binary_remote_addr zone=usersign_limit:10m rate=2r/s;

# 每个 IP 每秒最多 2 次 /oauth/
limit_req_zone $binary_remote_addr zone=oauth_limit:10m rate=2r/s;

    
server
{
    listen 80;
		listen 443 ssl http2;
    server_name mr010.com;
    index index.php index.html index.htm default.php default.htm default.html;
    root /www/wwwroot/keji_blog;
    #CERT-APPLY-CHECK--START
    # 用于SSL证书申请时的文件验证相关配置 -- 请勿删除
    include /www/server/panel/vhost/nginx/well-known/mr010.com.conf;
    #CERT-APPLY-CHECK--END

    #SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则
    #error_page 404/404.html;
    #HTTP_TO_HTTPS_START
    set $isRedcert 1;
    if ($server_port != 443) {
        set $isRedcert 2;
    }
    if ( $uri ~ /\.well-known/ ) {
        set $isRedcert 1;
    }
    if ($isRedcert != 1) {
        rewrite ^(/.*)$ https://$host$1 permanent;
    }
    #HTTP_TO_HTTPS_END
    ssl_certificate    /www/server/panel/vhost/cert/mr010.com/fullchain.pem;
    ssl_certificate_key    /www/server/panel/vhost/cert/mr010.com/privkey.pem;
    ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;
    ssl_ciphers EECDH+CHACHA20:EECDH+CHACHA20-draft:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5;
    ssl_prefer_server_ciphers on;
    ssl_session_cache shared:SSL:10m;
    ssl_session_timeout 10m;
    add_header Strict-Transport-Security "max-age=31536000";
    error_page 497  https://$host$request_uri;

    #SSL-END

    #ERROR-PAGE-START  错误页配置,可以注释、删除或修改
    #error_page 404 /404.html;
    #error_page 502 /502.html;
    #ERROR-PAGE-END

    #PHP-INFO-START  PHP引用配置,可以注释或修改
    include enable-php-74.conf;
    #PHP-INFO-END

    #REWRITE-START URL重写规则引用,修改后将导致面板设置的伪静态规则失效
    include /www/server/panel/vhost/rewrite/mr010.com.conf;
    #REWRITE-END

    #禁止访问的文件或目录
    location ~ ^/(\.user.ini|\.htaccess|\.git|\.env|\.svn|\.project|LICENSE|README.md)
    {
        return 404;
    }

    #一键申请SSL证书验证目录相关设置
    location ~ \.well-known{
        allow all;
    }

    #禁止在证书验证目录放入敏感文件
    if ( $uri ~ "^/\.well-known/.*\.(php|jsp|py|js|css|lua|ts|go|zip|tar\.gz|rar|7z|sql|bak)$" ) {
        return 403;
    }

    location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
    {
        expires      30d;
        error_log /dev/null;
        access_log /dev/null;
    }

    location ~ .*\.(js|css)?$
    {
        expires      12h;
        error_log /dev/null;
        access_log /dev/null;
    }
    
    #毛毛二开=================================开始
    location ~* "^/data:image/svg" {
        return 444;
    }
    # 直接限制前后台 2025-11-25 毛毛添加
    location ~* /wp-admin {
        allow 117.174.24.129;
        deny all;
        limit_req zone=ajax_limit burst=10 nodelay;
    }
    location = /wp-login.php {
        allow 117.174.24.129;
        deny all;
    }
    # 缓存图片、svg 等静态资源  2025-11-25 毛毛添加
    location ~* \.(svg|jpg|jpeg|png|gif|ico|woff|woff2|ttf)$ {
        expires 30d;
        access_log off;
        add_header Cache-Control "public";
    }
    
     # 限制 wp-admin/admin-ajax.php
    location ~ ^/wp-admin/admin-ajax\.php$ {
        #增加自己的IP访问
        allow 117.174.24.129;
        allow 127.0.0.1;
        deny all;
        
        limit_req zone=ajax_limit burst=10 nodelay;
        # 阻止常见爬虫 UA
        if ($http_user_agent ~* (python|curl|scrapy|spider|bot) ) {
            return 403;
        }
        # PHP 处理
        include fastcgi_params;
        fastcgi_pass unix:/run/php-fpm.sock;   # 按你的 PHP-FPM 实际路径改
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    }
    
    # 限制 /user-sign
    location ~ ^/user-sign {
        #增加自己的IP访问
        allow 117.174.24.129;
        allow 127.0.0.1;
        deny all;
        
        limit_req zone=usersign_limit burst=5 nodelay;
        if ($http_user_agent ~* (python|curl|scrapy|spider|bot) ) {
            return 403;
        }
        # WordPress rewrite
        try_files $uri /index.php?$args;
    }
    
    # 限制 /oauth 下所有路径
    location ^~ /oauth {
        limit_req zone=oauth_limit burst=5 nodelay;
        
        if ($http_user_agent ~* (python|curl|scrapy|spider|bot) ) {
            return 403;
        }
    }
    #毛毛二开==============结束
    
    
    access_log  /www/wwwlogs/mr010.com.log;
    error_log  /www/wwwlogs/mr010.com.error.log;
}
正文完
 0
评论(没有评论)

辉哥

一言一句话
-「
最新文章
淘宝店铺转让需要哪些条件,新手能操作吗?

淘宝店铺转让需要哪些条件,新手能操作吗?

淘宝店铺转让需要哪些条件?新手能操作吗?2026最新全攻略 随着电商竞争日益激烈,很多卖家选择淘宝店铺转让来快...
智能客服机器人的优势在哪里?自动化客服系统有哪些核心功能?

智能客服机器人的优势在哪里?自动化客服系统有哪些核心功能?

智能客服机器人的优势在哪里?自动化客服系统有哪些核心功能? 在数字化时代,企业客户服务正迎来深刻变革。智能客服...
智能客服机器人应用了哪些技术?市面上AI客服公司排名如何?

智能客服机器人应用了哪些技术?市面上AI客服公司排名如何?

智能客服机器人应用了哪些技术?市面上AI客服公司排名如何? 随着数字化时代的加速演进,智能客服机器人已成为企业...
智能客服机器人的作用是什么?这种AI机器人技术如何提升客户满意度?

智能客服机器人的作用是什么?这种AI机器人技术如何提升客户满意度?

智能客服机器人的作用是什么?这种AI机器人技术如何提升客户满意度? 在数字化时代,客户服务已成为企业核心竞争力...
智能客服机器人的功能与特点是什么?客服机器人的工作原理是怎样的?

智能客服机器人的功能与特点是什么?客服机器人的工作原理是怎样的?

智能客服机器人的功能与特点是什么?工作原理详解 在数字化时代,智能客服机器人已成为企业提升服务效率的核心工具。...
智能客服机器人的优点有哪些?AI客服如何帮助企业降低运营成本?

智能客服机器人的优点有哪些?AI客服如何帮助企业降低运营成本?

智能客服机器人的优点有哪些?AI客服如何帮助企业降低运营成本? 在数字化时代,企业越来越注重客户体验与运营效率...
知识库怎么建立才能好用?搭建过程中常见问题如何解决?

知识库怎么建立才能好用?搭建过程中常见问题如何解决?

知识库怎么建立才能好用?搭建过程中常见问题如何解决? 在数字化时代,企业知识库已成为提升客服效率、优化用户体验...
淘宝店铺流量提升软件是否可靠,是否影响店铺信誉?

淘宝店铺流量提升软件是否可靠,是否影响店铺信誉?

淘宝店铺流量提升软件是否可靠,是否影响店铺信誉? 在淘宝电商竞争日益激烈的2025-2026年,许多店主为了快...
知识库平台怎么选?AI知识库和传统知识库有何区别?

知识库平台怎么选?AI知识库和传统知识库有何区别?

知识库平台怎么选?AI知识库和传统知识库有何区别? 在企业数字化进程中,知识库平台已成为提升团队协作效率、沉淀...
AI训练系统如何运作?训练场对企业智能化转型有何意义?

AI训练系统如何运作?训练场对企业智能化转型有何意义?

AI训练系统如何运作?训练场对企业智能化转型有何意义? 在数字化时代,企业客服团队的快速成长直接影响服务质量和...
智能客服机器人的优缺点有哪些?企业如何合理部署这类系统?

智能客服机器人的优缺点有哪些?企业如何合理部署这类系统?

智能客服机器人的优缺点有哪些?企业如何合理部署这类系统? 在数字化时代,智能客服机器人已成为越来越多企业提升客...