越权攻击解决

目录

🧂1.发现问题

🌭2.越权攻击

🥓3.越权分类 

🍿4.越权防范 


1.发现问题

当我们添加好用户地址的查、删的功能接口时,发现,正产情况下,登录用户只能查看自己的收货地址或删除自己的收货地址,但是测试发现,只要输入收获地址id竟然都可以查到。这也太可怕了吧!! 

2.越权攻击

        指应用在检查授权时存在纰漏,使得攻击者在获得低权限用户账户后,利用一些方式绕过权限检查,访问或者操作其他用户或者更高权限。

3.越权分类 

  • 1.水平越权
    • 攻击者尝试访问与他拥有相同权限的用户的资源
    • 例子: A用户可以直接操作到B用户的数据
  • 2.垂直越权
    • 一个低级别攻击者尝试访问高级别用户的资源
    • 例子:普通管理员登录,拼接浏览器地址,直接访问高级管理员的页面

4.越权防范 

  • 1.防范水平越
    • 权建立用户和可操作资源的绑定关系,用户对任何资源进行操作时,通过该绑定关系确保该资源是属于该用户所有的

实战应用 

在根据id查看收货地址时,同时校验是否是登陆者,根据拦截器获取threadLocal,进一步获取登录者信息,然后在添加条件时,判断用户id是否一致


    /**
     * 根据id删除地址
     *
     * @param addressId
     * @return
     */
    @Override
    public int deleteAddressById(Long addressId) {
        //防止水平越权,检验登录者id是否一致
        LoginUser loginUser = LoginInterceptor.threadLocal.get();
        int rows = addressMapper.delete(new QueryWrapper<AddressDO>().eq("id", addressId).eq("user_id", loginUser.getId()));
        return rows;
    }

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

会敲代码的小张

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值