首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Java SecurityManager -如何确保一个方法只由另一个方法运行?

Java SecurityManager -如何确保一个方法只由另一个方法运行?
EN

Stack Overflow用户
提问于 2018-05-18 16:32:11
回答 2查看 297关注 0票数 -3

我希望B只由使用或处理敏感数据(例如:密钥、国家id等)的private方法A#getSensitiveData()运行。

public final class A{
    private transient final B sensitiveHolder; //set at Constructor
    public A(B sensitiveHolder){
        this.sensitiveHolder = sensitiveHolder;
    }
    private final byte[] getSensitiveData(){
        return sensitiveHolder.getSensitiveData();
    }
}

public final class B{
    private transient final byte[] sensitiveData;//encrypt and set at Constructor
    public final byte[] getSensitiveData(){
        //check if it is run by A#getSensitiveData(); if it is, decrypt by DEK and give plaintext.
    }
}

请考虑到代码会被混淆,所以请不要将任何包名作为String

我必须用SecurityManager#checkPrivilege()AccessController.doPrivileged()写什么才能达到这样的效果?

编辑:显然这是不同的,因为所谓的“答案”不包含任何代码。正常工作的代码比“哦,做这个做那个”更有价值。

EN

回答 2

Stack Overflow用户

发布于 2018-05-26 00:04:12

你可以这样做:

private boolean verify(final StackTraceElement e[]) {
    boolean doNext = false;
    for (final StackTraceElement s : e) {
        if (doNext && s.getClassName().equals("A") && s.getMethodName().equals("getSensitiveData"))
            return true;
        doNext = s.getMethodName().equals("getStackTrace");
    }
    return false;
}

并调用该方法:

public final byte[] getSensitiveData(StackTraceElement e[]){
    if (verify(e)) {
        // Do something good
    }
}

A类中,像这样调用B类:

return sensitiveHolder.getSensitiveData(Thread.currentThread().getStackTrace());

我不知道这是你需要的,还是接近那个。您可以使用ifequals部分中的值。我从this站点获取并修改了示例。

票数 5
EN

Stack Overflow用户

发布于 2018-05-29 14:15:16

如果您能够使用引入了StackWalker的JDK 9+,那么这类东西可能对您有效。这项技术似乎取代了sun.reflect.Reflection#getCallerClass(int)的使用。(我希望您不会指望得到与SecurityManager相关的答案。)

package asdf;

import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;

import java.util.EnumSet;
import java.util.List;
import java.util.stream.Collectors;

public class Asdf {

  @Test
  public void what() {
    get();
  }

  void get() {
    StackWalker.StackFrame stackFrame =
        StackWalker.getInstance(EnumSet.of(StackWalker.Option.RETAIN_CLASS_REFERENCE))
            .walk(stream -> {
              List<StackWalker.StackFrame> stackFrames = stream.collect(Collectors.toList());
              return stackFrames.get(1);
            });
    Assertions.assertEquals(Asdf.class, stackFrame.getDeclaringClass());
    Assertions.assertEquals("what", stackFrame.getMethodName());
    Assertions.assertEquals(0, stackFrame.getMethodType().parameterCount());

    // now do caller-sensitive stuff
  }
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50407042

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档