java基于Aspectj的请求限制,实现手速太快限制功能

java后台通过AOP注解方式可以轻松实现 用户因网络等原因,请求未结束,再次请求,有时候会造成数据错乱的情况,通过AOP,可以很好的实现手速太快提示。

废话不多说,直接上代码。

1.切片类

注意:@Pointcut 切点对应的控制器一定要注意,否则会出现无法拦截的情况,具体用法相信大家随便百度一下就可以知道,值得一提的是,如果你的控制器有子文件夹,你需要监听的话,要加 ..*  两个点 代表 该文件夹及子文件夹。

package com.xkygame.ssm.aspect;

import com.alibaba.fastjson.JSON;
import com.xkygame.ssm.enums.CodeEnums;
import com.xkygame.ssm.model.DataRes;
import com.xkygame.ssm.model.SessionUser;
import com.xkygame.ssm.utils.RedisTool;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.OutputStream;

/**
 * Created by clarence on 2018/6/27.
 * version : 1.0.
 * desc : 请求访问限制切点类
 *   未响应结束不可重复访问
 * Author clarence.
 */
@Aspect //该标签把LoggerAspect类声明为一个切面
@Component //该标签把SystemLogAspect类放到IOC容器中
@Order(1)
public class RequestLimitAspect {

    //本地异常日志记录对象
    private static final Logger logger = LoggerFactory.getLogger(RequestLimitAspect.class);

    /**
     * 定义一个方法,用于声明切入点表达式,方法中一般不需要添加其他代码
     * 使用@Pointcut声明切入点表达式
     * 后面的通知直接使用方法名来引用当前的切点表达式;如果是其他类使用,加上包名即可
     */
    @Pointcut("execution(* com.xkygame.ssm.controller..*.*OrderTo(..))")
    public void requestLimitPointCut() {
    }

    /**
     * 前置通知 用于拦截Controller层 不可重复的操作
     *
     * @param joinPoint 切点
     */
    @Before("requestLimitPointCut()")
    public void doBefore(JoinPoint joinPoint) throws Exception {
        HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
        HttpServletResponse response = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getResponse();
        SessionUser sessionUser = (SessionUser)request.getSession().getAttribute("sessionUser");

        if(sessionUser != null){
            String methodName = joinPoint.getSignature().getName();
            logger.info("=============== 用户请求了方法:" + methodName);
            String requestKey = "maojiRequest:" + sessionUser.getId();
            boolean isExist = RedisTool.sismember(requestKey,methodName);
            if(isExist){
                logger.info("请求尚未结束,用户手速太快");

                // 超过次数,权限拒绝访问,访问太频繁!
                render(response);
                return;
            }

            RedisTool.sadd(requestKey,methodName);
            RedisTool.setExpire(requestKey,300); //5分钟
        }else {
            logger.info("=============== 用户请求:未登录");
        }
    }


    /**
     * 目标方法执行完 后 通知 用于拦截Controller层记录用户的操作
     *
     * @param joinPoint 切点
     */
    @After("requestLimitPointCut()")
    public void doAfter(JoinPoint joinPoint) throws Exception {
        HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
        SessionUser sessionUser = (SessionUser)request.getSession().getAttribute("sessionUser");

        if(sessionUser != null){
            String methodName = joinPoint.getSignature().getName();
            logger.info("=============用户请求结束:" + methodName);
            String requestKey = "maojiRequest:" + sessionUser.getId();
            boolean isExist = RedisTool.sismember(requestKey,methodName);
            if(isExist){
                logger.info("请求已经结束,去除限制");
                long res = RedisTool.srem(requestKey,methodName);
                if(res == 1){
                    logger.info("请求已经结束,移除接口:[" + methodName + "]限制成功!");
                }
            }
        }else {
            logger.info("=============用户请求结束:未登录");
        }
    }

    private void render(HttpServletResponse response) throws Exception {
        response.setContentType("application/json;charset=UTF-8");
        OutputStream out = response.getOutputStream();
        DataRes dataRes = new DataRes(CodeEnums.err3,"亲,请不要手速太快哦!");
        String str = JSON.toJSONString(dataRes);
        out.write(str.getBytes("UTF-8"));
        out.flush();
        out.close();
    }

}

2.注解类

package com.xkygame.ssm.annotation;

import java.lang.annotation.*;

/**
 * @Author: Clarence
 * @Description:  自定义注解  访问限制 未响应结束不可手速太快
 * @Date: 2018/8/3 13:13.
 */
