Interceptor的实现

本文介绍了一个简单的Java程序,演示了如何使用拦截器模式来增强Action类的功能。通过两个不同的拦截器,展示了请求如何被处理及传递给下一个拦截器直至目标Action,最后返回执行结果。
public interface Action { 
public String execute() throws Exception;
}

public class TestAction implements Action {

public String execute() throws Exception {
System.out.println("action exe");
return "success";
}

}

public interface Interceptor {
public String intercept(ActionInvocation invocation) throws Exception;
}

public class Test1Intercpetor implements Interceptor{

public String intercept(ActionInvocation invocation) throws Exception{
System.out.println("hello!in test1");
String code= invocation.invoke();
System.out.println("end!in test1");
return code;
}

}

public class Test2Intercpetor implements Interceptor{

public String intercept(ActionInvocation invocation) throws Exception{
System.out.println("hello!in test2");
String code= invocation.invoke();
System.out.println("end!in test2");
return code;
}

}

public interface ActionInvocation {
public String invoke() throws Exception ;
}


public class DefaultInvocation implements ActionInvocation{

private List<Interceptor> interceptors =new ArrayList<Interceptor>();
private int index=-1;
private String result;
public String invoke() throws Exception {

if(index==interceptors.size()-1){
result=action.execute();
}else
{
index++;
result=((Interceptor)interceptors.get(index)).intercept(this);
System.out.println("????"+result);

}
return result;
}

public void addInterceptor(Interceptor interceptor){
interceptors.add(interceptor);
}

private Action action;
public Action getAction() {
return action;
}
public void setAction(Action action) {
this.action = action;
}


}


public class Test {
public static void main(String[] args){
DefaultInvocation d=new DefaultInvocation();
d.setAction(new TestAction());
d.addInterceptor(new Test1Intercpetor());
d.addInterceptor(new Test2Intercpetor());
try {
d.invoke();
} catch (Exception ex) {
Logger.getLogger(Test.class.getName()).log(Level.SEVERE, null, ex);
}
}

### 通过 MyBatis Interceptor 实现分页功能 MyBatis 提供了灵活的拦截器机制(Interceptor),可以通过自定义拦截器实现分页功能。以下是一个基于 MyBatis 的分页插件实现示例,代码参考了 MyBatisPlus 的分页插件设计理念[^1]。 #### 配置拦截器 首先需要创建一个自定义拦截器类,该类继承 `Interceptor` 接口,并实现其方法。以下是一个简单的分页拦截器实现: ```java import org.apache.ibatis.executor.statement.StatementHandler; import org.apache.ibatis.plugin.*; import org.apache.ibatis.reflection.MetaObject; import org.apache.ibatis.reflection.SystemMetaObject; import java.sql.Connection; import java.util.Properties; @Intercepts({@Signature(type = StatementHandler.class, method = "prepare", args = {Connection.class, Integer.class})}) public class PaginationInterceptor implements Interceptor { @Override public Object intercept(Invocation invocation) throws Throwable { // 获取当前执行的 SQL 和参数 StatementHandler statementHandler = (StatementHandler) invocation.getTarget(); MetaObject metaObject = SystemMetaObject.forObject(statementHandler); // 动态修改 SQL 为分页查询语句 String originalSql = (String) metaObject.getValue("delegate.boundSql.sql"); String modifiedSql = modifySqlForPagination(originalSql); // 将修改后的 SQL 设置回去 metaObject.setValue("delegate.boundSql.sql", modifiedSql); return invocation.proceed(); } private String modifySqlForPagination(String sql) { // 根据数据库类型生成分页 SQL,例如 MySQL 的 LIMIT 子句 return sql + " LIMIT #{limit} OFFSET #{offset}"; } @Override public Object plugin(Object target) { return Plugin.wrap(target, this); } @Override public void setProperties(Properties properties) { // 可以在这里设置分页相关的属性 } } ``` #### 注册拦截器 在 MyBatis 的配置文件中注册拦截器,或者通过 Java 配置类完成注册。以下是 Java 配置类的方式: ```java import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import javax.sql.DataSource; @Configuration public class MyBatisConfig { @Bean public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception { SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean(); sessionFactory.setDataSource(dataSource); // 注册自定义拦截器 PaginationInterceptor paginationInterceptor = new PaginationInterceptor(); sessionFactory.setPlugins(new Interceptor[]{paginationInterceptor}); return sessionFactory.getObject(); } } ``` #### 使用分页功能 在 Mapper 接口中定义查询方法时,可以传递分页参数,例如 `limit` 和 `offset`。以下是一个示例: ```java public interface UserMapper { @Select("SELECT * FROM users") List<User> getUsers(@Param("limit") int limit, @Param("offset") int offset); } ``` 调用时传入分页参数即可: ```java List<User> users = userMapper.getUsers(10, 20); // 获取第 3 页,每页 10 条数据 ``` ### 注意事项 - 上述代码中的 `modifySqlForPagination` 方法需要根据具体的数据库类型调整分页语法[^1]。 - 如果使用的是复杂查询(如带有排序或嵌套子查询),可能需要进一步优化 SQL 修改逻辑
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值