mirror of
https://gitee.com/binary/weixin-java-tools.git
synced 2025-12-17 17:41:32 +08:00
issue #69 添加Session的支持,添加测试用例
This commit is contained in:
@@ -1,9 +1,6 @@
|
||||
package me.chanjar.weixin.mp.api;
|
||||
|
||||
import me.chanjar.weixin.common.session.InternalSession;
|
||||
import me.chanjar.weixin.common.session.InMemorySessionManager;
|
||||
import me.chanjar.weixin.common.session.WxSession;
|
||||
import me.chanjar.weixin.common.session.WxSessionManager;
|
||||
import me.chanjar.weixin.common.session.*;
|
||||
import me.chanjar.weixin.common.util.WxMessageDuplicateChecker;
|
||||
import me.chanjar.weixin.common.util.WxMessageInMemoryDuplicateChecker;
|
||||
import me.chanjar.weixin.mp.bean.WxMpXmlMessage;
|
||||
@@ -67,7 +64,7 @@ public class WxMpMessageRouter {
|
||||
this.wxMpService = wxMpService;
|
||||
this.executorService = Executors.newFixedThreadPool(DEFAULT_THREAD_POOL_SIZE);
|
||||
this.messageDuplicateChecker = new WxMessageInMemoryDuplicateChecker();
|
||||
this.sessionManager = new InMemorySessionManager();
|
||||
this.sessionManager = new StandardSessionManager();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -131,29 +128,31 @@ public class WxMpMessageRouter {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (matchRules.size() == 0) {
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
WxMpXmlOutMessage res = null;
|
||||
final List<Future> futures = new ArrayList<Future>();
|
||||
for (final Rule rule : matchRules) {
|
||||
// 返回最后一个非异步的rule的执行结果
|
||||
if(rule.async) {
|
||||
futures.add(
|
||||
executorService.submit(new Runnable() {
|
||||
public void run() {
|
||||
rule.service(wxMessage);
|
||||
}
|
||||
})
|
||||
executorService.submit(new Runnable() {
|
||||
public void run() {
|
||||
rule.service(wxMessage);
|
||||
}
|
||||
})
|
||||
);
|
||||
} else {
|
||||
res = rule.service(wxMessage);
|
||||
// 在同步操作结束,session访问结束
|
||||
log.trace("End session access after sync operation finish {}", wxMessage.getFromUserName());
|
||||
sessionEndAccess(wxMessage);
|
||||
}
|
||||
}
|
||||
|
||||
// 告诉session,它已经用不着了
|
||||
if (futures.size() > 0) {
|
||||
executorService.submit(new Runnable() {
|
||||
@Override
|
||||
@@ -161,19 +160,17 @@ public class WxMpMessageRouter {
|
||||
for (Future future : futures) {
|
||||
try {
|
||||
future.get();
|
||||
log.trace("End session access after async operation finish {}", wxMessage.getFromUserName());
|
||||
// 异步操作结束,session访问结束
|
||||
sessionEndAccess(wxMessage);
|
||||
} catch (InterruptedException e) {
|
||||
log.error("Error happened when wait task finish", e);
|
||||
} catch (ExecutionException e) {
|
||||
log.error("Error happened when wait task finish", e);
|
||||
}
|
||||
}
|
||||
// 在这里session再也不会被使用了
|
||||
sessionEndAccess(wxMessage);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
// 在这里session再也不会被使用了
|
||||
sessionEndAccess(wxMessage);
|
||||
}
|
||||
return res;
|
||||
}
|
||||
@@ -183,10 +180,12 @@ public class WxMpMessageRouter {
|
||||
* @param wxMessage
|
||||
*/
|
||||
protected void sessionEndAccess(WxMpXmlMessage wxMessage) {
|
||||
WxSession session = sessionManager.getSession(wxMessage.getFromUserName(), false);
|
||||
|
||||
InternalSession session = ((InternalSessionManager)sessionManager).findSession(wxMessage.getFromUserName());
|
||||
if (session != null) {
|
||||
((InternalSession) session).endAccess();
|
||||
session.endAccess();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public static class Rule {
|
||||
|
||||
@@ -10,7 +10,7 @@ import me.chanjar.weixin.common.bean.WxMenu;
|
||||
import me.chanjar.weixin.common.bean.result.WxError;
|
||||
import me.chanjar.weixin.common.bean.result.WxMediaUploadResult;
|
||||
import me.chanjar.weixin.common.exception.WxErrorException;
|
||||
import me.chanjar.weixin.common.session.InMemorySessionManager;
|
||||
import me.chanjar.weixin.common.session.StandardSessionManager;
|
||||
import me.chanjar.weixin.common.session.WxSessionManager;
|
||||
import me.chanjar.weixin.common.util.StringUtils;
|
||||
import me.chanjar.weixin.common.util.crypto.SHA1;
|
||||
@@ -68,7 +68,7 @@ public class WxMpServiceImpl implements WxMpService {
|
||||
|
||||
private int maxRetryTimes = 5;
|
||||
|
||||
protected WxSessionManager sessionManager = new InMemorySessionManager();
|
||||
protected WxSessionManager sessionManager = new StandardSessionManager();
|
||||
|
||||
public boolean checkSignature(String timestamp, String nonce, String signature) {
|
||||
try {
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package me.chanjar.weixin.mp.api;
|
||||
|
||||
import me.chanjar.weixin.common.api.WxConsts;
|
||||
import me.chanjar.weixin.common.session.StandardSessionManager;
|
||||
import me.chanjar.weixin.common.session.WxSessionManager;
|
||||
import me.chanjar.weixin.mp.bean.WxMpXmlMessage;
|
||||
import me.chanjar.weixin.mp.bean.WxMpXmlOutMessage;
|
||||
@@ -159,4 +160,136 @@ public class WxMpMessageRouterTest {
|
||||
|
||||
}
|
||||
|
||||
@DataProvider
|
||||
public Object[][] standardSessionManager() {
|
||||
|
||||
// 故意把session存活时间变短,清理更频繁
|
||||
StandardSessionManager ism = new StandardSessionManager();
|
||||
ism.setMaxInactiveInterval(1);
|
||||
ism.setProcessExpiresFrequency(1);
|
||||
ism.setBackgroundProcessorDelay(1);
|
||||
|
||||
return new Object[][] {
|
||||
new Object[] { ism }
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
@Test(dataProvider = "standardSessionManager")
|
||||
public void testSessionClean1(StandardSessionManager ism) throws InterruptedException {
|
||||
|
||||
// 两个同步请求,看是否处理完毕后会被清理掉
|
||||
final WxMpMessageRouter router = new WxMpMessageRouter(null);
|
||||
router.setSessionManager(ism);
|
||||
router
|
||||
.rule().async(false).handler(new WxSessionMessageHandler()).next()
|
||||
.rule().async(false).handler(new WxSessionMessageHandler()).end();
|
||||
|
||||
WxMpXmlMessage msg = new WxMpXmlMessage();
|
||||
msg.setFromUserName("abc");
|
||||
router.route(msg);
|
||||
|
||||
Thread.sleep(2000l);
|
||||
Assert.assertEquals(ism.getActiveSessions(), 0);
|
||||
|
||||
}
|
||||
|
||||
@Test(dataProvider = "standardSessionManager")
|
||||
public void testSessionClean2(StandardSessionManager ism) throws InterruptedException {
|
||||
|
||||
// 1个同步,1个异步请求,看是否处理完毕后会被清理掉
|
||||
{
|
||||
final WxMpMessageRouter router = new WxMpMessageRouter(null);
|
||||
router.setSessionManager(ism);
|
||||
router
|
||||
.rule().async(false).handler(new WxSessionMessageHandler()).next()
|
||||
.rule().async(true).handler(new WxSessionMessageHandler()).end();
|
||||
|
||||
WxMpXmlMessage msg = new WxMpXmlMessage();
|
||||
msg.setFromUserName("abc");
|
||||
router.route(msg);
|
||||
|
||||
Thread.sleep(2000l);
|
||||
Assert.assertEquals(ism.getActiveSessions(), 0);
|
||||
}
|
||||
{
|
||||
final WxMpMessageRouter router = new WxMpMessageRouter(null);
|
||||
router.setSessionManager(ism);
|
||||
router
|
||||
.rule().async(true).handler(new WxSessionMessageHandler()).next()
|
||||
.rule().async(false).handler(new WxSessionMessageHandler()).end();
|
||||
|
||||
WxMpXmlMessage msg = new WxMpXmlMessage();
|
||||
msg.setFromUserName("abc");
|
||||
router.route(msg);
|
||||
|
||||
Thread.sleep(2000l);
|
||||
Assert.assertEquals(ism.getActiveSessions(), 0);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@Test(dataProvider = "standardSessionManager")
|
||||
public void testSessionClean3(StandardSessionManager ism) throws InterruptedException {
|
||||
|
||||
// 2个异步请求,看是否处理完毕后会被清理掉
|
||||
final WxMpMessageRouter router = new WxMpMessageRouter(null);
|
||||
router.setSessionManager(ism);
|
||||
router
|
||||
.rule().async(true).handler(new WxSessionMessageHandler()).next()
|
||||
.rule().async(true).handler(new WxSessionMessageHandler()).end();
|
||||
|
||||
WxMpXmlMessage msg = new WxMpXmlMessage();
|
||||
msg.setFromUserName("abc");
|
||||
router.route(msg);
|
||||
|
||||
Thread.sleep(2000l);
|
||||
Assert.assertEquals(ism.getActiveSessions(), 0);
|
||||
|
||||
}
|
||||
|
||||
@Test(dataProvider = "standardSessionManager")
|
||||
public void testSessionClean4(StandardSessionManager ism) throws InterruptedException {
|
||||
|
||||
// 一个同步请求,看是否处理完毕后会被清理掉
|
||||
{
|
||||
final WxMpMessageRouter router = new WxMpMessageRouter(null);
|
||||
router.setSessionManager(ism);
|
||||
router
|
||||
.rule().async(false).handler(new WxSessionMessageHandler()).end();
|
||||
|
||||
WxMpXmlMessage msg = new WxMpXmlMessage();
|
||||
msg.setFromUserName("abc");
|
||||
router.route(msg);
|
||||
|
||||
Thread.sleep(2000l);
|
||||
Assert.assertEquals(ism.getActiveSessions(), 0);
|
||||
}
|
||||
|
||||
{
|
||||
final WxMpMessageRouter router = new WxMpMessageRouter(null);
|
||||
router.setSessionManager(ism);
|
||||
router
|
||||
.rule().async(true).handler(new WxSessionMessageHandler()).end();
|
||||
|
||||
WxMpXmlMessage msg = new WxMpXmlMessage();
|
||||
msg.setFromUserName("abc");
|
||||
router.route(msg);
|
||||
|
||||
Thread.sleep(2000l);
|
||||
Assert.assertEquals(ism.getActiveSessions(), 0);
|
||||
}
|
||||
}
|
||||
|
||||
public static class WxSessionMessageHandler implements WxMpMessageHandler {
|
||||
|
||||
@Override
|
||||
public WxMpXmlOutMessage handle(WxMpXmlMessage wxMessage, Map<String, Object> context, WxMpService wxMpService,
|
||||
WxSessionManager sessionManager) {
|
||||
sessionManager.getSession(wxMessage.getFromUserName());
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user