微信公众账号申请完成后,默认开启的是编辑模式。
我们需要修改为开发模式。
登陆微信公众平台》功能》高级功能
先关闭 编辑模式,再开启 开发模式。
申请成为开发者,如果是服务号,需要则会有开发者凭证信息
如图
如果是订阅号,则只显示服务器配置。
下一步就是配置接口服务器了。
在公众平台网站的高级功能 – 开发模式页,点击“成为开发者”按钮,填写URL和Token,其中URL是开发者用来接收微信服务器数据的接口URL。(这就是我们开发的程序,并部署到公网上了)
Token 官网描述:可由开发者任意填写,用作生成签名(该Token会和接口URL中包含的Token进行比对,从而验证安全性)。
总之就是你的程序里面写的token和这里填入的token要一致。
还没有url和token?
首先需要新建一个java web工程。
接下来就要看看验证url和token了。
下面是官网的描述,已经写的很清楚了
核心实现方式就是将三个参数排序,拼接成字符串进行sha1加密,然后与signature比较
官网也给了实例,是php的,我们只需要装换成java就可以了。
private function checkSignature() { $signature = $_GET["signature"]; $timestamp = $_GET["timestamp"]; $nonce = $_GET["nonce"]; $token = TOKEN; $tmpArr = array($token, $timestamp, $nonce); sort($tmpArr); $tmpStr = implode( $tmpArr ); $tmpStr = sha1( $tmpStr ); if( $tmpStr == $signature ){ return true; }else{ return false; } }
java代码 我的 WeixinController 类
我的项目架构是基于spring3.0的,用到了注解。当get请求的时候会执行get方法,post请求的时候会执行post方法,分别来处理不同的请求,各位也可用servlet等去实现,原理都一样
package com.ifp.weixin.controller; import java.io.IOException; import java.io.PrintWriter; import java.io.UnsupportedEncodingException; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import com.ifp.weixin.biz.core.CoreService; import com.ifp.weixin.util.SignUtil; @Controller @RequestMapping("/weixinCore") public class WeixinController { @Resource(name="coreService") private CoreService coreService; @RequestMapping(method = RequestMethod.GET) public void get(HttpServletRequest request, HttpServletResponse response) { // 微信加密签名,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 = null; try { out = response.getWriter(); // 通过检验signature对请求进行校验,若校验成功则原样返回echostr,否则接入失败 if (SignUtil.checkSignature(signature, timestamp, nonce)) { out.print(echostr); } } catch (IOException e) { e.printStackTrace(); } finally { out.close(); out = null; } } @RequestMapping(method = RequestMethod.POST) public void post(HttpServletRequest request, HttpServletResponse response) { //暂时空着,在这里可处理用户请求 } }
上面类中用到了SignUtil 类
package com.ifp.weixin.util; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Arrays; import com.ifp.weixin.constant.Constant; /** * 验证签名 * */ public class SignUtil { /** * 验证签名 * @param signature * @param timestamp * @param nonce * @return */ public static boolean checkSignature(String signature, String timestamp, String nonce) { String[] arr = new String[] { Constant.TOKEN, timestamp, nonce }; // 将token、timestamp、nonce三个参数进行字典排序 Arrays.sort(arr); StringBuilder content = new StringBuilder(); for (int i = 0; i < arr.length; i++) { content.append(arr[i]); } MessageDigest md = null; String tmpStr = null; try { md = MessageDigest.getInstance("SHA-1"); // 将三个参数字符串拼接成一个字符串进行sha1加密 byte[] digest = md.digest(content.toString().getBytes()); tmpStr = byteToStr(digest); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } content = null; // 将sha1加密后的字符串可与signature对比 return tmpStr != null ? tmpStr.equals(signature.toUpperCase()) : false; } /** * 将字节数组转换为十六进制字符串 * * @param byteArray * @return */ private static String byteToStr(byte[] byteArray) { String strDigest = ""; for (int i = 0; i < byteArray.length; i++) { strDigest += byteToHexStr(byteArray[i]); } 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; } }
我们看到 checkSignature 这个方法里使用到了Constant.TOKEN ,这个token,我声明的一个常量。
要与微信配置接口里面的token值一样
/** * 与接口配置信息中的Token要一致 */ public static String TOKEN = "infopower";
也贴上web.xml的配置,我的后缀是.html 的请求都交给DispatcherServlet了。
<?xml version="1.0" encoding="UTF-8"?> <web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"> <display-name>weixinHelp</display-name> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:/applicationContext.xml</param-value> </context-param> <context-param> <param-name>log4jConfigLocation</param-name> <param-value>classpath:/properties/log4j.properties</param-value> </context-param> <listener> <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class> </listener> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <listener> <description>spring 容器的监听器</description> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <servlet> <servlet-name>action</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>action</servlet-name> <url-pattern>*.html</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app>
我们的代码已经写完了,访问请求地址试试
什么都没有显示,看看后台
报空指针异常
别担心,我们的代码没问题。
因为直接访问地址,默认是get请求,而什么参数都没有传给后台,当然会报空指针
前台没有异常,是因为我做了异常处理。
ok
接下来就是把代码打成war包发布到外网。
然后填入相应的url和token,接口的配置就完成了。
注意1:一定要发布war包到外网,配置外网的url,有些开发者配置的是ip是localhost,那肯定是不行的啦。
如果没有外网环境,请看我的第一篇,环境准备,里面有介绍可以使用百度bae
http://tuposky.iteye.com/blog/2008583
注意2:开发模式一定要开启,不然配置了url和token也没用,我犯过这个错,嘿嘿。
可加我的微信公众号一起讨论
微信公众号:andedaohang
或扫描二维码
转载请注明出处:
我所有的博客都搬到csdn了,以后所有的博客都会在csdn上更新,
CSDN博客地址:http://blog.csdn.net/tuposky
相关推荐
微信公众帐号开发教程第 3 篇-开发模式启用及接口配置.. 7 微信公众帐号开发教程第 4 篇-消息及消息处理工具的封装. 17 微信公众帐号开发教程第 5 篇-各种消息的接收与响应 39 微信公众帐号开发教程第 6 篇-文本消息...
2. 微信公众帐号开发教程第2篇-微信公众帐号...3. 微信公众帐号开发教程第3篇-开发模式启用及接口配置 . 微信公众帐号开发教程第5篇-各种消息的接收与响应 6. 微信公众帐号开发教程第6篇-文本消息的内容长度限制揭秘
[027] 微信公众帐号开发教程第3篇-开发模式启用及接口配置 - 柳峰的专栏 - 博客频道 - CSDN.NET [035] 微信公众帐号开发教程第11篇-符号表情的发送(上) - 柳峰的专栏 - 博客频道 - CSDN.NET [036] 微信公众帐号...
微信公众帐号开发教程第1 篇-引言 ...微信公众帐号开发教程第3 篇-开发模式启用及接口配置 微信公众帐号开发教程第4 篇-消息及消息处理工具的封装 微信公众帐号开发教程第5 篇-各种消息的接收与响应
微信服务号Java版开发教程是针对使用Java语言进行微信服务号功能开发的全面指南。微信服务号是一个为企业和组织提供更强大的业务服务与用户管理能力的公众平台,它允许开发者通过API接口实现各种功能,例如自定义...
MVC模式的微信公众平台接口开发DEMO,验证。
他还是一位资深的Java软件开发工程师和Android/iOS移动应用开发工程师,活跃于CocoaChina、开源中国、CSDN等社区,CSDN博客专家,在CSDN博客撰写了系列微信公众平台二次开发的教程,深受欢迎并被广泛传播,也因此...
微信小程序是一种轻量级的应用程序,可以在微信的环境中运行,无需下载安装即可使用。它主要由JavaScript、WXML... - 上传小程序到微信公众平台。 - 提交审核。 - 发布上线。 ### 常用API接口 - **wx.request()
登录微信公众平台后,点击高级功能=》开发模式=》成为开发者=》填写接口配置信息,提交后等待我司工作人员的审核. 1. 开发者认证 这个最简单了,直接上个超简单版代码: exit($_GET['echostr']); php文件就写上面这一...
通过这个"Java微信支付视频教程",你不仅可以掌握Java语言与微信支付接口的对接技术,还能了解到支付系统的设计原则和安全策略,为你的项目开发增添强大的支付功能。无论是电商平台还是其他需要支付功能的应用,这套...
本文实例讲述了.net开发微信公众平台的方法。分享给大家供大家参考。具体实现方法如下: 一、说明: 公众平台信息接口为开发者提供了一种新的消息处理方式,只有申请成为开发者后,你才能使用公众平台的开发功能,在...
微信开放平台提供了丰富的接口和服务,让开发者能够接入微信的各种功能,包括扫码登录。首先,你需要在微信开放平台上注册成为开发者,并创建一个应用,获取到AppID和AppSecret,这两个是后续调用微信API的基础。 ...
open_wechat是一个用Java语言开发的微信公众平台基础开发框架,open_chat致力于暴露尽量简单的接口,减少开发者对微信公众平台开发协议的关注。 open_wechat基于Maven开发,使用spring-mvc作为MVC框架。 open_wechat...
在微信小程序开发中,开发者可以使用小程序提供的编程框架进行开发,这个框架包含了一个基础的逻辑层和两个视图层,分别是 WXML(WeiXin Markup Language,微信标记语言)和 WXSS(WeiXin Style Sheets,微信样式表...
如果你自己仔细研究下,其实那么点东西,C#实现起来也很简单,原本不想写这篇文章的,但是本人当时摸索走了很多弯路,这边总结下,希望初次接触微信公众平台的朋友别像当时的我一样。 自己动手,丰衣足食。 ...
微信小程序是一种轻量级的应用开发平台,允许开发者快速构建功能丰富的应用,无需安装即可在微信内使用。本教程将指导你完成一个基础的微信小程序的开发,包括设置、创建项目、理解和编辑核心文件,以及预览和调试。...
### 微信小程序详细教程知识点解析 #### 一、小程序的开发准备 ##### 1.1 小程序的安装与创建 - **第一步**: 访问微信官方开发者平台(https://developers.weixin.qq.com/miniprogram/dev/index.html),注册并登录...
"电影周周看"微信小程序源代码提供了一个极好的学习平台,特别是对于编程新手来说,这是一个了解并掌握微信小程序开发的绝佳起点。 首先,我们要理解微信小程序的基本结构。一个完整的微信小程序由多个部分组成,...
最后,通过微信公众平台提交审核,审核通过后即可发布上线,供用户使用。 通过学习以上知识点,你将具备开发微信小程序课程表系统的能力。实践是最好的老师,动手尝试创建自己的小程序,你将不断深化对这一技术的...