@Target({ElementType.PARAMETER, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface RequestLimit {
}

3.redis工具类(单机,如需集群自行更改)

package com.xkygame.ssm.utils;

import com.google.common.collect.Sets;
import com.mysql.jdbc.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import redis.clients.jedis.BinaryClient;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import java.util.*;

/**
 * Created by will on 2016/6/20.
 */
public class RedisTool {
    private static JedisPool jedisPool = null;
    private static Logger logger = LoggerFactory.getLogger(RedisTool.class);

    /**
     * 初始化jedis连接池
     *
     * @return
     */
    public static JedisPool getPool() {
        if (jedisPool == null) {
            JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
            Properties prop =PropertyUtil.getAll("redisConfig.properties");

            int maxTotal=Integer.valueOf(prop.get("redis.maxTotal").toString());
            int maxIdle=Integer.valueOf(prop.get("redis.maxIdle").toString());
            int maxWaitMillis=Integer.valueOf(prop.get("redis.maxWaitMillis").toString());
            boolean testOnBorrow=Boolean.valueOf(prop.get("redis.testOnBorrow").toString());
            boolean testOnReturn=Boolean.valueOf(prop.get("redis.testOnReturn").toString());
            String host=prop.get("redis.host").toString();
            int port=Integer.valueOf(prop.get("redis.port").toString());

            boolean testWhileIdle=Boolean.valueOf(prop.get("redis.testWhileIdle").toString());
            int timeBetweenEvictionRunsMillis=Integer.valueOf(prop.get("redis.timeBetweenEvictionRunsMillis").toString());
            int numTestsPerEvictionRun=Integer.valueOf(prop.get("redis.numTestsPerEvictionRun").toString());
            int minEvictableIdleTimeMillis=Integer.valueOf(prop.get("redis.minEvictableIdleTimeMillis").toString());
            int minIdle=Integer.valueOf(prop.get("redis.minIdle").toString());
            // 控制一个pool最多有多少个可用的的jedis实例
            jedisPoolConfig.setMaxTotal(maxTotal);
            // 最大能够保持空闲状态的对象数
            jedisPoolConfig.setMaxIdle(maxIdle);
            // 超时时间
            jedisPoolConfig.setMaxWaitMillis(maxWaitMillis);
            // 在borrow一个jedis实例时,是否提前进行alidate操作;如果为true,则得到的jedis实例均是可用的;
            jedisPoolConfig.setTestOnBorrow(testOnBorrow);
            // 在还会给pool时,是否提前进行validate操作
            jedisPoolConfig.setTestOnReturn(testOnReturn);

            jedisPoolConfig.setTestWhileIdle(testWhileIdle);
            jedisPoolConfig.setNumTestsPerEvictionRun(numTestsPerEvictionRun);
            jedisPoolConfig.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
            jedisPoolConfig.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);
            jedisPoolConfig.setMinIdle(minIdle);

            jedisPool = new JedisPool(jedisPoolConfig, host, port);

        }
        return jedisPool;
    }


    /**
     * 返还到连接池
     *
     * @param pool
     * @param redis
     */
    public static void returnResource(JedisPool pool, Jedis redis) {
        if (redis != null) {
            pool.returnResource(redis);
        }
    }


    /**
     * <p>通过key获取储存在redis中的value</p>
     * <p>并释放连接</p>
     * @param key
     * @return 成功返回value 失败返回null
     */
    public static String get(String key){
        String value = null;

        JedisPool pool = null;
        Jedis jedis = null;
        try {
            logger.info("建立连接中....");
            pool = getPool();
            jedis = pool.getResource();
            logger.info("获取"+key+"中....");
            value = jedis.get(key);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error("建立连接失败:"+e.getMessage());
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }

        return value;
    }


    /**
     * <p>向redis存入key和value,并释放连接资源</p>
     * <p>如果key已经存在 则覆盖</p>
     * @param key
     * @param value
     * @return 成功 返回OK 失败返回 0
     */
    public static void set(String key, String value, int time) {
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            jedis.setex(key, time, value);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error(e.getMessage());
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
    }

    /**
     * 对key值为数值的增加 1
     * @param key
     */
    public static long Incre(String key) {
        JedisPool pool = null;
        Jedis jedis = null;
        long count = 0;
        try {
            pool = getPool();
            jedis = pool.getResource();
            count = jedis.incr(key);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            e.printStackTrace();
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
        return count;
    }

    /**
     * 对key的值为数值类型 减一
     * @param key
     */
    public static void Decr(String key) {
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            jedis.decr(key);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            e.printStackTrace();
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
    }

    /**
     * 为给定 key 设置生存时间,当 key 过期时(生存时间为 0 ),它会被自动删除。
     * @param key
     * @param time 指定的秒数时间戳
     */
    public static void setExpire(String key, int time) {
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            jedis.expire(key,time);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error(e.getMessage());
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
    }


    /**
     * 添加数据
     *
     * @param key
     * @param value
     */
    public static void set(String key, String value) {
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            jedis.set(key, value);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error(e.getMessage());
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
    }

    /**
     * <p>删除指定的key,也可以传入一个包含key的数组</p>
     * @param keys 一个key  也可以使 string 数组
     * @return 返回删除成功的个数
     */
    public static Long del(String... keys){
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            return jedis.del(keys);
        } catch (Exception e) {
            e.printStackTrace();
            return 0L;
        } finally {
            returnResource(pool, jedis);
        }
    }

    /**
     * 修改数据
     *
     * @param key:要修改数据的key
     * @param value:要修改数据的值
     * @return:返回boolean值,表示是否修改成功
     */
    public static void update(String key, String value,int time) {
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            if (jedis.exists(key)) {
                try {
                    jedis.setex(key,time, value);
                    if (value.equals(jedis.get(key))) {
                        logger.info("redis修改数据成功");
                    } else {
                        logger.error("redis修改数据失败");
                    }
                } catch (Exception e) {
                    logger.error("redis修改数据失败:"+e.getMessage());
                    e.printStackTrace();
                }
            } else {
                logger.error(key + "不存在");
                logger.error("若要新增数据请使用set()方法");
            }
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error(e.getMessage());
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
    }

    /**
     * 修改数据
     *
     * @param key:要修改数据的key
     * @param value:要修改数据的值
     * @return:返回boolean值,表示是否修改成功
     */
    public static void update(String key, String value) {
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            if (jedis.exists(key)) {
                try {
                    jedis.set(key, value);
                    if (value.equals(jedis.get(key))) {
                        logger.info("redis修改数据成功");
                    } else {
                        logger.error("redis修改数据失败");
                    }
                } catch (Exception e) {
                    logger.error("redis修改数据失败:"+e.getMessage());
                    e.printStackTrace();
                }
            } else {
                logger.error(key + "不存在");
                logger.error("若要新增数据请使用set()方法");
            }
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error(e.getMessage());
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
    }

    /**
     * 设置Set缓存
     * @param key 键
     * @param value 值
     * @param cacheSeconds 超时时间,0为不超时
     * @return
     */
    public static long setSet(String key, Set<String> value, int cacheSeconds) {
        long result = 0;
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            if (jedis.exists(key)) {
                jedis.del(key);
            }

            Object[] objects = value.toArray();
            String[] setStr = new String[objects.length];
            for (int i=0;i<objects.length;i++) {
                setStr[i] = objects[i].toString();
            }
            result = jedis.sadd(key, setStr);
            if (cacheSeconds > 0) {
                jedis.expire(key, cacheSeconds);
            }
            logger.info("setSet {} = {}", key, value);
        }catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error(e.getMessage());
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
        return result;
    }

    /**
     * 获取缓存
     * @param key 键
     * @return 值
     */
    public static Set<String> getSet(String key) {
        Set<String> value = null;
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            if (jedis.exists(key)) {
                value = jedis.smembers(key);
                logger.debug("getSet {} = {}", key, value);
            }
        } catch (Exception e) {
            logger.warn("getSet {} = {}", key+value, e);
        } finally {
            returnResource(pool, jedis);
        }
        return value;
    }

    /**
     * <p>通过key向指定的value值追加值</p>
     * @param key
     * @param str
     * @return 成功返回 添加后value的长度 失败 返回 添加的 value 的长度  异常返回0L
     */
    public Long append(String key ,String str){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.append(key, str);
        } catch (Exception e) {
            e.printStackTrace();
            return 0L;
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>判断key是否存在</p>
     * @param key
     * @return true OR false
     */
    public Boolean exists(String key){
        JedisPool pool =null;
        Jedis jedis = null;
        try {
            jedis = pool.getResource();
            return jedis.exists(key);
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        } finally {
            returnResource(pool, jedis);
        }
    }
    /**
     * <p>设置key value,如果key已经存在则返回0,nx==> not exist</p>
     * @param key
     * @param value
     * @return 成功返回1 如果存在 和 发生异常 返回 0
     */
    public Long setnx(String key ,String value){
        JedisPool pool =null;
        Jedis jedis = null;
        try {
            jedis = pool.getResource();
            return jedis.setnx(key, value);
        } catch (Exception e) {
            e.printStackTrace();
            return 0L;
        } finally {
            returnResource(pool, jedis);
        }
    }

    /**
     * <p>设置key value并制定这个键值的有效期</p>
     * @param key
     * @param value
     * @param seconds 单位:秒
     * @return 成功返回OK 失败和异常返回null
     */
    public String setex(String key,String value,int seconds){
        JedisPool pool =null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.setex(key, seconds, value);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }


    /**
     * <p>通过key 和offset 从指定的位置开始将原先value替换</p>
     * <p>下标从0开始,offset表示从offset下标开始替换</p>
     * <p>如果替换的字符串长度过小则会这样</p>
     * <p>example:</p>
     * <p>value : bigsea@zto.cn</p>
     * <p>str : abc </p>
     * <P>从下标7开始替换  则结果为</p>
     * <p>RES : bigsea.abc.cn</p>
     * @param key
     * @param str
     * @param offset 下标位置
     * @return 返回替换后  value 的长度
     */
    public Long setrange(String key,String str,int offset){
        JedisPool pool =null;
        Jedis jedis = null;
        try {
            jedis = pool.getResource();
            return jedis.setrange(key, offset, str);
        } catch (Exception e) {
            e.printStackTrace();
            return 0L;
        } finally {
            returnResource(pool, jedis);
        }
    }



    /**
     * <p>通过批量的key获取批量的value</p>
     * @param keys string数组 也可以是一个key
     * @return 成功返回value的集合, 失败返回null的集合 ,异常返回空
     */
    public List<String> mget(String...keys){
        JedisPool pool =null;
        Jedis jedis = null;
        List<String> values = null;
        try {
            jedis = pool.getResource();
            values = jedis.mget(keys);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnResource(pool, jedis);
        }
        return values;
    }

    /**
     * <p>批量的设置key:value,可以一个</p>
     * <p>example:</p>
     * <p>  obj.mset(new String[]{"key2","value1","key2","value2"})</p>
     * @param keysvalues
     * @return 成功返回OK 失败 异常 返回 null
     *
     */
    public String mset(String...keysvalues){
        JedisPool pool =null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.mset(keysvalues);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>批量的设置key:value,可以一个,如果key已经存在则会失败,操作会回滚</p>
     * <p>example:</p>
     * <p>  obj.msetnx(new String[]{"key2","value1","key2","value2"})</p>
     * @param keysvalues
     * @return 成功返回1 失败返回0
     */
    public Long msetnx(String...keysvalues){
        JedisPool pool =null;
        Jedis jedis = null;
        Long res = 0L;
        try {
            jedis = pool.getResource();
            res =jedis.msetnx(keysvalues);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }



    /**
     * 设置Set缓存
     * @param key 键
     * @param value 值
     * @param cacheSeconds 超时时间,0为不超时
     * @return
     */
    public static long setObjectSet(String key, Set<Object> value, int cacheSeconds) {
        long result = 0;
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            if (jedis.exists(key)) {
                jedis.del(key);
            }
            Set<byte[]> set = Sets.newHashSet();
            for (Object o : value){
                set.add(toBytes(o));
            }
            result = jedis.sadd(getBytesKey(key), (byte[][])set.toArray());
            if (cacheSeconds != 0) {
                jedis.expire(key, cacheSeconds);
            }
            logger.debug("setObjectSet {} = {}", key, value);
        } catch (Exception e) {
            logger.error("setObjectSet {} = {}", key + value, e);
        } finally {
            returnResource(pool,jedis);
        }
        return result;
    }

    /**
     * 获取缓存
     * @param key 键
     * @return 值
     */
    public static Set<Object> getObjectSet(String key) {
        Set<Object> value = null;
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            if (jedis.exists(getBytesKey(key))) {
                value = Sets.newHashSet();
                Set<byte[]> set = jedis.smembers(getBytesKey(key));
                for (byte[] bs : set){
                    value.add(toObject(bs));
                }
                logger.debug("getObjectSet {} = {}", key, value);
            }
        } catch (Exception e) {
            logger.warn("getObjectSet {} = {}", key+value, e);
        } finally {
            returnResource(pool, jedis);
        }
        return value;
    }

    /**
     * Object转换byte[]类型
     * @param object
     * @return
     */
    public static byte[] toBytes(Object object){
        return ObjectUtils.serialize(object);
    }

    /**
     * 获取byte[]类型Key
     * @param object
     * @return
     */
    public static byte[] getBytesKey(Object object){
        if(object instanceof String){
            return StringUtils.getBytes((String) object);
        }else{
            return ObjectUtils.serialize(object);
        }
    }

    /**
     * byte[]型转换Object
     * @param bytes
     * @return
     */
    public static Object toObject(byte[] bytes){
        return ObjectUtils.unserialize(bytes);
    }



    /**
     * 存储REDIS队列 顺序存储
     * <p>通过key向list头部添加字符串</p>
     * @param key
     * @param strs 可以使一个string 也可以使string数组
     * @return 返回list的value个数
     */
    public static Long lpush(String key, String... strs){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            res = jedis.lpush(key, strs);
        } catch (Exception e) {
            logger.error("redis连接失败:"+e.getMessage());
            e.printStackTrace();
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * 存储REDIS队列 反向存储
     * <p>通过key向list尾部添加字符串</p>
     * @param key
     * @param strs 可以使一个string 也可以使string数组
     * @return 返回list的value个数
     */
    public Long rpush(String key ,String...strs){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.rpush(key, strs);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key在list指定的位置之前或者之后 添加字符串元素</p>
     * @param key
     * @param where LIST_POSITION枚举类型
     * @param pivot list里面的value
     * @param value 添加的value
     * @return
     */
    public Long linsert(String key, BinaryClient.LIST_POSITION where, String pivot, String value){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.linsert(key, where, pivot, value);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key设置list指定下标位置的value</p>
     * <p>如果下标超过list里面value的个数则报错</p>
     * @param key
     * @param index 从0开始
     * @param value
     * @return 成功返回OK
     */
    public String lset(String key ,Long index, String value){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.lset(key, index, value);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key从对应的list中删除指定的count个 和 value相同的元素</p>
     * @param key
     * @param count 当count为0时删除全部
     * @param value
     * @return 返回被删除的个数
     */
    public Long lrem(String key,long count,String value){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.lrem(key, count, value);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key保留list中从strat下标开始到end下标结束的value值</p>
     * @param key
     * @param start
     * @param end
     * @return 成功返回OK
     */
    public String ltrim(String key ,long start ,long end){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.ltrim(key, start, end);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key从list的头部删除一个value,并返回该value</p>
     * @param key
     * @return
     */
    synchronized public String lpop(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.lpop(key);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key从list尾部删除一个value,并返回该元素</p>
     * @param key
     * @return
     */
    static synchronized public String rpop(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            logger.info("建立连接中....");
            pool = getPool();
            jedis = pool.getResource();
            logger.info("连接成功,读取中....");
            res = jedis.rpop(key);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key从一个list的尾部删除一个value并添加到另一个list的头部,并返回该value</p>
     * <p>如果第一个list为空或者不存在则返回null</p>
     * @param srckey
     * @param dstkey
     * @return
     */
    public String rpoplpush(String srckey, String dstkey){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.rpoplpush(srckey, dstkey);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取list中指定下标位置的value</p>
     * @param key
     * @param index
     * @return 如果没有返回null
     */
    public String lindex(String key,long index){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.lindex(key, index);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key返回list的长度</p>
     * @param key
     * @return
     */
    public Long llen(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.llen(key);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * 获取队列(list)数据
     * <p>通过key获取list指定下标位置的value</p>
     * <p>如果start 为 0 end 为 -1 则返回全部的list中的value</p>
     * @param key
     * @param start
     * @param end
     * @return
     */
    public static List lrange(String key, long start, long end){
        JedisPool pool = null;
        Jedis jedis = null;
        List res = null;
        try {
            logger.info("建立连接中....");
            pool = getPool();
            jedis = pool.getResource();
            logger.info("连接成功,读取中....");
            res = jedis.lrange(key, start, end);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key向指定的set中添加value</p>
     * @param key
     * @param members 可以是一个String 也可以是一个String数组
     * @return 添加成功的个数
     */
    public Long sadd(String key,String...members){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.sadd(key, members);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key删除set中对应的value值</p>
     * @param key
     * @param members 可以是一个String 也可以是一个String数组
     * @return 删除的个数
     */
    public Long srem(String key,String...members){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.srem(key, members);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key随机删除一个set中的value并返回该值</p>
     * @param key
     * @return
     */
    public String spop(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.spop(key);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取set中的差集</p>
     * <p>以第一个set为标准</p>
     * @param keys 可以使一个string 则返回set中所有的value 也可以是string数组
     * @return
     */
    public Set<String> sdiff(String...keys){
        JedisPool pool = null;
        Jedis jedis = null;
        Set<String> res = null;
        try {
            jedis = pool.getResource();
            res = jedis.sdiff(keys);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取set中的差集并存入到另一个key中</p>
     * <p>以第一个set为标准</p>
     * @param dstkey 差集存入的key
     * @param keys 可以使一个string 则返回set中所有的value 也可以是string数组
     * @return
     */
    public Long sdiffstore(String dstkey,String... keys){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.sdiffstore(dstkey, keys);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取指定set中的交集</p>
     * @param keys 可以使一个string 也可以是一个string数组
     * @return
     */
    public Set<String> sinter(String...keys){
        JedisPool pool = null;
        Jedis jedis = null;
        Set<String> res = null;
        try {
            jedis = pool.getResource();
            res = jedis.sinter(keys);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取指定set中的交集 并将结果存入新的set中</p>
     * @param dstkey
     * @param keys 可以使一个string 也可以是一个string数组
     * @return
     */
    public Long sinterstore(String dstkey,String...keys){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.sinterstore(dstkey, keys);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key返回所有set的并集</p>
     * @param keys 可以使一个string 也可以是一个string数组
     * @return
     */
    public Set<String> sunion(String... keys){
        JedisPool pool = null;
        Jedis jedis = null;
        Set<String> res = null;
        try {
            jedis = pool.getResource();
            res = jedis.sunion(keys);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key返回所有set的并集,并存入到新的set中</p>
     * @param dstkey
     * @param keys 可以使一个string 也可以是一个string数组
     * @return
     */
    public Long sunionstore(String dstkey,String...keys){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.sunionstore(dstkey, keys);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key将set中的value移除并添加到第二个set中</p>
     * @param srckey 需要移除的
     * @param dstkey 添加的
     * @param member set中的value
     * @return
     */
    public Long smove(String srckey, String dstkey, String member){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.smove(srckey, dstkey, member);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取set中value的个数</p>
     * 获取集合大小
     * @param key
     * @return
     */
    public static Long scard(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            logger.info("建立连接中....");
            pool = getPool();
            jedis = pool.getResource();
            res = jedis.scard(key);
            logger.info("Set集合中:"+key+" --> 个数: " + res);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error("建立连接失败:"+e.getMessage());
        } finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key判断value是否是set中的元素</p>
     * 判断key,value是否是集合中值
     * @param key
     * @param member
     * @return
     */
    public static Boolean sismember(String key, String member){
        JedisPool pool = null;
        Jedis jedis = null;
        Boolean res = null;
        try {
            logger.info("建立连接中....");
            pool = getPool();
            jedis = pool.getResource();
            res = jedis.sismember(key, member);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error("建立连接失败:"+e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取set中随机的value,不删除元素</p>
     * @param key
     * @return
     */
    public String srandmember(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            jedis = pool.getResource();
            res = jedis.srandmember(key);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取set中所有的value</p>
     * @param key
     * @return
     */
    public static Set<String> smembers(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        Set<String> res = new HashSet<String>();
        try {
            pool = getPool();
            jedis = pool.getResource();
            res = jedis.smembers(key);
        } catch (Exception e) {
            pool.returnBrokenResource(jedis);
            logger.error("建立连接失败:"+e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }


    /**
     * <p>通过key向zset中添加value,score,其中score就是用来排序的</p>
     * <p>如果该value已经存在则根据score更新元素</p>
     * @param key
     * @param score
     * @param member
     * @return
     */
    public Long zadd(String key,double score,String member){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zadd(key, score, member);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key删除在zset中指定的value</p>
     * @param key
     * @param members 可以使一个string 也可以是一个string数组
     * @return
     */
    public Long zrem(String key,String...members){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zrem(key, members);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key增加该zset中value的score的值</p>
     * @param key
     * @param score
     * @param member
     * @return
     */
    public Double zincrby(String key ,double score ,String member){
        JedisPool pool = null;
        Jedis jedis = null;
        Double res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zincrby(key, score, member);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key返回zset中value的排名</p>
     * <p>下标从小到大排序</p>
     * @param key
     * @param member
     * @return
     */
    public Long zrank(String key,String member){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zrank(key, member);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key返回zset中value的排名</p>
     * <p>下标从大到小排序</p>
     * @param key
     * @param member
     * @return
     */
    public Long zrevrank(String key,String member){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zrevrank(key, member);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key将获取score从start到end中zset的value</p>
     * <p>socre从大到小排序</p>
     * <p>当start为0 end为-1时返回全部</p>
     * @param key
     * @param start
     * @param end
     * @return
     */
    public Set<String> zrevrange(String key ,long start ,long end){
        JedisPool pool = null;
        Jedis jedis = null;
        Set<String> res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zrevrange(key, start, end);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key返回指定score内zset中的value</p>
     * @param key
     * @param max
     * @param min
     * @return
     */
    public Set<String> zrangebyscore(String key,String max,String min){
        JedisPool pool = null;
        Jedis jedis = null;
        Set<String> res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zrevrangeByScore(key, max, min);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key返回指定score内zset中的value</p>
     * @param key
     * @param max
     * @param min
     * @return
     */
    public Set<String> zrangeByScore(String key ,double max,double min){
        JedisPool pool = null;
        Jedis jedis = null;
        Set<String> res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zrevrangeByScore(key,max,min);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>返回指定区间内zset中value的数量</p>
     * @param key
     * @param min
     * @param max
     * @return
     */
    public Long zcount(String key,String min,String max){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zcount(key, min, max);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key返回zset中的value个数</p>
     * @param key
     * @return
     */
    public Long zcard(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zcard(key);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key获取zset中value的score值</p>
     * @param key
     * @param member
     * @return
     */
    public Double zscore(String key,String member){
        JedisPool pool = null;
        Jedis jedis = null;
        Double res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zscore(key, member);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key删除给定区间内的元素</p>
     * @param key
     * @param start
     * @param end
     * @return
     */
    public Long zremrangeByRank(String key ,long start, long end){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zremrangeByRank(key, start, end);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key删除指定score内的元素</p>
     * @param key
     * @param start
     * @param end
     * @return
     */
    public Long zremrangeByScore(String key,double start,double end){
        JedisPool pool = null;
        Jedis jedis = null;
        Long res = null;
        try {
            jedis = pool.getResource();
            res = jedis.zremrangeByScore(key, start, end);
        } catch (Exception e) {

            logger.error(e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }
    /**
     * <p>返回满足pattern表达式的所有key</p>
     * <p>keys(*)</p>
     * <p>返回所有的key</p>
     * @param pattern
     * @return
     */
    public Set queryKeys(String pattern){
        JedisPool pool = null;
        Jedis jedis = null;
        Set res = null;
        try {
            pool = getPool();
            jedis = pool.getResource();
            res = jedis.keys(pattern);
        } catch (Exception e) {
            logger.error(e.getMessage());
            e.printStackTrace();
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * <p>通过key判断值得类型</p>
     * @param key
     * @return
     */
    public String type(String key){
        JedisPool pool = null;
        Jedis jedis = null;
        String res = null;
        try {
            logger.info("建立连接中....");
            pool = getPool();
            jedis = pool.getResource();
            res = jedis.type(key);
            logger.info("获取"+key+"类型: " + res);
        } catch (Exception e) {
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error("建立连接失败:"+e.getMessage());
        } finally {
            returnResource(pool, jedis);
        }
        return res;
    }

    /**
     * 向Redis中Set集合添加值
     * @return
     */
    public static long sadd(String key, String value){
        JedisPool pool = null;
        Jedis jedis = null;
        long res = 0;
        try{
            logger.info("建立连接中....");
            pool = getPool();
            jedis = pool.getResource();
            res = jedis.sadd(key, value);
            logger.info("向Redis中Set集合添加值: --> "+key+" 结果: " + res);
        }catch (Exception e){
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error("建立连接失败:"+e.getMessage());
        }finally {
            //返还到连接池
            returnResource(pool, jedis);
        }

        return res;
    }

    /**
     * 移除:取消点赞
     * @param key
     * @param value
     * @return
     */
    public static long srem(String key, String value){
        JedisPool pool = null;
        Jedis jedis = null;
        long res = 0;
        try{
            logger.info("建立连接中....");
            pool = getPool();
            jedis = pool.getResource();
            res = jedis.srem(key, value);
            logger.info("向Redis中Set集合移除值: --> "+ key +" 结果: " + res);
        }catch (Exception e){
            //释放redis对象
            pool.returnBrokenResource(jedis);
            logger.error("建立连接失败:"+e.getMessage());
        }finally {
            //返还到连接池
            returnResource(pool, jedis);
        }
        return res;
    }



    public static void main(String[] arg0) {
//        List<ProSalesDto> proSalesDtos = new ArrayList<ProSalesDto>();
//
//        for (int i = 0; i < 10; i++) {
//            ProSalesDto proSalesDto = new ProSalesDto();
//            proSalesDto.setName("第"+i +"个");
//            RedisTool.sadd("proSalesDtos2", JSONObject.toJSONString(proSalesDto));
//        }

        Set<String> sets =  RedisTool.smembers("proSalesDtos333");
        System.out.println("The members of myset are: " + sets.size());
        Iterator<String> iterator = sets.iterator();
        while(iterator.hasNext()){
            String it = iterator.next();
            System.out.println(it);
        }
    }

}

4.请求响应类

package com.xkygame.ssm.model;

import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.xkygame.ssm.enums.CodeEnums;

import java.io.Serializable;

/**
 * Created by will on 2017/2/19.
 * 描述 :由服务端响应数据返回体
 */
public class DataRes implements Serializable{
    /**
     * 请求响应结果码
     */
    private String status;

    /**
     * 对响应的结果码进行具体描述
     */
    private String errmsg;

    /**
     * 附加数据
     */
    private String otherData;

    /**
     * 返回的请求数据
     */
    private JSONObject result;

    /**
     * 返回的请求数据
     */
    private JSONObject otherRes;

    /**
     * 返回的列表数据
     */
    private JSONArray arrayresult;
    private JSONArray list;

    public DataRes(String status, String errmsg, JSONObject result) {
        this.status = status;
        this.errmsg = errmsg;
        this.result = result;
    }
    public DataRes(CodeEnums codeEnums, String errmsg, JSONObject result) {
        this.status = codeEnums.getErrCode();
        this.errmsg = errmsg;
        this.result = result;
    }

    public DataRes(CodeEnums codeEnums,JSONObject result,String otherData) {
        this.status = codeEnums.getErrCode();
        this.otherData = otherData;
        this.errmsg = codeEnums.getErrMsg();
        this.result = result;
    }

    public DataRes(CodeEnums codeEnums, JSONArray arrayresult) {
        this.status = codeEnums.getErrCode();
        this.errmsg = codeEnums.getErrMsg();
        this.arrayresult = arrayresult;
    }

    public DataRes(CodeEnums codeEnums, JSONObject result, JSONArray arrayresult) {
        this.status = codeEnums.getErrCode();
        this.errmsg = codeEnums.getErrMsg();
        this.result = result;
        this.arrayresult = arrayresult;
    }

    public DataRes(CodeEnums codeEnums, String errmsg, JSONObject result, JSONArray arrayresult) {
        this.status = codeEnums.getErrCode();
        this.errmsg = errmsg;
        this.result = result;
        this.arrayresult = arrayresult;
    }

    public DataRes(CodeEnums codeEnums, JSONObject result) {
        this.status = codeEnums.getErrCode();
        this.errmsg = codeEnums.getErrMsg();
        this.result = result;
    }

    public DataRes(CodeEnums codeEnums, String errmsg) {
        this.status = codeEnums.getErrCode();
        this.errmsg = errmsg;
    }

    public DataRes(CodeEnums codeEnums) {
        this.status = codeEnums.getErrCode();
        this.errmsg = codeEnums.getErrMsg();
    }

    public DataRes(CodeEnums codeEnums, String errmsg, JSONObject result, JSONArray arrayresult,JSONArray list) {
        this.status = codeEnums.getErrCode();
        this.errmsg = errmsg;
        this.result = result;
        this.arrayresult = arrayresult;
        this.list = list;
    }

    public DataRes(CodeEnums codeEnums, JSONArray arrayresult, JSONArray list) {
        this.status = codeEnums.getErrCode();
        this.errmsg = codeEnums.getErrMsg();
        this.arrayresult = arrayresult;
        this.list = list;
    }

    public DataRes(CodeEnums codeEnums, String errmsg, JSONObject otherRes, JSONObject result) {
        this.status = codeEnums.getErrCode();
        this.errmsg = errmsg;
        this.result = result;
        this.otherRes = otherRes;
    }


    public String getStatus() {
        return status;
    }

    public void setStatus(String status) {
        this.status = status;
    }

    public String getErrmsg() {
        return errmsg;
    }

    public void setErrmsg(String errmsg) {
        this.errmsg = errmsg;
    }

    public JSONObject getResult() {
        return result;
    }

    public void setResult(JSONObject result) {
        this.result = result;
    }

    public JSONArray getArrayresult() {
        return arrayresult;
    }

    public void setArrayresult(JSONArray arrayresult) {
        this.arrayresult = arrayresult;
    }

    public String getOtherData() {
        return otherData;
    }

    public void setOtherData(String otherData) {
        this.otherData = otherData;
    }

    public JSONObject getOtherRes() {
        return otherRes;
    }

    public void setOtherRes(JSONObject otherRes) {
        this.otherRes = otherRes;
    }

    public JSONArray getList() {
        return list;
    }

    public void setList(JSONArray list) {
        this.list = list;
    }
}

最后,只需要在需要请求限制的接口上添加注解@RequestLimit()

当然,这是根据我目前项目使用到的代码,大家可以根据自己所需选取相应部分。因为我比较懒~

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值