Java微信二次開發(fā)(一) Java微信請求驗證功能
準備用Java做一個微信二次開發(fā)項目,把流程寫在這里吧。
第一篇,做微信請求驗證
需要導入庫:servlet-api.jar
第一步:新建包com.wtz.service,新建類LoginServlet.java
package com.wtz.service;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.wtz.util.ValidationUtil;
/**
* @author wangtianze QQ:864620012
* @date 2017年4月17日 下午8:11:32
* <p>version:1.0</p>
* <p>description:微信請求驗證類</p>
*/
public class LoginServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("get請求。。。。。。");
//1.獲得微信簽名的加密字符串
String signature = request.getParameter("signature");
//2.獲得時間戳信息
String timestamp = request.getParameter("timestamp");
//3.獲得隨機數(shù)
String nonce = request.getParameter("nonce");
//4.獲得隨機字符串
String echostr = request.getParameter("echostr");
System.out.println("獲得微信簽名的加密字符串:"+signature);
System.out.println("獲得時間戳信息:"+timestamp);
System.out.println("獲得隨機數(shù):"+nonce);
System.out.println("獲得隨機字符串:"+echostr);
PrintWriter out = response.getWriter();
//驗證請求確認成功原樣返回echostr參數(shù)內容,則接入生效,成為開發(fā)者成功,否則失敗
if(ValidationUtil.checkSignature(signature, timestamp, nonce)){
out.print(echostr);
}
out.close();
out = null;
}
}
第二步:新建包com.wtz.util,新建類Validation.java
package com.wtz.util;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
/**
* @author wangtianze QQ:864620012
* @date 2017年4月17日 下午8:35:57
* <p>version:1.0</p>
* <p>description:微信請求校驗工具類</p>
*/
public class ValidationUtil {
private static String token = "wangtianze";
public static boolean checkSignature(String signature,String timestamp,String nonce){
//1.將token,timestamp,nonce三個參數(shù)進行排序
String[] str = new String[]{token,timestamp,nonce};
Arrays.sort(str);
//2.將三個參數(shù)字符串拼接成一個字符串
StringBuilder buff = new StringBuilder();
for(int i=0;i<buff.length();i++){
buff.append(str[i]);
}
//3.進行sha1加密
MessageDigest md = null;
String result = "";
try {
md = MessageDigest.getInstance("SHA-1");
byte[] data = md.digest(buff.toString().getBytes());
//將字節(jié)數(shù)組轉換成字符串
result = bytesToString(data);
System.out.println("加密后的字符串為:"+result);
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return result!=null?(result.equals(signature.toUpperCase())):false;
}
/**
* 將字節(jié)數(shù)組轉換成十六進制字符串
* @param byteArray
* @return
*/
private static String bytesToString(byte[] byteArray){
String stringDigest = "";
for(int i=0;i<stringDigest.length();i++){
stringDigest += byteToHexString(byteArray[i]);
}
return stringDigest;
}
/**
* 將一個字節(jié)轉換為十六進制字符串
* @param mByte
* @return
*/
private static String byteToHexString(byte mByte){
char[] digit = {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
char[] temp = new char[2];
temp[0] = digit[(mByte>>>4) & 0X0F];
temp[1] = digit[mByte & 0X0F];
String str = new String(temp);
return str;
}
}
第一天就做了這些,完成了微信請求驗證的功能。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Springboot使用zxing實現(xiàn)二維碼生成和解析
ZXing支持各種條形碼,二維碼掃描,由多個模塊組成,?而且支持PC端,移動端,本文將利用zxing實現(xiàn)二維碼生成和解析,感興趣的小伙伴可以跟隨小編一起學習一下2023-10-10
利用MyBatis-Plus靈活處理JSON字段的技巧與最佳實踐
這篇文章主要給大家介紹了關于利用MyBatis-Plus靈活處理JSON字段的技巧與最佳實踐,Mybatis-Plus可以很方便地處理JSON字段,在實體類中可以使用@JSONField注解來標記JSON字段,需要的朋友可以參考下2024-07-07
SpringMVC使用JsonView針對統(tǒng)一實體返回不同信息
這篇文章主要為大家介紹了SpringMVC使用JsonView針對統(tǒng)一實體返回不同信息,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-03-03
關于springboot配置druid數(shù)據(jù)源不生效問題(踩坑記)
今天日常跟著網(wǎng)課學習,學到了整合druid數(shù)據(jù)源,遇到了好幾個坑,希望這篇文章可以幫助一些和我一樣踩坑的人2021-09-09
java整數(shù)與byte數(shù)組的轉換實現(xiàn)代碼
這篇文章主要介紹了java整數(shù)與byte數(shù)組的轉換實現(xiàn)代碼的相關資料,需要的朋友可以參考下2017-07-07

