静态工具类中使用注解注入service

时间:2021-09-22 01:40:27

转载:http://blog.csdn.net/p793049488/article/details/37819121

一般需要在一个工具类中使用@Autowired 注解注入一个service。但是由于工具类方法一般都写成static,所以直接注入就存在问题。

注:Spring工厂要有这个bean。

使用如下方式可以解决:

  1. /**
  2. *
  3. */
  4. package cn.ffcs.drive.common.util;
  5. import javax.annotation.PostConstruct;
  6. import javax.servlet.http.HttpServletRequest;
  7. import org.slf4j.Logger;
  8. import org.slf4j.LoggerFactory;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.stereotype.Component;
  11. import cn.ffcs.drive.domain.Admin;
  12. import cn.ffcs.drive.domain.OpeLog;
  13. import cn.ffcs.drive.service.IOpeLogService;
  14. import cn.ffcs.zq.util.DateUtils;
  15. /**
  16. * className:OpeLogUtils
  17. *
  18. * 管理员操作日志
  19. *
  20. * @author pengyh
  21. * @version 1.0.0
  22. * @date 2014-07-10 09:04:48
  23. *
  24. */
  25. @Component
  26. public class OpeLogUtils {
  27. private static Logger logger = LoggerFactory.getLogger(OpeLogUtils.class);
  28. @Autowired
  29. private IOpeLogService opeLogService;
  30. private static OpeLogUtils opeLogUtils;
  31. public void setUserInfo(IOpeLogService opeLogService) {
  32. this.opeLogService = opeLogService;
  33. }
  34. @PostConstruct
  35. public void init() {
  36. opeLogUtils = this;
  37. opeLogUtils.opeLogService = this.opeLogService;
  38. }
  39. /**
  40. * 执行操作日志入库操作
  41. * @param adminId   管理员id
  42. * @param opeDesc   操作日志信息
  43. * @param cityCode  城市编码
  44. */
  45. public static void insertOpeLog(HttpServletRequest req, String opeDesc) {
  46. try {
  47. /**
  48. * 获取管理员信息
  49. */
  50. Admin admin = DriveUtil.getSessionUser(req);
  51. if(admin != null && opeDesc != null && !opeDesc.trim().equals("")){
  52. //封装日志信息
  53. logger.info("开始封装日志信息。");
  54. OpeLog opeLog = new OpeLog();
  55. opeLog.setAdminId(admin.getId());
  56. opeLog.setCityCode(admin.getCityCode());
  57. opeLog.setOpeDesc("管理员id="+admin.getId()+"操作【"+opeDesc+"】");
  58. opeLog.setOpeTime(DateUtils.getNow());
  59. opeLog.setIsDelete("0");
  60. opeLogUtils.opeLogService.save(opeLog);
  61. logger.info("保存管理员操作日志成功,信息为【adminId:{},cityCode:{},opeDesc:{},opeTime:{}】",new Object[]{admin!=null?admin.getId():null,admin.getCityCode(),opeDesc,DateUtils.getNow()});
  62. }else{
  63. logger.info("保存操作日志失败,参数不足【adminId:{},cityCode:{},opeDesc:{},opeTime:{}】",new Object[]{admin!=null?admin.getId():null, admin!=null?admin.getCityCode():null, opeDesc, DateUtils.getNow()});
  64. }
  65. } catch (Exception e) {
  66. logger.error("保存操作日志异常,异常信息为:" + e.getMessage(), e);
  67. }
  68. }
  69. }