記事ディレクトリ
WeChatパブリックプラットフォーム開発の概要| WeChat公式ドキュメント
1.テスト番号を申請する
個人的に申請した公式アカウントは認証できず、取得できない権限が多いため、まずはテスト公式アカウントを申請してください。テストアカウントを申請する方がはるかに便利です。
テスト番号を申請する
2.イントラネットペネトレーションアクセス
テストを容易にするためにイントラネットペネトレーションを使用する必要があります。また、クラウドサーバーに直接展開することもできます。
無料のSunny-Ngrokイントラネット転送を使用しています。不安定な場合は、さらに数回試してください。
3、クラウドサーバーアクセス
クラウドサービスに接続するには、nginx転送を構成する必要があります
location /wx {
proxy_pass http://116.62.13.104:8083;
}
次に、nginx ./nginx -s reload
URLを再起動します:http://116.62.13.104/wx/
3、コードアクセス
このページには、インターフェイス構成情報があることがわかります。これ
URL
は、プロジェクトにアクセスするためにWeChatサーバーに指定するアドレスです。ここではイントラネットペネトレーションを使用するため、他のユーザーから割り当てられたドメイン名アドレスを使用します(クラウドサーバーのみを使用する場合は、通常のアドレスを入力します)。 Ip + port + path)。
Token
自由に定義します。
注:プロジェクト(イントラネットの浸透を構成するためにローカルで開始するか、クラウドサービスに展開する)を正常に構成できる場合は、URLを介してWeChatサーバーを構成できる必要があります。
プロジェクト構造
application.yml
server:
port: 8083
tomcat:
# tomcat的URI编码
uri-encoding: UTF-8
# tomcat最大线程数,默认为200
# Tomcat启动初始化的线程数,默认值25
threads:
max: 800
min-spare: 30
spring:
datasource:
url: jdbc:mysql://116.62.13.104:3306/countdown?serverTimezone=UTC&useSSL=false&useUnicode=true&characterEncoding=UTF8
username: root
password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver
jpa:
show-sql: true
redis:
host: 116.62.13.104
port: 6379
# token配置
token:
# token 值
value: liushihao123
# 令牌自定义标识
header: Authorization
# 令牌秘钥
secret: abcdefghijklmnopqrstuvwxyz
# 令牌有效期(默认30分钟)
expireTime: 30
logging:
file:
path: /data/wx/logs/
コントローラ
package com.wx.controller;
import com.wx.model.Param;
import com.wx.service.WXService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.io.IOException;
/**
* @author :LiuShihao
* @date :Created in 2020/9/28 2:49 下午
* @desc :
*/
@RestController
@RequestMapping("/wx")
public class WXController {
@Autowired
WXService wxService;
/**
* signature 微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
* timestamp 时间戳
* nonce 随机数
* echostr 随机字符串
*
* 开发者通过检验signature对请求进行校验(下面有校验方式)。
* 若确认此次GET请求来自微信服务器,请原样返回echostr参数内容,则接入生效,成为开发者成功,否则接入失败。
* @return
*/
@GetMapping
public String test1(Param param) throws IOException {
System.out.println("param:"+param);
if(wxService.check(param)){
System.out.println("接入成功");
//原样返回
return param.getEchostr();
}else {
System.out.println("接入失败");
return null;
}
}
}
ServiceImpl
サービスインターフェース
package com.wx.service.Impl;
import com.wx.model.Param;
import com.wx.service.WXService;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
/**
* @author :LiuShihao
* @date :Created in 2020/10/2 1:12 下午
* @desc :
*/
@Service
public class WXServiceImpl implements WXService {
@Value("${token.value}")
public String token;
/**
* 开发者通过检验signature对请求进行校验(下面有校验方式)。
* 若确认此次GET请求来自微信服务器,请原样返回echostr参数内容,则接入生效,成为开发者成功,否则接入失败。加密/校验流程如下:
*
* 1)将token、timestamp、nonce三个参数进行字典序排序
* 2)将三个参数字符串拼接成一个字符串进行sha1加密
* 3)开发者获得加密后的字符串可与signature对比,标识该请求来源于微信
* @param param
* @return
*/
@Override
public boolean check(Param param) {
//1)将token、timestamp、nonce三个参数进行字典序排序
String[] strs = {
token,param.getTimestamp(),param.getNonce()};
Arrays.sort(strs);
//2)将三个参数字符串拼接成一个字符串进行sha1加密
String str = strs[0]+strs[1]+strs[2];
String mysign = sha1(str);
System.out.println("加密前:"+str);
System.out.println("Signature:"+param.getSignature());
System.out.println("mysign::"+mysign);
//3)开发者获得加密后的字符串可与signature对比,标识该请求来源于微信
return param.getSignature().equals(mysign);
}
private String sha1(String str) {
StringBuilder sb = new StringBuilder();
try {
//获取一个加密对象
MessageDigest md = MessageDigest.getInstance("sha1");
//加密
byte[] digest = md.digest(str.getBytes());
char[] chars = {
'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
//处理加密结果
for (byte b : digest){
sb.append(chars[(b>>4)&15]);
sb.append(chars[b&15]);
}
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return sb.toString();
}
}
エンティティクラス
package com.wx.model;
import lombok.Data;
/**
* @author :LiuShihao
* @date :Created in 2020/9/29 5:13 下午
* @desc :
*/
@Data
public class Param {
/**
* signature 微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
* timestamp 时间戳
* nonce 随机数
* echostr 随机字符串
* @return
*/
private String signature;
private String timestamp;
private String nonce;
private String echostr;
}
ページの[送信]をクリックします