楔子
在SpringMVC项目使用
@PostConstruct
,本意是系统启动的同时 发送邮件,但是出现错误Caused by: java.lang.IllegalStateException: No thread-bound request found: Are you referring to re
Caused by: 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.
at org.springframework.web.context.request.RequestContextHolder.currentRequestAttributes(RequestContextHolder.java:131)
at org.springframework.web.context.support.WebApplicationContextUtils.currentRequestAttributes(WebApplicationContextUtils.java:309)
at org.springframework.web.context.support.WebApplicationContextUtils.access$400(WebApplicationContextUtils.java:64)
问题描述
执行方法调用publicSendMail 提示request有问题,但是request是使用 @Resource
public HttpServletRequest req 注入的
@Controller
public class InitController extends SysBaseController {
/**
* 修改配置文件记录服务器启动次数
*/
@PostConstruct
public String modifyPublicTime() {
int pubTime = Integer.valueOf(PropUtils.getProp(SysConstant.PROP_PATH_PUBLIC_TIME).getProperty("publicTime"));
publicSendMail();
if (pubTime++ == 1) {
PropUtils.modifyProp(SysConstant.PROP_PATH_PUBLIC_TIME, SysConstant.PUBLIC_TIMESTAMP, SysUtils.getDateSplit_());
}
PropUtils.modifyProp(SysConstant.PROP_PATH_PUBLIC_TIME, SysConstant.PUBLIC_TIME, pubTime + "");
return RedirectAndForward.forward(UrlConstant.index) + SysUtils.getDateSpan();
}
public String publicSendMail() {
if (SysConstant.isFirstStart && !SysConstant.isLinux) {
SysConstant.isFirstStart = false;
File file = Paths.get(req.getRealPath("/WEB-INF/img/12b33.jpg")).toFile();
List<File> fileList = Arrays.asList(file);
mimeMailService.sendMimeMailPic("发版完成", PropUtils.getPropMail().getProperty("mail.receive").split(","), fileList, "发版完成" + SysUtils.getDateSpan());
log.info("-----------------发版完成");
}
return SysUtils.getDateSplit_();
}
}
public class SysBaseController {
@Resource
public HttpServletRequest req;
@Resource
public HttpServletResponse resp;
@Resource
public ServletContext servletContext;
@Resource
MimeMailService mimeMailService;
@Resource
public StringRedisTemplate stringRedisTemplate;
public static Logger log = LoggerFactory.getLogger(SysBaseController.class);
}
解决
问题出现在
File file = Paths.get(req.getRealPath("/WEB-INF/img/12b33.jpg")).toFile();
List<File> fileList = Arrays.asList(file);
中 ,没有通过url访问,没有request注入,使用servletContext 代替
@Resource
public ServletContext servletContext;
/**
* 在linux系统第一次发版时发送发版邮件通知 No thread-bound request found: Are you referring
* to request attributes outside of an actual web request
*/
public String publicSendMail() {
if (SysConstant.isFirstStart && SysConstant.isLinux) {
SysConstant.isFirstStart = false;
File file = Paths.get(servletContext.getRealPath("/WEB-INF/img/12b33.jpg")).toFile();
List<File> fileList = Arrays.asList(file);
mimeMailService.sendMimeMailPic("发版完成", PropUtils.getPropMail().getProperty("mail.receive").split(","), fileList, "发版完成" + SysUtils.getDateSpan());
log.info("-----------------发版完成");
}
return SysUtils.getDateSplit_();
}