目录
需求
对于所有的GET查询请求,我都想实现能走redis的就不走数据库。
大致思路是请求在通过Controller之前,咱们搞一个拦截器,符合get请求的拦截, 非get请求的放行。然后我们给符合条件的拦截器生成rediskey,把rediskey存入到redis数据库中,下次再执行查询,数据就是直接从redis数据库中取出的了~
新建拦截器类
package cn.itcast.haoke.dubbo.api.interceptor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.apache.commons.codec.digest.DigestUtils;
import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.Map;
@Component
public class RedisCacheInterceptor implements HandlerInterceptor {
private static ObjectMapper mapper = new ObjectMapper();
@Autowired
private RedisTemplate<String, String> redisTemplate;
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
if(StringUtils.equalsIgnoreCase(request.getMethod(), "OPTIONS")){
return true;
}
// 判断请求方式,get还是post还是其他。。。
if (!StringUtils.equalsIgnoreCase(request.getMe