wilco
2016-07-27 15:21:37
完
spring MVC项目中ThreadPoolTaskExecutor多线程注解为什么失败?
现web项目中存在一个正常的登陆功能,想在登陆的同时利用多线程添加一些额外的功能,代码如下:
controller:
@ResponseBody
@RequestMapping(value="/login",method=RequestMethod.POST)
public Massage<UserBean> login(HttpServletRequest request,String name,String password) {
Massage<UserBean> massage = loginService.login(name,password);
//TODO 此处利用多线程记录日志操作
return massage;
}
service:
@Override
public Massage<UserBean> login(String name ,String password) {
Massage<UserBean> massage = new Massage<UserBean>();
UserBean user = userBeanMapper.selectByName(name);
if (user == null) {
massage.setSyscode("001");
massage.setMsg("用户名称错误!");
logger.info("登陆失败:" + "name("+name+")" +"用户名称错误!");
}else if(!user.getPassword().equals(password)){
massage.setSyscode("002");
massage.setMsg("用户密码错误!");
logger.info("登陆失败:" + "name("+name+")" +"用户密码错误!");
}else{
massage.setT(user);
massage.setSyscode("000");
}
return massage;
}
修改后:
controller:
@ResponseBody
@RequestMapping(value="/login",method=RequestMethod.POST)
public Massage<UserBean> login(HttpServletRequest request,String name,String password) {
Massage<UserBean> massage = loginService.login(name,password);
//TODO 此处添加记录日志操作
if("000".equals(massage.getSyscode())){//登陆成功
WebApplicationContext context = WebApplicationContextUtils.getWebApplicationContext(request.getSession().getServletContext());
ThreadPoolTaskExecutor threadPool = (ThreadPoolTaskExecutor) context.getBean("threadPool");
threadPool.execute(new LoginRecordTask(name, massage.getSyscode()));
}
return massage;
}
public class LoginRecordTask implements Runnable {
private final static Logger logger = LoggerFactory.getLogger(LoginRecordTask.class);
private String name;
private String syscode;
@Autowired
private LoginService loginService;
public LoginRecordTask(String name, String syscode) {
super();
this.name = name;
this.syscode = syscode;
}
@Override
public void run() {
logger.info("登陆日志记录开始。。。");
loginService.recordLogin(name);
logger.info("登陆日志记录结束。。。");
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSyscode() {
return syscode;
}
public void setSyscode(String syscode) {
this.syscode = syscode;
}
}
测试发现:在LoginRecordTask中的loginService报了空指针,也就是未注入成功。。。
整了很久也没弄好,感谢知情者举手之劳!
评论
所有回答列表(4)
最代码温柔 LV18
2016年7月28日
你方法是对的,问题就在于,你往spring web容器离注入的bean含有线程类。springIOC反转控住的实质就是预先加载(new Bean)类,等你用的时候直接@Autowired就可以了,线程类就有点特殊了。线程类有6个状态(new,runnable,block,waite,time_waite,terminated)。。。好了不说废话了,我直接贴图告诉你我怎么解决的吧,你在控制器了,直接new 出线程类,然后start就好了,我用的是单例模式,你可以参考一下
这是我的线程类
你上下文没有获取到线程类,所以你的注入报service空,然后longin task也是报空
评论(0)
最佳答案
- 等 最代码怎么获取牛币啊?
- 完 谁来告诉我最代码上线的时间,答对者给5牛币,先来先得
- 等 牛友们,大家好,你们做程序员多久了?现在还好吗?
- 完 在微信打开的页面里进行app下载
- 等 最代码2014年欢乐聚声会
- 完 mysql如何查询表数据并且对3个字段降序的SQL?
- 完 最代码牛币机制改革
- 完 成功的在bae上使用了自定义运行环境 jetty+nginx的组合,大家对jetty+nginx优化有哪些心得?
- 完 进来分享一下各位牛牛是如何加入最代码大家庭的?
- 等 为什么java BufferedImage类处理大图直接抛出内存溢出的异常?
- 等 最代码是否开发手机app客户端?
- 完 java程序员学习哪些java的技术?java有哪些框架?都能做哪方面的开发?
- 等 php格式网页文件怎么运行?
- 等 Java volatile值获取的问题
- 等 前端vue,拦截了登录后台后,返回的token,requests拦截token,但是发送请求的时候,就出现跨越异常
- 等 大专本科计算机科班怎么找到Java工作?
- 等 eclipse怎么把三个java swing游戏项目合成一个项目?
- 完 伙伴们,大家都有什么好的解压方式么,分享一下~
- 完 三四线城市,6、7k,运维工作,索然无味,想去辞职上培训,各位牛牛有什么建议嘛
- 等 jsp页面输入中文变成问号
- 等 JPA在线上运行一段时间后报错Caused by: java.lang.IncompatibleClassChangeError: null
- 等 PHP 这个规则用preg_match_all怎么写
- 等 大佬们,有没有知道Alfresco如何配置LDAP登录呢?
- 等 php的install目录是框架带的吗?
相关问答
- 完 spring MVC中使用国际化为什么是乱码?
- 等 spring MVC中的@service和@autowired有什么联系么?
- 等 spring mvc项目源码实例代码哪位一行一行解释一下?
- 等 spring MVC开发后台权限admin登录正常,其他权限登录为什么抛出异常?
- 完 spring mvc框架开发java web项目如何学习才能快速入门?
- 完 spring mvc整合mybatis后配置中自动扫描包问题
- 完 spring mvc为什么文件下载失败?
- 等 Spring MVC如何实现InternalResourceViewResolver多视图配置?
- 等 spring mvc开发关于handlermapping和handlerAdapter的问题
- 完 学习spring MVC为什么抛出nested exception is java.lang.NoClassDefFoundError的异常?
- 等 Spring MVC是怎样架构的?
- 完 java初学小白 想了解一下spring MVC工作机制
最近浏览
vinod1213 LV12
2021年9月16日
fanchenh
2021年9月11日
暂无贡献等级
huang0725
2021年7月12日
暂无贡献等级
a314178817 LV1
2020年6月3日
muyan_love
2019年3月13日
暂无贡献等级
lijianMark LV6
2019年2月21日
vision_xie LV3
2018年12月27日
wangshaokai LV1
2018年10月23日
tjthink LV8
2018年9月14日
1210416663
2018年5月23日
暂无贡献等级




