首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为spring schedule作业添加@PreAuthorize角色

为spring schedule作业添加@PreAuthorize角色
EN

Stack Overflow用户
提问于 2019-03-01 10:16:45
回答 2查看 409关注 0票数 1

在我的后台,我添加了@PreAuthorize("hasRole(' ROLE_ADMIN ') )来允许用户访问服务层的功能。现在我想使用我的调度作业(ROLE_ADMIN调度)来访问这些服务,但显然它不能。我的问题是如何为调度作业添加springframework角色或生成用户主体?

代码语言:javascript
复制
@PreAuthorize("hasRole('ROLE_ADMIN')")
JsonNode loadSMS(String additionalPath) {
    .....
}
EN

回答 2

Stack Overflow用户

发布于 2019-03-01 10:32:00

或者使用另一个方法,该方法没有使用调度器调用的@PreAuthorize进行注释。将实现移动到这个新方法中,并更改现有的loadSMS以使用这个新方法来减少代码重复。否则,您可以在运行时添加角色,但我不认为这是一个很好的想法。

票数 1
EN

Stack Overflow用户

发布于 2019-03-01 10:33:35

你可以试试下面的代码

代码语言:javascript
复制
@Service
class SchedulerService {
    @Autowired
    private YourService service;

    @Scheduled(fixedRate = 600000L, initialDelay = 60000L)
    public void executeTask() throws IOException {
        RunAs.runAsAdmin(() -> {
          service.loadSMS(String additionalPath) {
        });
    }
}

public class RunAs {

    @FunctionalInterface
    public interface RunAsMethod {
        default void run() {
            try {
                runWithException();
            } catch (Exception e) {

            }
        }
        void runWithException() throws Exception;
    }

    public static void runAsAdmin(final RunAsMethod func) {
        final AnonymousAuthenticationToken token = new AnonymousAuthenticationToken("adminUser", "adminPassword",
                ImmutableList.of(new SimpleGrantedAuthority("ROLE_ADMIN")));
        final Authentication originalAuthentication = SecurityContextHolder.getContext().getAuthentication();
        SecurityContextHolder.getContext().setAuthentication(token);
        func.run();
        SecurityContextHolder.getContext().setAuthentication(originalAuthentication);
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54937024

复制
相关文章

相似问题

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