Java 如何从Micronaut中的控制器调用另一个rest api

Java 如何从Micronaut中的控制器调用另一个rest api,java,gradle,micronaut,Java,Gradle,Micronaut,由此,我在micronaut gradle应用程序中实现了从rest API方法调用另一个rest API。因为我的RESTAPI需要jwt令牌,所以我发送的令牌与我在当前请求中收到的令牌相同。我看到未经授权的错误,甚至令牌被传递。在这方面谁能帮忙。下面是我的代码 import io.micronaut.http.HttpRequest; import io.micronaut.http.HttpStatus; import io.appter.clientmgmt.models.ClientC

由此,我在micronaut gradle应用程序中实现了从rest API方法调用另一个rest API。因为我的RESTAPI需要jwt令牌,所以我发送的令牌与我在当前请求中收到的令牌相同。我看到未经授权的错误,甚至令牌被传递。在这方面谁能帮忙。下面是我的代码

import io.micronaut.http.HttpRequest;
import io.micronaut.http.HttpStatus;
import io.appter.clientmgmt.models.ClientContact;
import io.appter.clientmgmt.repositories.IClientContactRepository;
import io.micronaut.http.uri.UriTemplate;
import io.micronaut.security.annotation.Secured;
import io.micronaut.security.authentication.Authentication;
import io.micronaut.security.rules.SecurityRule;
import io.micronaut.http.annotation.*;
import io.micronaut.http.client.RxHttpClient;
import io.micronaut.http.client.annotation.Client;
import io.reactivex.Flowable;
import org.slf4j.LoggerFactory;
import org.slf4j.Logger;

import javax.validation.constraints.NotNull;
import java.security.Security;
import java.util.List;


@Controller("/clientcontact")
//@Secured(SecurityRule.IS_ANONYMOUS)
public class ClientContactController {
    private static final Logger LOG = LoggerFactory.getLogger(ClientContactController.class);
    private IClientContactRepository clientContactRepository;
    private final RxHttpClient httpClient;

    public ClientContactController(IClientContactRepository clientContactRepository,
                                   @Client("http://appterauthsvc-env.g2yapp2kcp.us-east-1.elasticbeanstalk.com") RxHttpClient httpClient) {
        this.clientContactRepository = clientContactRepository;
        this.httpClient = httpClient;
    }

    @Get("/")
    public HttpStatus index() {
        return HttpStatus.OK;
    }

    @Post("/")
    @Secured(SecurityRule.IS_AUTHENTICATED)
    public ClientContact createClientContact(@Body ClientContact clientContact,
                                             Authentication authentication,
                                             @Header("Authorization") String authorization) {
        try {
            List<ClientContact> existingClientContacts = clientContactRepository.getClientContactByClientId(clientContact.getClientId());
            LOG.info("current contacts count for the client " + clientContact.getClientId() + " is " + existingClientContacts.size());
            if (existingClientContacts.isEmpty()) {

                User userObj = new User();
                Long clientId = new Long(clientContact.getClientId());
                userObj.setClientId(clientId);
                userObj.setFirstName(clientContact.getFirstName());
                userObj.setLastName(clientContact.getLastName());
                userObj.setEmailId(clientContact.getEmailAddress());
                userObj.setPhoneNo(clientContact.getContactNumber());
                userObj.setIsActive(true);

                LOG.info("User Email set is: "+userObj.getEmailId());
                LOG.info("authorization token is: "+authorization);
                HttpRequest<?> request = HttpRequest.POST("/user", userObj).bearerAuth(authorization);

                String response = httpClient.toBlocking().retrieve(request);
                LOG.info("Request Object: "+ request.toString());
                LOG.info("Response Object: "+ response.toString());
                LOG.info("User API executed.. ");
            }


            return clientContactRepository.createClientContact(clientContact);
        } catch (Exception ex) {
            LOG.error(ex.getMessage(), ex);
            return null;
        }
    }
}
提前感谢。

可能是因为@HeaderAuthorization字符串授权返回的内容类似于承载人xyz。。。BeareAuth方法是将Bearer添加到字符串中,因此您将发送Bearer xyz

那就这么做吧,校长,授权,授权


另外,作为补充说明,您确实不应该在这个方法中阻止HTTP调用。这并不是世界末日,因为在本例中,您正在阻止一个IO线程,但是应该避免这种类型的代码。

感谢@James的更新。是的,一旦我在头中设置了令牌,它就工作得很好。现在我正在尝试使用micronaut令牌传播将令牌传递给我的API调用。我又看到了未经授权的错误。我严格遵守了公司的指示,尽管没有工作。有人对此有想法吗?@佛陀,这听起来像是一个单独的问题,应该是一个新的话题。请接受这个答案,如果它解决了你的问题克莱什,是的,你的回答解决了我的问题。正如您提到的,我已经为令牌传播创建了一个新的主题/问题