获取java.lang.IllegalStateException:找不到线程绑定的请求

时间:2018-09-05 16:08:30

标签: java spring-mvc

当我尝试使用@Async注释时,出现错误提示。

java.lang.IllegalStateException: No thread-bound request found: Are you referring to request attributes outside of an actual web request, or processing a request outside of the originally receiving thread? If you are actually operating within a web request and still receive this message, your code is probably running outside of DispatcherServlet/DispatcherPortlet: In this case, use RequestContextListener or RequestContextFilter to expose the current request.

代码:

@Async
@Override
@Transactional
public void triggerEmailCommunication(List<String> eventCode, Integer authorizationId, Integer claimId,
        boolean callMethod) {
    Map<String, Object> emailBody = new HashMap<>();
    try {

        if (callMethod) {
            LOGGER.info("Communication async flow triggerEmailCommunication method starts.");
            emailBody = emailBodyObject(authorizationId, claimId, eventCode);
  }


private Map<String, Object> emailBodyObject(Integer authorizationId, Integer claimId, List<String> eventCode)
        throws CareBusinessServiceException {
    LOGGER.info("EmailBodyObject method starts.");
    Map<String, Object> emailBody = new HashMap<String, Object>();
    EmailClaimDetailsVO emailClaimDetails = new EmailClaimDetailsVO();
    ClaimAuthorizationVO claimAuthVO = new ClaimAuthorizationVO();
    Claim claim = new Claim();
    Authorization authorization = new Authorization();
    List<String> rejectReasonList = new ArrayList<>();
    Provider provider = new Provider();
    String providerName = null;
    String claimIntimationNbr = null;
    String authorizationNbr = null;
    SimpleDateFormat formatter = new SimpleDateFormat(AmhiConstants.DATE_FORMAT_DD_MM_YYYY);
    try {
        Integer claimIntimationId = null;
        if (null != claimId) {
            claim = enableBusinessService.retrieveClaimDetails(claimId);
     } catch(Exception e) {
     }
}

DAO层

@Override
public Claim retrieveClaimIdRecord(Integer claimId) {
    CriteriaBuilder builder = manager.getCriteriaBuilder();
    CriteriaQuery<Claim> criteriaQuery = builder.createQuery(Claim.class);
    Root<Claim> root = criteriaQuery.from(Claim.class);
    ArrayList<Predicate> conditions = new ArrayList<>();
    conditions.add(builder.equal(root.get(Claim_.claimId), claimId));
    criteriaQuery.select(root).where(conditions.toArray(new Predicate[] {}));
    javax.persistence.Query query = manager.createQuery(criteriaQuery);
    List<Claim> claims = query.getResultList();
    if(CollectionUtils.isNotEmpty(claims)){
        return claims.get(0);
    }
    return new Claim();
}

正在从数据库中检索值。但是如上所述,我已经超越了例外。

1 个答案:

答案 0 :(得分:0)

在我的情况下,它发生在我在请求级别创建一个bean并尝试从另一个使用@Async注释创建的线程中访问它时。 Bean信息仅存储在原始线程的本地线程中。

在@Async通知之后,您是否正在使用在函数或后续函数的基本线程本地线程中创建并存储的内容?

@Async创建另一个线程,但不复制导致问题的原始线程的本地线程。

查看此内容-https://jira.spring.io/browse/SPR-6873