springboot+mybatis保存数据自动填入创建时间,创建人,修改时间,修改人

注解

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 自动设置创建人
 */
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})
public @interface CreateBy {
    String value() default "";
}
/**
 * 自动设置创建时间
 */
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})
public @interface CreateTime {
    String value() default "";
}
/**
 * 自动设置修改人
 */
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})
public @interface UpdateBy {
    String value() default "";
}
/**
 * 自动设置修改时间
 */
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})
public @interface UpdateTime {
    String value() default "";
}

拦截器

import org.apache.ibatis.binding.MapperMethod;
import org.apache.ibatis.executor.Executor;
import org.apache.ibatis.mapping.MappedStatement;
import org.apache.ibatis.mapping.SqlCommandType;
import org.apache.ibatis.plugin.Interceptor;
import org.apache.ibatis.plugin.Intercepts;
import org.apache.ibatis.plugin.Invocation;
import org.apache.ibatis.plugin.Signature;
import org.springframework.stereotype.Component;

import java.lang.reflect.Field;
import java.sql.Timestamp;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
/**
 * 自定义 Mybatis 插件,自动设置 createTime 和 updatTime 的值。
 * 拦截 update 操作(添加和修改)
 */
@Component
@Intercepts({@Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class})})
public class CustomInterceptor implements Interceptor {
    private static final Logger logger = LoggerFactory.getLogger(CustomInterceptor.class);

    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        MappedStatement mappedStatement = (MappedStatement) invocation.getArgs()[0];

        // 获取 SQL 命令
        SqlCommandType sqlCommandType = mappedStatement.getSqlCommandType();
        //只判断新增和修改
        if (SqlCommandType.INSERT.equals(sqlCommandType) || SqlCommandType.UPDATE.equals(sqlCommandType)) {
            // 获取参数
            Object parameter = invocation.getArgs()[1];
            //批量操作时
            if (parameter instanceof MapperMethod.ParamMap) {
                MapperMethod.ParamMap map = (MapperMethod.ParamMap) parameter;
                Object obj = map.get("list");
                List<?> list = (List<?>) obj;
                if (list != null) {
                    for (Object o : list) {
                        setParameter(o, sqlCommandType);
                    }
                }
            } else {
                setParameter(parameter, sqlCommandType);
            }
        }
        return invocation.proceed();
    }

    public void setParameter(Object parameter, SqlCommandType sqlCommandType) throws Throwable {
        Class<?> aClass = parameter.getClass();
        Field[] declaredFields;
        //如果常用字段提取了公共类 BaseEntity
        //判断BaseEntity是否是父类
        if (BaseEntity.class.isAssignableFrom(aClass)) {
        // 获取父类私有成员变量
            declaredFields = aClass.getSuperclass().getDeclaredFields();
        } else {
            // 获取私有成员变量
            declaredFields = aClass.getDeclaredFields();
        }
        for (Field field : declaredFields) {
            if (SqlCommandType.INSERT.equals(sqlCommandType)) { // insert 语句插入 createBy
                if (field.getAnnotation(CreateBy.class) != null) {
                    field.setAccessible(true);
                    field.set(parameter, SecurityUtils.getUsername());
                }

                if (field.getAnnotation(CreateTime.class) != null) { // insert 语句插入 createTime
                    field.setAccessible(true);
                    field.set(parameter, new Timestamp(System.currentTimeMillis()));
                }
            }

            if (SqlCommandType.UPDATE.equals(sqlCommandType)) {
                if (field.getAnnotation(UpdateTime.class) != null) { // update 语句插入 updateTime
                    field.setAccessible(true);
                    field.set(parameter, new Timestamp(System.currentTimeMillis()));
                }
                if (field.getAnnotation(UpdateBy.class) != null) { // update 语句插入 updateBy
                    field.setAccessible(true);
                    field.set(parameter, SecurityUtils.getUsername());
                }
            }
        }
    }
}

变量上添加注解

public class BaseEntity implements Serializable {

    /**
     * 创建者
     */
    @CreateBy
    private String createBy;

