码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 记录一下:基于nginx配置的封禁真实IP


    nginx

    • Situation(背景)
    • Task(任务)
    • Action(行动)
      • 1:方法1:使用nginx 自带的deny 和 allow 来实现
      • 2:方法2:添加配置
    • Result(结果)

    Situation(背景)

    服务器正在被使用

    Task(任务)

    封禁指定网段的IP

    Action(行动)

    1:方法1:使用nginx 自带的deny 和 allow 来实现

    由于nginx封禁的是抵达服务器前的那个代理的ip,并非真实IP所以失败了

    2:方法2:添加配置

    
    http {
        ...
        geo $ip_addr $real_ip {
            default               "";
            219.248.141.0/24      "blocked";
        }
    # 首先定义了一个名为 $ip_addr 的变量,它将从客户端请求中提取出 IP 地址;
    # 然后定义了一个名为 $real_ip 的变量,它将根据 $ip_addr 的值获取到对应的真实 IP 地址;
    # 接着通过 geo 块对真实 IP 进行判断,如果属于 219.248.141.0/24 网段,则将其设置为字符串 "blocked",否则将其设置为默认值 "";
    # 最后使用 map 块将 $real_ip 映射到一个变量 $block,如果 $real_ip 被设置为 "blocked",则将 $block 设置为 1,否则设置为 0。
        map $real_ip $block {
            default            0;
            "blocked"          1;
        }
    # 在 Nginx 的主配置块中定义了一个 server 块,在这里可以通过 if 指令判断是否需要阻止访问,如果 $block 被设置为 1,则返回 HTTP 403 错误。
        server {
            ...
    
            if ($block) {
                return 403;
            }
    
            ...
        }
        ...
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    之后如果需要添加封禁的ip在geo中添加就好。

    Result(结果)

  • 相关阅读:
    SpringMVC 04 RestFul风格
    有什么docker容器可以监视本地请求的码
    springboot仓库管理系统
    Hadoop 集群搭建(docker版本)
    idea2018 编译打包报错java.lang.StackOverflowError
    C++类型安全
    苹果或推出多屏幕iPhone;​爱彼迎CEO:办公室时代已过去;Apache Flink 1.15 发布|极客头条
    剑指Offer05-替换空格
    Flowable实战:启动事件与结束事件
    【uni-app从入门到实战】数据绑定、事件、生命周期
  • 原文地址:https://blog.csdn.net/m0_51828898/article/details/132599562
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号