如何解决从响应式弹簧服务调用阻塞假客户端
.doOnNext(user1 -> {
ResponseEntity<Void> response = recorderClient.createuserProfile(new UserProfileDto().principal(user1.getLogin()));
if (!response.getStatusCode().equals(HttpStatus.OK)) {
log.error("recorder backend Could not create user profile for user: {} ",user1.getLogin());
throw new RuntimeException("recorder backend Could not create user profile for login name" + user1.getLogin());
}
})
调用已执行,但是当我尝试从响应式安全上下文(在请求拦截器中)检索 jwt 令牌时,如下所示:
public static Mono<String> getCurrentUserJWT() {
return reactivesecuritycontextholder
.getContext()
.map(SecurityContext::getAuthentication)
.filter(authentication -> authentication.getCredentials() instanceof String)
.map(authentication -> (String) authentication.getCredentials());
}
....
SecurityUtils.getCurrentUserJWT().blockOptional().ifPresent(s -> template.header(AUTHORIZATION_HEADER,String.format("%s %s",BEARER,s)));
上下文为空。由于我对反应式 spring 还很陌生,所以我肯定会胡思乱想一些愚蠢而重要的事情。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。