最近在做微信服務號碼開發,簡單總結一下,方便自己學習累積和分享給大家:
環境介紹:
Spring Spring MVC Mybatis
開發語言:
JAVA
微信大眾平台的開發中,微信隻公佈了一個基於Http協定的介面和加解密的演算法sdk,在開發的過程中可以自己根據需求來配置數據,調用相關接口,也可以引用比較成熟的基於java語言的微信公眾號sdk。作者引用的是目前較流行的
weixin-java-tools
可以參考:點選開啟連結
專案中引入了 weixin-java-mp-2.9.0.jar和 weixin-java-common-2.9.0.jar 就可直接呼叫相關功能介面及完成jssdk認證 # 分享介面:
# 1.後台準備:
建立一個公用控制類別: WeXinJsSdkController ,透過ajax 存取完成jssdk認證:
@Controller @RequestMapping("jssdk") public class WeXinJsSdkController { @Autowired private WxMpService wxMpService; @RequestMapping(value = "/config", method = RequestMethod.GET) @ResponseBody public WxJsapiSignature wxJsSdkConfig(HttpServletRequest request,String url) { try { // 直接调用wxMpServer 接口 WxJsapiSignature wxJsapiSignature = wxMpService.createJsapiSignature(url); return wxJsapiSignature; } catch (WxErrorException e) { return null; } } }
<%--通过config接口注入权限验证配置--%> /* 初始化jssdk 分享功能 */ $.get("${basePath}/jssdk/config.do",{url:window.location.href},function(data,status){ if(status == "success"){ wx.config({ debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId: data.appId, // 必填,公众号的唯一标识 timestamp: data.timestamp, // 必填,生成签名的时间戳 nonceStr: data.nonceStr, // 必填,生成签名的随机串 signature: data.signature,// 必填,签名,见附录1 jsApiList: ['checkJsApi', 'onMenuShareTimeline', 'onMenuShareAppMessage', 'onMenuShareQQ'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ // layer.msg("jssdk初始化成功"); // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作, //所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。 <%-- 分型内容 分享给朋友、朋友圈、 --%> var shareData = { title: '${requestScope.atc.trainsubject}', desc: '${description}', // link: 'https://www.baidu.com', // 分享域名要和当前域名保持一致!! imgUrl: 'http://www.cyfd.cn/tektcrm/EventNoti/images/attendance.png', success: function (res) { // alert('已分享'); }, cancel: function (res) { // alert('已取消'); }, fail: function (res) { // alert(JSON.stringify(res)); } }; <%--分享给朋友接口--%> wx.onMenuShareAppMessage(shareData); <%--分享到朋友圈接口--%> wx.onMenuShareTimeline(shareData); <%--分享到QQ朋友接口--%> wx.onMenuShareQQ(shareData); }); wx.error(function(res){ // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看, //也可以在返回的res参数中查看,对于SPA可以在这里更新签名。 // layer.msg(res); }); } },"json");
以上是微信開發的分享介面 相關內容的詳細內容。更多資訊請關注PHP中文網其他相關文章!