很多人问,我的微信qp游戏为什么会被封?原因就是腾讯检测到你的网页内容存在诱导、诈骗等行为,还有一个重要因素就是被人举报,这也许是你的竞争对手故意黑你,当一人或者几个人举报并上传图片的时候腾讯会限制你游戏的某些功能,但是当有很多人举报的时候,腾讯就会把你微信qp游戏域名封掉,这个问题让开发商和游戏代理商都非常头,那我们要怎做到有效防封呢?猴子数据给关于微信qp游戏域名防封最新解决方案。
现在市场上有两种防封方案,第一种就是检测微信qp游戏域名并将域名切换。首先你要有一个微信域名检测接口,配置好你的接口请求程序,准备2套域名A和B。我们分享出去的域名是A,但点开后跳到B,前提是要检测一下B有没有被封,这里我们的 B一般需要准备几十甚至上百个,利用域名检测接口可以轻松实现被封自动切换。这种防封方式一般是比较浪费域名的,而且效果也一般。第二种是多级矩阵加密跳转,这里需要注意的是,着陆页的域名尽可能长一点,落地域名采用多层动态加密形式,有效的保护好我们的原始推广落地页地址。如果是通过海报推广的用户还可以用到我们的活码接口,保证扫描二位码后的链接能够得到有效的切换,延长海报使用寿命。通过实践证明,多级矩阵加密防封效果更好、稳定性会更高。那种需要玩家扫描并且需要微信绑定获取玩家信息的只能用这种防封方案,再结合微信内置浏览器直接下载APP接口直接下载app,减少用户收到选择浏览器下载的繁琐,这样可以将推广流量转化率最大化,也更有效的保护微信qp游戏域名,这种方案也不浪费域名,前期只需要准备5到8个阿里云备案并且没有被拦截过的域名,最好是.com和.cn的。具体的操作流程可以参考猴子数据官网或者咨询q:3602249720
下面只是部分代码,猴子数据采用全网最新技术,协议检测,稳定性可以达到99.999%,是公司团队运营,有专业的技术开发做保障,我们的原则就是稳定、靠谱,保障客户利益为根本。
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.HttpURLConnection;
import java.net.URL;
import java.net.URLEncoder;
import java.util.HashMap;
import java.util.Map;
import net.sf.json.JSONObject;
public class Demo {
public static final String DEF_CHATSET = "UTF-8";
public static final int DEF_CONN_TIMEOUT = 30000;
public static final int DEF_READ_TIMEOUT = 30000;
public static String userAgent = "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.66 Safari/537.36";
public static void mobileQuery(){
String result =null;
String url ="http://api.monkeyapi.com";//请求接口地址
Map params = new HashMap();//请求参数
params.put("appkey" , "appkey");//您申请的APPKEY
params.put("path" , "/home");//需要切换的路由(非必传)
try {
result = net(url, params, "GET");
JSONObject object = JSONObject.fromObject(result);
if(object.getInt("error_code")==0){
System.out.println(object.get("result"));
}else{
System.out.println(object.get("error_code")+":"+object.get("reason"));
}
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
}
/**
*
* @param strUrl 请求地址
* @param params 请求参数
* @param method 请求方法
* @return 网络请求字符串
* @throws Exception
*/
public static String net(String strUrl, Map params,String method) throws Exception {
HttpURLConnection conn = null;
BufferedReader reader = null;
String rs = null;
try {
StringBuffer sb = new StringBuffer();
if(method==null || method.equals("GET")){
strUrl = strUrl+"?"+urlencode(params);
}
URL url = new URL(strUrl);
conn = (HttpURLConnection) url.openConnection();
if(method==null || method.equals("GET")){
conn.setRequestMethod("GET");
}else{
conn.setRequestMethod("POST");
conn.setDoOutput(true);
}
conn.setRequestProperty("User-agent", userAgent);
conn.setUseCaches(false);
conn.setConnectTimeout(DEF_CONN_TIMEOUT);
conn.setReadTimeout(DEF_READ_TIMEOUT);
conn.setInstanceFollowRedirects(false);
conn.connect();
if (params!= null && method.equals("POST")) {
try {
DataOutputStream out = new DataOutputStream(conn.getOutputStream());
out.writeBytes(urlencode(params));
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}
InputStream is = conn.getInputStream();
reader = new BufferedReader(new InputStreamReader(is, DEF_CHATSET));
String strRead = null;
while ((strRead = reader.readLine()) != null) {
sb.append(strRead);
}
rs = sb.toString();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (reader != null) {
reader.close();
}
if (conn != null) {
conn.disconnect();
}
}
return rs;
}
//将map型转为请求参数型
public static String urlencode(Map<String,String> data) {
StringBuilder sb = new StringBuilder();
for (Map.Entry i : data.entrySet()) {
try {
sb.append(i.getKey()).append("=").append(URLEncoder.encode(i.getValue()+"","UTF-8")).append("&");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
return sb.toString();
}
}
原文地址:https://blog.51cto.com/14161916/2357197