.Net WebAPI 增加对接口的IP访问限制

该代码定义了一个自定义的授权过滤器AuthorizeAttrbute,用于检查用户IP是否在白名单中。如果IP不在白名单内,返回401未经授权的响应。同时,它使用缓存来存储IP的访问权限状态,过期时间为12小时。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 public class AuthorizeAttrbute : System.Web.Http.Filters.AuthorizationFilterAttribute
    {
        public override void OnAuthorization(System.Web.Http.Controllers.HttpActionContext actionContext)
        {
            var ipAddress = GetIpAddress(); // 获取用户ip
            object objCache = null;
            objCache = GetCache(ipAddress); // 获取缓存结果
            {
                if (objCache == null)
                {
                    if (!IpConfig(ipAddress))
                    {
                        //返回401
                        actionContext.Response = new HttpResponseMessage
                        {
                            Content = new StringContent("当前ip地址 " + ipAddress + " 无访问权限",
                                Encoding.GetEncoding("UTF-8"), "application/json"),
                            StatusCode = HttpStatusCode.Unauthorized
                        };
                        return;
                    }
                    else
                    {
                        SetCache(ipAddress, "1", 12); // Key,Value,失效时间
                    }
                }
            }
            base.OnAuthorization(actionContext);
        }

        public static bool IpConfig(string ip)
        {
            // 返回 ip 地址在白名单中的查找结果
            return new OdpIpWhiteListService().CheckIpExists(ip);
        }

        /// <summary>
        /// 获取当前应用程序指定CacheKey的Cache值
        /// </summary>
        /// <param name="CacheKey"></param>
        /// <returns></returns>
        public static object GetCache(string CacheKey)
        {
            System.Web.Caching.Cache objCache = HttpRuntime.Cache;
            return objCache[CacheKey];
        }
        /// <summary>
        ///  设置缓存
        /// </summary>
        /// <param name="CacheKey"></param>
        /// <param name="objObject"></param>
        /// <param name="expires_in"></param>
        public static void SetCache(string CacheKey, object objObject, double expires_in)
        {
            Cache objCache = HttpRuntime.Cache;
            objCache.Insert(CacheKey, objObject, null, DateTime.Now.AddHours(expires_in), Cache.NoSlidingExpiration);
        }
        /// <summary>
        ///   获取IP地址
        /// </summary>
        /// <returns></returns>
        public static string GetIpAddress()
        {
            string result = HttpContext.Current.Request.ServerVariables["HTTP_CDN_SRC_IP"]; // 判断CDN IP是否存在,如果存在获取真实ip
            if (string.IsNullOrEmpty(result))
                result = HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"]; // 获取发起请求的远程主机 ip

            if (string.IsNullOrEmpty(result))
                result = HttpContext.Current.Request.UserHostAddress;

            if (string.IsNullOrEmpty(result) || !IsIP(result))
                return "127.0.0.1";

            return result;
        }
        public static bool IsIP(string ip)
        {
            return Regex.IsMatch(ip, "^((2[0-4]\\d|25[0-5]|[01]?\\d\\d?)\\.){3}(2[0-4]\\d|25[0-5]|[01]?\\d\\d?)$");
        }
    }

接口上增加标记即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值