package com.yanzuoguang.wxxcx.user.getuserencryptkey; import com.alibaba.fastjson.TypeReference; import com.yanzuoguang.util.helper.CheckerHelper; import com.yanzuoguang.util.helper.HttpHelper; import com.yanzuoguang.util.helper.JsonHelper; import com.yanzuoguang.wxxcx.base.*; /** * 获取用户encryptKey 转换 * * @author 李贤军 */ public class WxXcxGetUserEncryptKeyRequest implements WxXcxRequestUrl, WxXcxRequestUrlPara, WxXcxRequestPostFormData { private final WxXcxConfig wxXcxConfig; private final WxXcxRequest wxXcxRequest; private final WxXcxAccessToken accessToken; private final WxXcxGetUserEncryptKeyReq req; public WxXcxGetUserEncryptKeyRequest(WxXcxConfig wxXcxConfig, WxXcxRequest wxXcxRequest, WxXcxAccessToken accessToken, WxXcxGetUserEncryptKeyReq req) { this.wxXcxConfig = wxXcxConfig; this.wxXcxRequest = wxXcxRequest; this.accessToken = accessToken; this.req = req; } @Override public String getUrl() { return wxXcxConfig.getBaseUrl() + wxXcxConfig.getGetUserEncryptKeyUrl() + "?" + this.getUrlPara(); } @Override public String getUrlPara() { return HttpHelper.getUrlParameter(accessToken); } @Override public String getPost() { return HttpHelper.getUrlParameter(req); } public WxXcxGetUserEncryptKeyRes getResponse() { checkParam(req); return this.wxXcxRequest.request(this, response -> { WxXcxGetUserEncryptKeyRes ret = JsonHelper.deserialize(response, new TypeReference<WxXcxGetUserEncryptKeyRes>() { }); WxXcxAssert.assertBaseError(ret); return ret; }); } private void checkParam(WxXcxGetUserEncryptKeyReq req) { CheckerHelper.newInstance() .notBlankCheck(WxXcxAccessTokenField.FIELD_ACCESS_TOKEN, req.getAccess_token()) .notBlankCheck("openid", req.getOpenid()) .notBlankCheck("signature", req.getSignature()) .notBlankCheck("sig_method", req.getSig_method()) .checkException(); } }