多线程里面不能注入Service或者Mapper

多线程里面不能注入Service或者Mapper

  • 1.问题及原因
  • 2.解决方案
    • 2.1新建一个工具类
    • 2.2配置文件

1.问题及原因

if(msg.contains("成功")) {
	Log log = new Log();
	log.setStatus(1);
	log.setUserId(Integer.parseInt(u.getStuNum()));
	log.setCreateTime(MyUtils.getNowDateTime());
	log.setCount(Integer.parseInt(seat));
	logService.addLog(log);
	break;
}	

本想通过注解的方式实现日志插入,
但是一直报空指针。
经过一段时间的百度已经试验,
终于调试成功。

2.解决方案

2.1新建一个工具类

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;

/**
 * class name: AppBean 
* class description: please write your description
* @version 1.0 2019年4月2日 上午10:03:10 * @author Aisino)weihaohao */
public class AppBean implements ApplicationContextAware { private static ApplicationContext applicationContext; /** * @Override * @see org.springframework.context.ApplicationContextAware#setApplicationContext(org.springframework.context.ApplicationContext)
* Method name: setApplicationContext
* Description: please write your description
* Remark:
* @param applicationContext * @throws BeansException
*/
@Override public void setApplicationContext(ApplicationContext appContext) throws BeansException { applicationContext = appContext; } public static Object getBean(String name){ return applicationContext.getBean(name); } public static ApplicationContext getApplicationContext() { return applicationContext; } }

2.2配置文件

在Config包下加一个Bean

	@Bean
	public AppBean appBean() {
		return new AppBean();
	}

或者在spring.xml里面加上

<bean id="AppBean" 
class="com.xxx.xxx.AppBean"/>

然后在线程里面加上下面语句,
再次调用即可。

private static LogService logService = (LogService) AppBean.getBean("logService");

你可能感兴趣的:(常见问题)