2
0
mirror of https://gitee.com/hotlcc/wechat4j.git synced 2025-12-24 02:49:37 +08:00

提交代码

This commit is contained in:
hotlcc
2018-07-22 19:39:30 +08:00
parent bd6c61b3c3
commit 5106ffb0bf
2 changed files with 111 additions and 106 deletions

View File

@@ -1,6 +1,9 @@
package com.hotlcc.wechat4j;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.hotlcc.wechat4j.api.WebWeixinApi;
import com.hotlcc.wechat4j.util.QRCodeUtil;
import org.apache.http.client.CookieStore;
import org.apache.http.client.HttpClient;
import org.apache.http.impl.client.BasicCookieStore;
@@ -41,4 +44,111 @@ public class Wechat {
public void autoLogin() {
}
public void test() {
JSONObject result = null;
String redirectUri = null;
login:
while (true) {
//1、获取uuid
logger.info("开始获取uuid...");
String uuid = null;
while (uuid == null || "".equals(uuid)) {
result = webWeixinApi.getWxUuid(httpClient);
if (result != null) {
uuid = result.getString("uuid");
}
if (uuid == null || "".equals(uuid)) {
logger.info("获取uuid失败将自动重试");
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
} else {
break;
}
}
logger.info("获取uuid成功值为{}", uuid);
//2、获取二维码
logger.info("开始获取二维码...");
result = webWeixinApi.getQR(httpClient, uuid);
logger.info("获取二维码成功,请扫描二维码:\n{}", QRCodeUtil.toCharMatrix(result.getBytes("data")));
//3、轮询
String code = null;
while (!"200".equals(code)) {
result = webWeixinApi.getRedirectUri(httpClient, uuid);
code = result.getString("code");
if ("408".equals(code)) {
continue;
} else if ("400".equals(code)) {
logger.info("二维码失效,将自动获取新的二维码");
continue login;
} else if ("201".equals(code)) {
logger.info("请在手机上确认");
continue;
} else if ("200".equals(code)) {
redirectUri = result.getString("redirectUri");
logger.info("手机端认证成功");
break login;
} else {
break login;
}
}
}
//4、获取登录认证码
logger.info("开始获取登录认证码");
result = webWeixinApi.getLoginCode(httpClient, redirectUri);
String wxsid = result.getString("wxsid");
String passTicket = result.getString("pass_ticket");
String skey = result.getString("skey");
String wxuin = result.getString("wxuin");
logger.info("获取登录认证码成功");
//5、初始化数据
logger.info("开始初始化数据");
result = webWeixinApi.webWeixinInit(httpClient, passTicket, wxsid, skey, wxuin);
JSONObject loginUser = result.getJSONObject("User");
logger.info("欢迎回来,{}", loginUser.getString("NickName"));
JSONObject SyncKey = result.getJSONObject("SyncKey");
logger.info("初始化数据完成");
//6、开启消息状态通知
logger.info("开始开启消息状态通知");
result = webWeixinApi.statusNotify(httpClient, passTicket, wxsid, skey, wxuin, loginUser.getString("UserName"));
logger.info("开启消息状态通知完成");
//7、服务端状态同步
logger.info("开始轮询服务端状态");
while (true) {
result = webWeixinApi.syncCheck(httpClient, wxsid, skey, wxuin, SyncKey.getJSONArray("List"));
System.out.println(result);
int retcode = result.getIntValue("retcode");
if (retcode != 0) {
logger.info("微信已退出登录");
break;
} else {
int selector = result.getIntValue("selector");
if (selector == 2) {
logger.info("收到新消息");
//8、获取新消息内容
result = webWeixinApi.pullNewMsg(httpClient, passTicket, wxsid, skey, wxuin, SyncKey);
SyncKey = result.getJSONObject("SyncKey");
JSONArray AddMsgList = result.getJSONArray("AddMsgList");
if (AddMsgList != null) {
for (int i = 0, len = AddMsgList.size(); i < len; i++) {
JSONObject Msg = AddMsgList.getJSONObject(i);
String Content = Msg.getString("Content");
int MsgType = Msg.getIntValue("MsgType");
String FromUserName = Msg.getString("FromUserName");
String ToUserName = Msg.getString("ToUserName");
logger.info("消息类型:{},消息内容:{},发送方:{},接收方:{}", MsgType, Content, FromUserName, ToUserName);
result = webWeixinApi.sendMsg(httpClient, passTicket, wxsid, skey, wxuin, Content, MsgType, ToUserName, FromUserName);
logger.info("自动回复消息完成,返回:{}", result);
}
}
}
}
}
}
}