    /**
     * 创建时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    @CreateTime
    private Date createTime;
    }
    @UpdateBy
    private String updateBy;

    /**
     * 更新时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss" , timezone = "GMT+8")
    @UpdateTime
    private Date updateTime;

保存当前线程变量

import com.alibaba.ttl.TransmittableThreadLocal;
import com.yjt.common.core.constant.SecurityConstants;
import com.yjt.common.core.text.Convert;
import com.yjt.common.core.utils.StringUtils;

import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;


public class SecurityContextHolder
{
    private static final TransmittableThreadLocal<Map<String, Object>> THREAD_LOCAL = new TransmittableThreadLocal<>();

    public static void set(String key, Object value)
    {
        Map<String, Object> map = getLocalMap();
        map.put(key, value == null ? StringUtils.EMPTY : value);
    }

    public static String get(String key)
    {
        Map<String, Object> map = getLocalMap();
        return Convert.toStr(map.getOrDefault(key, StringUtils.EMPTY));
    }

    public static <T> T get(String key, Class<T> clazz)
    {
        Map<String, Object> map = getLocalMap();
        return StringUtils.cast(map.getOrDefault(key, null));
    }

    public static Map<String, Object> getLocalMap()
    {
        Map<String, Object> map = THREAD_LOCAL.get();
        if (map == null)
        {
            map = new ConcurrentHashMap<String, Object>();
            THREAD_LOCAL.set(map);
        }
        return map;
    }

    public static void setLocalMap(Map<String, Object> threadLocalMap)
    {
        THREAD_LOCAL.set(threadLocalMap);
    }

    public static String getUserName()
    {
        return get("username");
    }

    public static void setUserName(String username)
    {
        set("username", username);
    }

    public static void remove()
    {
        THREAD_LOCAL.remove();
    }
}

拦截器


public class HeaderInterceptor implements AsyncHandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
//通过request获取到当前访问用户信息 在设置进线程变量中
       SecurityContextHolder.setUserName("获取到的用户名称");
        return true;
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        SecurityContextHolder.remove();
    }
}

获取用户信息工具类
public class SecurityUtils
{
/**
* 获取用户名称
*/
public static String getUsername()
{
return SecurityContextHolder.getUserName();
}
}

  • 5
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
好的,我可以为你解答。以下是一个简单的实现步骤: 1. 创建数据库表 首先,你需要在 MySQL 数据库中创建一个表来存储搜索数据。例如,可以创建一个名为 `product` 的表,包含 `id`、`name` 和 `description` 三个字段。 ```sql CREATE TABLE product ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(255), description TEXT ); ``` 2. 创建后端服务 使用 Spring BootMyBatis 框架来创建一个后端服务,可以接收搜索请求并从数据库中获取数据。具体实现步骤如下: - 添加相关依赖 在 `pom.xml` 文件中添加 MyBatis 和 MySQL 相关依赖: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.0.6</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.25</version> </dependency> ``` - 配置数据库连接 在 `application.properties` 中添加数据库连接配置: ``` spring.datasource.url=jdbc:mysql://localhost:3306/test?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8&useSSL=false spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` - 创建数据模型 创建一个名为 `Product` 的 Java 类,用于映射数据库表中的数据: ```java public class Product { private Integer id; private String name; private String description; // 省略 getter 和 setter 方法 } ``` - 创建 MyBatis 映射文件 创建一个名为 `ProductMapper.xml` 的 MyBatis 映射文件,用于定义 SQL 语句和数据模型的映射关系: ```xml <mapper namespace="com.example.demo.mapper.ProductMapper"> <select id="search" resultType="com.example.demo.model.Product"> SELECT * FROM product WHERE name LIKE CONCAT('%', #{keyword}, '%') </select> </mapper> ``` - 创建数据访问层 创建一个名为 `ProductMapper` 的 Java 接口,用于定义数据访问方法: ```java @Mapper public interface ProductMapper { List<Product> search(String keyword); } ``` - 创建控制器 创建一个名为 `ProductController` 的 Spring MVC 控制器,用于接收搜索请求和返回搜索结果: ```java @RestController public class ProductController { @Autowired private ProductMapper productMapper; @GetMapping("/search") public List<Product> search(@RequestParam("keyword") String keyword) { return productMapper.search(keyword); } } ``` 至此,后端服务的实现就完成了。 3. 创建前端界面 在前端界面中,可以使用 Vue 和 ElementUI 的 `el-input` 和 `el-table` 组件来实现搜索和显示数据的功能。例如,可以实现如下代码: ```html <template> <div> <el-input v-model="keyword" placeholder="请输入搜索关键字" @keyup.enter.native="search" /> <el-table :data="data"> <el-table-column prop="name" label="名称" /> <el-table-column prop="description" label="描述" /> </el-table> </div> </template> <script> export default { data() { return { keyword: '', data: [] }; }, methods: { async search() { const { data } = await this.$http.get('/search', { params: { keyword: this.keyword } }); this.data = data; } } }; </script> ``` 这段代码会创建一个包含搜索输入框和显示搜索结果的界面,当用户输入关键字并按下回车键时,会向后端发送搜索请求,并将结果显示在表格中。 以上就是一个简单的使用 Spring BootMyBatis、Vue 和 ElementUI 来创建搜索功能的实现步骤。当然,具体实现方式还需要根据你的具体需求来进行调整。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值