Access Specifier Manipulation解决方案(Spring)

漏洞成因:field.setAccessible(true)

AccessibleObject允许程序员绕过由java说明符提供的access control检查。并反过来更改私有字段或调用私有方法、行为。

这里我只在网上查到了使用spring框架下的解决方案:ReflectionUtils.makeAccessible(field);

 

package com.example.springboot.entities;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.Date;

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Employee {

	private Integer id;
    private String lastName;

    private String email;
    //1 male, 0 female
    private Integer gender;
    private Department department;
    private Date birth;

    @Override
    public String toString() {
        return "Employee{" +
                "id=" + id +
                ", lastName='" + lastName + '\'' +
                ", email='" + email + '\'' +
                ", gender=" + gender +
                ", department=" + department +
                ", birth=" + birth +
                '}';
    }
}

如下代码是测试代码:

        Object obj = Employee.class.newInstance();
        Class<Employee> clazz = Employee.class;
        //通过属性名获取属性
        Field field = clazz.getDeclaredField("lastName");

        System.out.println(1+"-----"+field.getName());
        //这里如果不设置true,默认为false,只有在实体类employee
        //的属性修饰符为public时才可以访问的到,否者访问不到属性的值,也无法为其设置具体的值
        System.out.println(2+"-----"+field.getType());
        System.out.println(3+"-----"+field.isAccessible());
        //field.setAccessible(true);
        //通过这里ield.setAccessible(true);的设置为访问权限为true即可访问,但是此处的方法会被fortify扫描出Access Specifier Manipulation漏洞,
        // 如果你用的是spring可以通过另一个反射工具类去设置,这样做更安全,
        ReflectionUtils.makeAccessible(field);
        System.out.println(4+"-----"+field.isAccessible());
        if(field.getType() == String.class){
            field.set(obj,"Chow");
        }
        System.out.println(5+"-----"+obj.toString());

执行结果:

1-----lastName
2-----class java.lang.String
3-----false
4-----true
5-----Employee{id=null, lastName='Chow', email='null', gender=null, department=null, birth=null}

 

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值