46 lines
1.3 KiB
Java
46 lines
1.3 KiB
Java
package com.zeekling.solo.weixin.controller;
|
|
|
|
import com.qq.weixin.mp.aes.AesException;
|
|
import com.zeekling.solo.weixin.conf.WeXinConfigure;
|
|
import com.zeekling.solo.weixin.entity.Validate;
|
|
import com.zeekling.solo.weixin.verify.SHA1;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
import org.springframework.web.bind.annotation.RequestMapping;
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
import javax.annotation.Resource;
|
|
|
|
/**
|
|
* @author zeekling [lingzhaohui@zeekling.cn]
|
|
* @version 1.0
|
|
* @apiNote
|
|
* @since 2020-03-17
|
|
*/
|
|
@RestController
|
|
public class WeXinController {
|
|
|
|
private Logger logger = LoggerFactory.getLogger(getClass());
|
|
|
|
@Resource
|
|
private WeXinConfigure wechatConfig;
|
|
|
|
@RequestMapping(value = "/validate")
|
|
public String validate(Validate validate) throws AesException {
|
|
String token = wechatConfig.getToken();
|
|
String signature = SHA1.getSHA1(token, validate.getTimestamp(), validate.getNonce());
|
|
// 3.字符串校验
|
|
if (validate.getSignature().equals(signature)) {
|
|
logger.info("微信-签名校验通过");
|
|
logger.info("回复给微信的 echostr 字符串:{}", validate.getEchostr());
|
|
return validate.getEchostr();
|
|
} else {
|
|
logger.error("微信-签名校验失败");
|
|
return "";
|
|
}
|
|
|
|
}
|
|
|
|
|
|
}
|