在使用moco API的時候,發現文檔中的一些功能並不能知足構建測試服務的需求,須要本身開發一些功能。以前兩篇主要講了moco自己的補充,本篇說說moco文檔以外的功能:limit。 主要是用於限制訪問次數,並不針對某個session或者同一個用戶(本人暫時沒有這方面的需求,故沒有開發)。 使用場景的話:小遊戲的裏面的抽獎,訂單提交,耗時較長的功能等。在實際的業務邏輯中,極可能會有短期內不容許提交屢次,請求屢次的需求。java
下面上代碼:git
package com.fun.moco.support; import com.fun.utils.Time; import com.github.dreamhead.moco.HttpRequest; import com.github.dreamhead.moco.MocoConfig; import com.github.dreamhead.moco.ResponseHandler; import com.github.dreamhead.moco.handler.AbstractResponseHandler; import com.github.dreamhead.moco.internal.SessionContext; import com.github.dreamhead.moco.model.MessageContent; import com.google.common.base.Function; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; /** * 循環的responsehandle */ @SuppressWarnings("all") public class LimitHandle extends AbstractResponseHandler { private final ResponseHandler limit; private final ResponseHandler unlimit; private Map<String, Long> tatal = new ConcurrentHashMap<>(); private int interval; private LimitHandle(final ResponseHandler limit, final ResponseHandler unLimit, int interval) { this.limit = limit; this.unlimit = unLimit; this.interval = interval; } public static ResponseHandler newSeq(final ResponseHandler limit, final ResponseHandler unLimit, int interval) { return new LimitHandle(limit, unLimit, interval); } /** * 返回響應 * * @param context */ @Override public void writeToResponse(final SessionContext context) { HttpRequest request = (HttpRequest) context.getRequest(); String uri = request.getUri(); MessageContent content = request.getContent(); (limited(uri + content) ? limit : unlimit).writeToResponse(context); } @Override public ResponseHandler apply(final MocoConfig config) { if (config.isFor(MocoConfig.RESPONSE_ID)) { return super.apply(config); } return new LimitHandle(limit, unlimit, interval); } private Function<ResponseHandler, ResponseHandler> applyConfig(final MocoConfig config) { return new Function<ResponseHandler, ResponseHandler>() { @Override public ResponseHandler apply(final ResponseHandler input) { return input.apply(config); } }; } /** * 判斷是否被限制 * <p> * 經過記錄每一次響應的時間戳,判斷兩次請求間隔達到limit目的 * </p> * * @param info * @return */ public boolean limited(String info) { long fresh = Time.getTimeStamp(); long old = tatal.containsKey(info) ? tatal.get(info) : 0L; tatal.put(info, fresh); return fresh - old > interval; } }
使用方法以下:github
/** * 限制請求頻次,默認1000ms * @param limit * @param unlimit * @return */ static ResponseHandler limit(String limited, String unlimited) { limit contentResponse(limited), contentResponse(unlimited) } static ResponseHandler limit(JSONObject limited, JSONObject unlimited) { limit jsonResponse(limited), jsonResponse(unlimited) } static ResponseHandler limit(ResponseHandler limited, ResponseHandler unlimited) { limit limited, unlimited, 1000 } /** * 限制請求頻次 * @param limit * @param unlimit * @param interval 單位ms * @return */ static ResponseHandler limit(String limited, String unlimited, int interval) { limit contentResponse(limited), contentResponse(unlimited), interval } static ResponseHandler limit(JSONObject limited, JSONObject unlimited, int interval) { limit limited.toString(), unlimited.toString(), interval } static ResponseHandler limit(ResponseHandler limit, ResponseHandler unlimit, int interval) { LimitHandle.newSeq(limit, unlimit, interval) }
歡迎有興趣的童鞋一塊兒交流json