微信后台服务器配置 、第三方后台 验证服务器地址的有效性,判断请求来自微信服务器...

微信接入概述

接入微信公众平台开发,开发者需要按照如下步骤完成:

1、填写服务器配置  (微信公众平台后台配置服务器后会发送消息到配置的第三方链接地址 GET请求)

2、验证服务器地址的有效性 (第三方后台添加接收服务器配置传输过来的消息进行验证有效性)

3、依据接口文档实现业务逻辑

4、给公众号发送消息时公众号会推送消息到服务器配置的第三方链接地址 (POST请求)

微信服务器配置

第三方服务器开发

接收服务器配置时传输过来的数据进行验证

  

package com.demo.servlet;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.demo.utils.CheckSignatureUtil;

/**
 * 类名: CoreServlet </br> 
 * 描述: 来接收微信服务器传来信息 </br> 
 * 开发人员: tian</br> 
 * 创建时间:2017年2月14日 10:08:53 </br> 
 * 发布版本:V1.0 </br>
 */
@WebServlet("/coreServlet")
public class CoreServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
       
    /**
     * @see HttpServlet#HttpServlet()
     */
    public CoreServlet() {
        super();
    }

    /**
     * 验证服务器地址的有效性,判断请求来自微信服务器
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数
        String signature = request.getParameter("signature");
        //时间戳
        String timestamp = request.getParameter("timestamp");
        //随机数
        String nonce = request.getParameter("nonce");
        //随机字符串
        String echostr = request.getParameter("echostr");
        
        PrintWriter out = response.getWriter();
        
         // 通过检验signature对请求进行校验,若校验成功则原样返回echostr,表示接入成功,否则接入失败
        if(CheckSignatureUtil.checkSignature(signature, timestamp, nonce)){
            out.print(echostr);
        }
        out.close();
        out = null;
        
    }

    /**
     *  处理微信服务器发来的消息
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
    }

}
package com.demo.utils;

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;


/**
* 类名: CheckSignatureUtil </br>
* 描述: 检验signature 工具类 </br>
* 开发人员: tian </br>
* 创建时间:  2017年2月14日10:41:04 </br>
* 发布版本:V1.0  </br>
 */
public class CheckSignatureUtil {
    
    //token 令牌标识、和微信开发者中心配置服务器一致
    private static String token = "tian";
    
    
    /**
     * 校验微信加密签名
     * @param signature 微信加密签名
     * @param timestamp 时间戳
     * @param nonce    随机数
     * @return 签名是否正确
     */
    public static boolean checkSignature(String signature,String timestamp,String nonce){
         // 1.将token、timestamp、nonce三个参数进行字典序排序
        String[] arr = new String[]{token,timestamp,nonce};
        Arrays.sort(arr);
        // 2. 将三个参数字符串拼接成一个字符串进行sha1加密
        StringBuffer content = new StringBuffer();
        for (String temp : arr) {
            content.append(temp);
        }
         // 将三个参数字符串拼接成一个字符串进行sha1加密
        String currSignature = getSha1(content.toString());
        return currSignature!=null?currSignature.equals(signature.toUpperCase()):false;
    }
    
    
    /**
     * 字符串 sha1 加密
     * @param str 需加密字符串 
     * @return 加密后字符串
     */
    public static String getSha1(String str){
       if (null == str || 0 == str.length()){
            return null;
        }
       String byteToStr = "";
       try {
            MessageDigest md = MessageDigest.getInstance("SHA1");
            md.update(str.getBytes("UTF-8"));
            byte[] digest = md.digest();
            byteToStr = byteToStr(digest);
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return byteToStr;
    }
    

    /**
     * 将字节数组转换为十六进制字符串
     * @param byteArray 字节数组
     * @return 十六进制字符串
     */
    private static String byteToStr(byte[] byteArray) {
        String strDigest = "";
        for (byte mByte : byteArray) {
            strDigest += byteToHexStr(mByte);
        }
        return strDigest;
    }

    /**
     * 将字节转换为十六进制字符串
     * @param mByte 字节
     * @return 十六进制字符串
     */
    private static String byteToHexStr(byte mByte) {
        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[(mByte >>> 4) & 0X0F];
        tempArr[1] = Digit[mByte & 0X0F];
        String s = new String(tempArr);
        return s;
    }
    
}

 

 

 

 

转载于:https://www.cnblogs.com/tianzhongshan/p/6560253.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在微信服务器上使用宝塔面板搭建基于 Node.js 的小程序后台,您可以按照以下步骤进行操作: 1. 首先,确保您的微信服务器已经安装了 CentOS 操作系统。如果没有安装,您可以在微信服务器控制台上选择 CentOS 镜像进行安装。 2. 登录到您的微信服务器,可以使用 SSH 工具(如 PuTTY)进行连接。 3. 安装宝塔面板。可以使用以下命令在服务器上下载并执行宝塔面板的安装脚本: ``` yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh ``` 4. 安装完成后,您可以通过浏览器访问服务器的公网 IP 地址加上端口 8888(例如 http://服务器公网IP:8888)来访问宝塔面板。 5. 在浏览器中打开宝塔面板后,按照提示进行初始化设置,包括设置管理员账号和密码等。 6. 在宝塔面板中,选择“软件商店”,然后搜索并安装适合您的 Node.js 运行环境。 7. 安装完成后,您可以在宝塔面板中创建一个网站,并配置域名或使用默认的访问地址。 8. 在您的微信服务器上,使用 SSH 连接并进入您的网站根目录。一般情况下,宝塔面板会将网站文件存放在`/www/wwwroot/您的域名/public`目录下。 9. 在网站根目录下,使用以下命令初始化一个新的 Node.js 项目: ``` npm init ``` 这将在当前目录下创建一个 `package.json` 文件,用于管理您的 Node.js 项目的依赖和配置。 10. 安装您需要的 Node.js 框架和模块。例如,如果您想使用 Express 框架,可以使用以下命令安装: ``` npm install express ``` 11. 编写您的 Node.js 后台代码,包括路由、控制器、数据库连接等。 12. 在宝塔面板中,找到网站对应的域名配置,设置反向代理规则,将请求转发到 Node.js 项目运行的端口。 13. 启动您的 Node.js 服务器。在网站根目录下执行以下命令: ``` node app.js ``` 这将启动您的 Node.js 项目,并监听来自宝塔面板配置的端口的请求。 现在,您的基于 Node.js 的小程序后台已经搭建完成。您可以通过浏览器访问您的小程序后台,使用宝塔面板中配置的域名或服务器的公网 IP 地址来访问。 请注意,以上步骤仅为搭建 Node.js 小程序后台的基本步骤,具体的操作和配置可能会因您的项目需求而有所不同。建议您在搭建过程中参考官方文档或寻求开发人员的指导。 祝您搭建成功!如果您还有其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值