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

本文介绍了一种在Spring框架中解决静态工具类依赖注入问题的方法。通过将工具类声明为非静态,并利用@PostConstruct注解,在初始化阶段将实例变量设置为静态,从而实现在静态上下文中使用依赖的服务。

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

使用如下方式可以解决:

/**
 *
 */
package com.spring.drive.common.util;

import javax.annotation.PostConstruct;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import com.spring.drive.service.AutowiredStatic;


/**
 * className:OpeLogUtils
 *
 * 管理员操作日志
 *
 * @author pengyh
 * @version 1.0.0
 * @date 2014-07-10 09:04:48
 *
 */
@Component
public class AutowiredStatic{

    private static Logger logger = LoggerFactory.getLogger(AutowiredStatic.class);

    @Autowired
    private AutoeiredService autoeiredService ;
    private static AutowiredStatic autowiredStatic;

    public void setAutoeiredService(AutoeiredServiceautoeiredService) {
        this.autoeiredService= autoeiredService;
    }
   

    /**

    *

    *关于在spring  容器初始化 bean 和销毁前所做的操作定义方式有三种:

    *第一种:通过@PostConstruct 和 @PreDestroy 方法 实现初始化和销毁bean之前进行的操作

    *第二种是:通过 在xml中定义init-method 和  destory-method方法

    *第三种是: 通过bean实现InitializingBean和 DisposableBean接口

    */

    @PostConstruct
    public void init() {
        autowiredStatic= this;
        autowiredStatic.autoeiredService= this.autoeiredService;

    }

    /**
     * 静态方法使用spring注解获取到的对象
     */
    public static void main(String[] args) {

        //使用注解对象调用方法

       autowiredStatic.autoeiredService.findAllData();

    }
}



### 解决 Db 静态工具类不可用的问题 在 MyBatis-Plus 中,`Db` 类是一个常用的静态工具类,用于简化数据库操作。然而,在某些情况下可能会遇到 `Db` 工具类不可用的问题。这通常是因为项目中引入的 MyBatis-Plus 版本较低或者未正确配置相关依赖。 #### 问题原因分析 1. **版本过低**:早期版本的 MyBatis-Plus 并未提供完整的 `Db` 工具类支持[^3]。 2. **依赖缺失**:如果项目的 Maven 或 Gradle 文件中缺少必要的依赖项,则可能导致功能无法正常使用。 3. **Spring 容器管理问题**:即使依赖已正确添加,但如果工具类未被 Spring 容器托管,也可能引发空指针异常等问题[^2]。 #### 解决方案 以下是针对上述问题的具体解决方案: 1. **升级 MyBatis-Plus 至最新版本** 确保项目中的 MyBatis-Plus 依赖已经更新至至少 3.x 的稳定版本(如 3.5.3)。可以通过修改 `pom.xml` 文件来实现: ```xml <!-- MyBatis-Plus 核心依赖 --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.3</version> </dependency> <!-- Generator 模块 --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <version>3.5.3</version> </dependency> ``` 2. **确认工具类是否已被 Spring 托管** 如果需要在工具类中注入其他 Bean 对象(例如 DAO 层接口),则应将其纳入 Spring 容器管理范围。具体做法是在工具类上添加 `@Component` 注解,并确保其所在包已在 Spring 配置文件中声明扫描路径: ```java @Component public class CustomTool { @Autowired private SomeService someService; public void execute() { // 调用 service 方法 someService.doSomething(); } } ``` 同时,在 Spring 配置文件中加入如下内容以启用组件扫描: ```xml <context:component-scan base-package="com.example.package"/> ``` 3. **验证 Db 工具类的功能** 升级完成后,可以直接测试 `Db` 工具类的核心方法是否正常工作。以下是一些常见的使用场景示例: ```java import com.baomidou.mybatisplus.core.toolkit.Db; public class TestMain { public static void main(String[] args) { // 插入数据 boolean insertResult = Db.insert("INSERT INTO user (name, age) VALUES ('Tom', 20)"); // 查询单条记录 Map<String, Object> resultMap = Db.queryMap("SELECT * FROM user WHERE id = ?", 1); System.out.println("Insert Result: " + insertResult); System.out.println("Query Result: " + resultMap); } } ``` 4. **排查潜在错误** 若仍然存在问题,建议通过日志查看具体的异常堆栈信息并逐一排除可能性。例如,检查是否存在拼写错误、SQL 语法问题或其他外部因素干扰。 --- ### 总结 通过对 MyBatis-Plus 的版本控制以及 Spring 容器的有效利用,能够有效解决 `Db` 静态工具类不可用的问题。务必保持框架及相关库处于较新状态以便获得更好的兼容性和稳定性。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值