微信公众平台停用服务器配置,1.微信公众号服务器配置启用

微信公众号开发首先要配置服务器,否则你只能使用一些简单功能,比如自动回复。

1.登录微信公众号并且进入开发的基本配置

446670478591

image.png

2.微信开发中所有服务器配置是以get请求请求你所配置的服务器的地址。首先贴出服务器配置的简单明文方式代码。

@Path("weixin")

public class WeXinResource

{

@GET

@Path("message")

public String getMessage(@QueryParam("signature") String signature, @QueryParam("timestamp") String timestamp, @QueryParam("nonce") String nonce, @QueryParam("echostr") String echostr ) throws Exception {

String sig = null;

if(SignUtil.checkSignature(signature, timestamp, nonce)) {

System.out.println(echostr);

return echostr;

}

return null;

}

return "";

}

}

public class SignUtil {

private static String token = "weixin";//服务器配置中的令牌

/**

* 校验签名

* @param signature 签名

* @param timestamp 时间戳

* @param nonce 随机数

* @return true 成功,false 失败

*/

public static boolean checkSignature(String signature,String timestamp, String nonce){

String checktext = null;

if(null != signature){

//对Token,timestamp nonce 按字典排序

String [] paramArr = new String[] {token, timestamp, nonce};

Arrays.sort(paramArr);

//将排序后的结果拼成一个字符串

String content = paramArr[0].concat(paramArr[1]).concat(paramArr[2]);

try {

MessageDigest md = MessageDigest.getInstance("SHA-1");

//对接后的字符串进行sha1加密

byte[] digest = md.digest(content.toString().getBytes());

checktext = byteToStr(digest);

} catch (NoSuchAlgorithmException e) {

e.printStackTrace();

}

}

//将加密后的字符串与signature进行对比

return checktext != null ? checktext.matches(signature.toUpperCase()) :false;

}

/**

* 将字节数组转化为16进制字符串

* @return 字符串

*/

private static String byteToStr(byte[] byteArrays) {

String str="";

for (int i = 0; i < byteArrays.length; i++){

str += byteToHexStr(byteArrays[i]);

}

return str;

}

/**

* 将字节转化为十六进制字符串

* @param myByte 字节

* @return 字符串

*/

private static String byteToHexStr(byte myByte) {

char[] Digit = {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};

char[] tempArr = new char[2];

tempArr[0] = Digit[(myByte >>> 4)&0X0F];

tempArr[1] = Digit[myByte & 0x0F];

String str = new String(tempArr);

return str;

}

}

3.由代码可以看出来我们的服务器验证是将微信将timestamp,nonce,和服务器配置中的令牌token进行组合加密后得到的值和signature进行判断如果一致则返回echostr告诉微信我们这边服务器验证通过否则就不返回。其中注意一点返回值echostr直接返回不要进行任何json形式处理比如{code: 200, data: "1486311617119204983"} 。

4.这样我们服务器配置的地方就完了。注意代码中的 private static String token = "weixin"是服务器配置中的令牌 而消息加解密密钥随便选择一个即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值