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

时间:2022-09-26 22:48:41

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

使用如下方式可以解决:

  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);

静态工具类中使用注解注入service实例的更多相关文章

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

    转载:http://blog.csdn.net/p793049488/article/details/37819121 一般需要在一个工具类中使用@Autowired 注解注入一个service.但是 ...

  2. spring 在静态工具类中使用注解注入bean

    /** * @author: jerry * @Email: * @Company: * @Action: 日志处理工具类 * @DATE: 2016-9-19 */ @Component//泛指组件 ...

  3. SpringBoot 项目在静态工具类中注入 RedisTemplate

    静态属性不能直接注入,可以通过其set方法进行注入.(注意生成的set方法需要去掉static). 在工具类里直接注入RedisTemplate,两种方法: (1)使用@Autowired priva ...

  4. 解决 SpringMVC 非spring管理的工具类使用@Autowired注解注入DAO为null的问题

    在SpringMVC框架中,我们经常要使用@Autowired注解注入Service或者Mapper接口,我们也知道,在Controller层中注入service接口,在service层中注入其它的s ...

  5. JAVA中SpringMVC获取bean方法,在工具类(utils)注入service

    有时候我们会出现无法用注解 @Autowired 注入bean的情况,这个时候可以 通过contextLoader获取 WebApplicationContext ctx = ContextLoade ...

  6. 在静态工具类中需要注入mapper

    在xml中 <bean id="messageUtil" class="org.ldd.ssm.hangyu.utils.MessageUtil" ini ...

  7. Spring 中将service 注入到普通的工具类中

    记录一下,防止忘记. 要求每次生成一个和数据库不重复的组队码,于是就想在工具类中加入service注入 方法1(红框是注意的地方)

  8. Springboot在工具类&lpar;Util&rpar;中使用&commat;Autowired注入Service

    1. 使用@Component注解标记工具类MailUtil: 2. 使用@Autowired注入我们需要的bean: 3. 在工具类中编写init()函数,并使用@PostConstruct注解标记 ...

  9. 关于工具类静态方法调用&commat;Autowired注入的service类问题

    @Component //此处注解不能省却(0) 1 public class NtClient { 2 /** 3 * 日志 4 */ 5 private static String clazzNa ...

随机推荐

  1. js-JavaScript高级程序设计学习笔记20

    第二十三章 离线应用与客户端存储 1.离线检测 HTML5定义navigator.onLine属性.还定义了两个事件,online和offline,当网络从离线变为在线或从在线变为离线时在window ...

  2. 移动端web app自适应布局探索与总结

    要掌握的知识点: iphone6 屏幕尺寸为 375*667 (pt)也就是 网页 全屏显示时候 document.documentElement.clientWidth------可以理解为屏幕越大 ...

  3. Ubuntu 14&period;10 下Server版本中文乱码问题

    在安装Ubuntu server 14.10 时候选择了中文版,但是装好系统发现,里面的中文有乱码,解决办法 打开 /etc/default/locale sudo nano /etc/default ...

  4. QTP10补丁汇总

    QTP10补丁汇总 QTP_00591.EXE QTP10 调试器视图问题的补丁 QTP_00591 - Prevent QuickTest Debug Viewer Problems when Pr ...

  5. ASP&period;NET面试题总结

    1.ASP.NET中的身份验证有那些?你当前项目采用什么方式验证请解释ASP.NET身份验证模式包括Windows.Forms(窗体).Passport(护照)和None(无). 1.Windows身 ...

  6. &lbrack;51nod1355&rsqb; 斐波那契的最小公倍数

    Description 给定 \(n\) 个正整数 \(a_1,a_2,...,a_n\),求 \(\text{lcm}(f_{a_1},f_{a_2},...,f_{a_n})\).其中 \(f_i ...

  7. Web GIS离线地图

    参考资料: http://www.cnblogs.com/luxiaoxun/p/5022333.html https://www.cnblogs.com/luxiaoxun/p/4454880.ht ...

  8. PHP类中self和&dollar;this的区别

    1.self代表类,$this代表对象2.能用$this的地方一定使用self,能用self的地方不一定能用$this静态的方法中不能使用$this,静态方法给类访问的. 今天在使用静态方法的时候,使 ...

  9. file 文件上传后缀转化小写

    1.上传的文件后缀是大写的我们做上传文件的时候考虑的比较少,所以我就想把客户上传的文件后缀统一一下,后面我解析附件的时候比较好解析.例子:我得到的文件名称:$infoFileName;$fileNam ...

  10. 解决 E&colon; Could not get lock &sol;var&sol;lib&sol;apt&sol;lists&sol;lock

    参考:Unable to lock the administration directory (/var/lib/dpkg/) is another process using it? 在更换软件源时 ...