关于在网页面调用微信jssdk接口,网页是不是只有在微信内置浏览器里打开,才能触发里面的事件

第一次弄这个,网上看了很多资料,也去官网上看了文档。但是找到一个确定答案。
这次项目需要做一个可以把我们的网站分享到微信的功能,看了网上的网站都是点击一个图标出现一个二维码。
当时我就在想我是不是先要做一个生成二维码的功能呢。网上也有很多插件可以实现。

又搜索到网上有很多调用微信jssdk的方法。
开始我还以为直接调用微信jssdk,就可以弹出一个二维码呢。
后来发现太天真了,写了很多代码,点击之后啥反应都没有。
想问一问微信jssdk里的接口,比如说是分享接口。
1.是不是说我们网上发布的网站里必须写好微信jssdk帮助文档里所说的那些配置和接口,并且必须要用户通过扫一扫在手机微信内置浏览器中打开,并且点击右上角的三个点点,并点击分享按钮才能触发。
2.而我们在网页上写的和微信相关的代码,其实就是在点击微信内置浏览器里右上角三个点点的时候,在手机底部跳出来的这个菜单呢。
3.如果是这样,那我们网站在本地开发不是没法调试了吗?本地调试的话有什么工具呢???
4.还有这些和公众号有什么关系呢。我们的方法写在网页里,难道接口返回的内容不在网页后台接受吗?

希望有人可以回答我吧。不问具体怎么写,只是问一下逻辑而已。不知道我想的对不对!

1个回答

jssdk只能在微信里面用,其他浏览器永不了。就好比ie的acx,你想在chrome,firefox上跑是不可能的,不支持,需要特定的环境,jssdk的环境就是微信

pc端调试用微信自己的工具==》微信web开发者工具

https://mp.weixin.qq.com/wiki?action=doc&id=mp1455784140&t=0.6914906297693256

showbo
支付宝加好友偷能量挖 回复xm3530: 有用记得采纳:)。。。
2 年多之前 回复
xm3530
xm3530 非常感谢
2 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
微信jssdk调用接口时报permission denied
本人想使用微信jssdk的选图接口,但是调用方法时发现不进success回调函数,总是进fail回调函数,报permission denied错误,我的jsApiList明明已经配了选图接口,请问哪位大神知道是怎么回事?
调用微信jssdk,使用开始录音接口时,弹出“要使用你的录音功能,是否允许”
第一次用微信调用时,总是出现这个提示框,只要点击确定,原有的 animate就出现了问题。,如何用js监控这个提示框的出现
微信jssdk调用接口没有响应
代码如下:![图片说明](https://img-ask.csdn.net/upload/201508/21/1440167766_329505.jpg)![图片说明](https://img-ask.csdn.net/upload/201508/21/1440167812_989022.jpg)![图片说明](https://img-ask.csdn.net/upload/201508/21/1440167784_144506.jpg) 没有任何报错信息
微信JSSDK wx.config问题
去年做了个微信扫一扫的功能,调用微信接口。今天放假归来微信APP更新了,导致IOS可以正常调用摄像头扫码,而安卓却没有半点反应。有大佬遇到过这样的问题吗
微信JSSDK调用播放音频接口为什么没有响应?求大神指点!!!!
在做微信语音播放的项目,可是调用后为什么没有动静?wx.ready方法已经通过了,可以alert,但是把检测的JS接口的wx.checkJsApi贴上去也没有什么反应?而且wx.playVoice的接口中localId是否是mediaid?代码如下:求指点。。。。 var timestamp=""; var nonceStr=""; var signature=""; function getVoice(mediaId){ $.ajax({ url : "/getVoice", type : "GET", dataType : "json", success : function(data){ timestamp=data.timestamp; nonceStr=data.nonceStr; signature=data.signature; }, error : function(){ alert("系统故障,请稍后再试!"); } }); } //通过config接口注入权限验证配置,所有需要使用JS-SDK的页面必须先注入配置信息,否则将无法调用 wx.config({ debug: true, appId: 'wxf8b4f85f3a794e77', timestamp: timestamp, nonceStr: nonceStr, signature: signature, jsApiList: [ 'playVoice' ] }); //通过ready接口处理成功验证 wx.ready(function (){ wx.checkJsApi({ jsApiList: ['playVoice'], // 需要检测的JS接口列表,所有JS接口列表见附录2, success: function(res) { alert(res); // 以键值对的形式返回,可用的api值true,不可用为false // 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"} }, fail function (res){ alert(res); } }); }); wx.playVoice({ localId: '' // 需要播放的音频的本地ID,由stopRecord接口获得 });
微信JSSDK图像接口调用,从缓存中获取到的 localId,wx.getLocalImgData 为什么不能执行?
$(document).ready(function () { //查看缓存,判断是否有已经有上传过照片,但是没有提交且刷新页面导致照片消失的情况,在提交表单的时候会清除此缓存 var zpIDs = localStorage.getItem("zpIDs"); alert(1); alert(zpIDs); if(zpIDs!=null&&zpIDs!=''){ var IDs = zpIDs.split(","); for (var i = 0; i < IDs.length; i++) { WX_FUN.showImgByobj(IDs[i], addImg, IDs[i]); } } } ``` _WXUtils.prototype={ init: function(appId,timestamp,nonceStr,signature){ //配置微信JS调用 wx.config({ debug: false, appId: appId, timestamp: timestamp, nonceStr: nonceStr, signature: signature, jsApiList: [ ] }); }, //用于显示图片 add by lv showImgByobj:function(localId,callback,obj){ alert(1111); //用于适配新版的ios 微信 if(window.__wxjs_is_wkwebview==true){ alert(2222); wx.getLocalImgData({ localId: localId.toString(), success: function (res) { var localData = res.localData; alert(3333); callback(localData,obj); } }); }else{ callback(localId,obj); } } } ``` //动态添加img ,add by lv function addImg(src, localId) { var id = localId.replace(/[^0-9]/ig, ""); var lis_count = $("#xsphoto li").length; var li = "<li class='mui-table-view-cell mui-media mui-col-xs-4'>" + "<div class='imgDiv'>" + "<img class='mui-media-object' src='" + src + "'>" + "<input type='hidden' name='picbase64str_zp' id='" + id + "'/>" + "<a href='#' onclick='delImg(this," + lis_count + ")'>" + "<img src='${req.contextPath}/images/cha.png' class='delete' />" + "</a>" + "</div>" + "</li>"; $("#xsphoto ul").append(li); } ``` ``` alert(1111)和alert(2222);都可以执行,但是alert(3333)就不执行,可见 wx.getLocalImgData 没有执行或者执行失败?有大佬知道原因吗?
怎么使用微信jssdk,,,
wx.config({ debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId: '', // 必填,公众号的唯一标识 timestamp: , // 必填,生成签名的时间戳 nonceStr: '', // 必填,生成签名的随机串 signature: '',// 必填,签名,见附录1 jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); 问下appid,timestamp,nonceStr,signature这些都是什么,要在哪里得到啊
调用 微信 分享到朋友圈 接口
调用 微信接口 分享到朋友圈 接口 结果控制台打印出:“[JSSDK Info] 注册 onMenuShareTimeline”; 怎样让我注册 是什么意思? 请赐教
angualr框架 IOS版本偶尔调用微信分享wx.onMenuShareAppMessage无效
本人用的是angualr前端开发框架,在微信分享中,如果签名使用当前页URL,页面URL包含#(签名会报错invalid signature),页面刷新一次后签名才会正确,分享也正常。如果用window.location.href.split('#')[0]签名,签名正确,但IOS手机调用微信JSSDK偶尔会失效,分享错误。之前试过URL去#号模式,问题同上。求解???
微信jssdk调用摄像头如何跳过选择?
![图片说明](https://img-ask.csdn.net/upload/201810/22/1540217866_368430.jpg)
微信JSSDK config显示OK,checkJsApi显示OK,然后就没有任何反应了,求指导
这是我的测试地址:http://ecapex.top/wx/sample/php/sample.php 以下是我的前端代码: ``` <script> wx.config({ debug: true, appId: '<?php echo $signPackage["appId"];?>', timestamp: <?php echo $signPackage["timestamp"];?>, nonceStr: '<?php echo $signPackage["nonceStr"];?>', signature: '<?php echo $signPackage["signature"];?>', jsApiList: [ // 所有要调用的 API 都要加到这个列表中 'updateAppMessageShareData', 'updateTimelineShareData', 'onMenuShareAppMessage', 'onMenuShareTimeline' ] }); //将分享的数组组成json数组 window.share_config = { "share": { "imgUrl": "http://ecapex.top/upload/partertalents/min/20180629202242.jpg",//分享图,默认当相对路径处理,所以使用绝对路径的的话,“http://”协议前缀必须在。 "desc" : "你真是太棒了",//摘要,如果分享到朋友圈的话,不显示摘要。 "title" : '你真是非常的棒',//分享卡片标题 "link": 'http://ecapex.top',//分享出去后的链接,这里可以将链接设置为另一个页面。 "success":function(){//分享成功后的回调函数 }, 'cancel': function () { // 用户取消分享后执行的回调函数 } } }; wx.ready(function () { // 在这里调用 API //判断当前客户端版本是否支持指定JS接口 wx.checkJsApi({ jsApiList: [ // 所有要调用的 API 都要加到这个列表中 'updateAppMessageShareData', 'updateTimelineShareData', 'onMenuShareAppMessage', 'onMenuShareTimeline' ], // 需要检测的JS接口列表,所有JS接口列表见附录2, success: function(res) { console.log(res) // 以键值对的形式返回,可用的api值true,不可用为false // 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"} } }); }); function AppMessage() { wx.updateAppMessageShareData(share_config.share); } function Timeline() { wx.updateTimelineShareData(share_config.share); } function Messages() { wx.onMenuShareAppMessage(share_config.share); } function timelines() { wx.onMenuShareTimeline(share_config.share) } </script> <button onclick="AppMessage()">自定义分享给朋友</button><br> <button onclick="Timeline()">自定义分享到朋友圈</button><br> <button onclick="Messages()">分享给朋友</button> <button onclick="timelines()">分享到朋友圈</button> ``` 后端代码: ``` class JSSDK { private $appId; private $appSecret; public function __construct($appId, $appSecret) { $this->appId = $appId; $this->appSecret = $appSecret; } public function getSignPackage() { $jsapiTicket = $this->getJsApiTicket(); // 注意 URL 一定要动态获取,不能 hardcode. $protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://"; $url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]"; $timestamp = time(); $nonceStr = $this->createNonceStr(); // 这里参数的顺序要按照 key 值 ASCII 码升序排序 $string = "jsapi_ticket=$jsapiTicket&noncestr=$nonceStr&timestamp=$timestamp&url=$url"; $signature = sha1($string); $signPackage = array( "appId" => $this->appId, "nonceStr" => $nonceStr,//随机字符串 "timestamp" => $timestamp,//时间戳 "url" => $url,//当前网页的URL "signature" => $signature,//签名 "rawString" => $string ); return $signPackage; } //设置签名的随机串并按ASCII 码从小到大排序 private function createNonceStr($length = 16) { $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; $str = ""; for ($i = 0; $i < $length; $i++) { $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1); } return $str; } //获取ticket private function getJsApiTicket() { // jsapi_ticket 应该全局存储与更新,以下代码以写入到文件中做示例 $data = json_decode($this->get_php_file("jsapi_ticket.php")); if ($data->expire_time < time()) { $accessToken = $this->getAccessToken(); $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token=$accessToken"; $res = json_decode($this->httpGet($url)); $ticket = $res->ticket; if ($ticket) { $data->expire_time = time() + 7000; $data->jsapi_ticket = $ticket; $this->set_php_file("jsapi_ticket.php", json_encode($data)); } } else { $ticket = $data->jsapi_ticket; } return $ticket; } //获取accesstoken private function getAccessToken() { // access_token 应该全局存储与更新,以下代码以写入到文件中做示例 $data = json_decode($this->get_php_file("access_token.php")); if ($data->expire_time < time()) { $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$this->appId&secret=$this->appSecret"; $res = json_decode($this->httpGet($url)); $access_token = $res->access_token; if ($access_token) { $data->expire_time = time() + 7000; $data->access_token = $access_token; $this->set_php_file("access_token.php", json_encode($data)); } } else { $access_token = $data->access_token; } return $access_token; } private function httpGet($url,$type='get',$res='json',$arr='') { $ch = curl_init(); if (class_exists('\CURLFile')) { curl_setopt($ch, CURLOPT_SAFE_UPLOAD, true); } else { if (defined('CURLOPT_SAFE_UPLOAD')) { curl_setopt($ch, CURLOPT_SAFE_UPLOAD, false); } } curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); if($type=='post'){ curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $arr); } curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); $output = curl_exec($ch); if($res=='json'){ if( curl_errno($ch) ){ //请求失败 return curl_error($ch); curl_close($ch); }else{ //请求成功 curl_close($ch); return $output; } } } //获取对应文件内容(accesstoken、ticket) private function get_php_file($filename) { return trim(substr(file_get_contents($filename), 15)); } //设置对应文件内容(accesstoken、ticket) private function set_php_file($filename, $content) { $fp = fopen($filename, "w"); fwrite($fp, "<?php exit();?>" . $content); fclose($fp); } } ``` 有没有大佬告诉下,到底是怎么回事啊?我的接口权限、js安全域名都是OK的,方便的话可以加我QQ指点下我825114245
按照微信提供的JSSDK接口 拉取用户卡券列表 失败 求助
根据微信提供的开发文档按照如下步骤实现却无法正常拉取卡券列表(python版本是3.7.1): ###第一步: 使用access_token请求https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=ACCESS_TOKEN&type=wx_card地址获取card的api_ticket ###第二步: 本地生成一个15位的随机数,再将当前时间转换为自1970年1月1日00:00:00至今的秒数,然后将api_ticket,appid,时间戳,随机数,cardtype(‘GENERAL_COUPON’),的值列表进行sort调用,然后使用sha1进行加密生成cardSign ###第三步: 将第二部生成的随机数,cardSign,时间戳,传入到H5页面中,在H5页面中作为chooseCard接口的参数调用 按照上面三个步骤后没有按照预期出现卡券的列表。麻烦大神们协助看下。非常感谢!!
通过jssdk调用扫一扫接口,扫码微信生成的带参数二维码,怎么获取二维码的参数?
想实现使用微信的扫一扫,扫带参数的二维码,会跳转到公众号内,获取参数后推送消息。使用jssdk的扫一扫,扫带参数二维码,获取二维码的参数直接跳转对应的页面。 服务器设置已经配置过,通过微信扫一扫,是可以监听到。jssdk 怎么监听?
java微信公众号 js调用微信支付报错 errMsg:chooseWXPay:fail
奖励有点少,实在是没有c币了。 下面是我的js,不清楚到底是什么原因导致的,各位大神帮忙给解决下吧;具体报错:config签名啥的是OK的,但是在调用chooseWXPay的时候,就失败了 报错errMsg:chooseWXPay:fail 没有别的提示信息,不清楚失败原因 $('#pay_sub_btn').on(touchType, function(){ var _this = $(this); var payType = $('#pay_type').val(); var orderId = $('#J_payOrder_id').val(); var orderSn = $('#J_payOrder_sn').val(); var payFee = $('#J_payOrder_card_no').val(); var fieldLabel = $('#fieldLabel').val(); var date = $('#date').val(); var orderTimes = $('#orderTimes').val(); var gymName = $('#gymName').val(); var path = $('#basePath').val(); hideError(); lock = true; _this.text('支付中...'); if(payType == 13){ //支付宝支付 }else{ $.ajax({ url:path+"/orders/OrdersPayForWx.do?orderId="+orderId }).done(function(data){ var obj = eval('(' + data + ')'); if(parseInt(obj.agent)<5 && obj.agent != "false"){ alert("您的微信版本低于5.0无法使用微信支付,请升级之后再操作!~"); return; }else if(obj.agent == "false"){ alert("请使用微信浏览器操作!~"); return; } if(obj.code == "0"){ alert("登陆已经过期,请重新登录!~"); window.location.href = path+'/login.jsp'; } wx.config({ debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId: obj.appId, // 必填,公众号的唯一标识 timestamp: obj.contime, // 必填,生成签名的时间戳 nonceStr: obj.constr, // 必填,生成签名的随机串 signature: obj.consign,// 必填,签名,见附录1 jsApiList: ['chooseWXPay'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ wx.chooseWXPay({ "timestamp": obj.paytime, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符 "nonceStr": obj.paystr, // 支付签名随机串,不长于 32 位 "package": obj.paypack, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***) "signType": obj.paysigntype, // 签名方式,默认为'SHA1',使用新版支付需传入'MD5' "paySign": obj.paysign, // 支付签名 success: function (res) { // 支付成功后的回调函数 alert(res.err_msg); _this.text('支付'); if(res.err_msg == "get_brand_wcpay_request:ok" ) { _this.text('支付'); // 使用以上方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回 ok,但并不保证它绝对可靠。 window.location.href = path + '/orders/GetOrders.do?page=1&pageSize=10&orderStatus=0'; }else{ alert(res.errMsg); alert(res.err_msg); _this.text('支付'); return false; } } }); }); wx.error(function(res){ alert(res.err_msg); _this.text('支付'); return false; }); }); } });
加载微信的jssdk后,通过文档提供的wx对象调用,提示wx为undefined
``` <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <script src="//cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script> <script type="text/jscript" href="https://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> <style> body{width:100%; min-height:100%;} body img{width:100%;} </style> <title>关注分享送红包</title> </head> <body> <p id="test">ttttttttttt</p> <script> wx.config({ debug: true, appId: '<?php echo $signPackage["appId"];?>', timestamp: <?php echo $signPackage["timestamp"];?>, nonceStr: '<?php echo $signPackage["nonceStr"];?>', signature: '<?php echo $signPackage["signature"];?>', jsApiList: [ // 所有要调用的 API 都要加到这个列表中 'checkJsApi', 'openLocation', 'getLocation', 'onMenuShareTimeline', 'onMenuShareAppMessage' ] }); wx.ready(function(){ alert('成功'); }) wx.error(function(res){ // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的 debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。 $('#test').html(res); }); $('#test').html("bbbbbbbb"); </script> ```
问:微信js sdk接口调用必须事件触发吗?我想在一个循环里多次调用录音和停止接口功能怎么做?
看jssdk demo里都写到按钮onclick里了。要实现点击一个按钮先执行录音接口功能,10秒后停止录音,然后再进行语音识别。js代码该怎么写呢?
asp.net调用微信端的JS-SDK接口,但是权限签名一直出错,步骤也没错跟微信文档的一样,急急急
/// <summary> /// 获得accesstoken /// </summary> /// <returns></returns> public static string AccessToken() { return SendRequest("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appid + "&secret=" + secret, Encoding.UTF8); } /// <summary> /// 根据accesstoken获得ticket /// </summary> /// <returns></returns> public static string GetTicket() { string access_token = AccessToken(); string url1 = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=" + access_token.Substring(access_token.IndexOf(':') + 2, access_token.IndexOf(',') - 3 - access_token.IndexOf(':')) + "&type=jsapi"; string requstStr = SendRequest(url1, Encoding.UTF8); string ticket = requstStr.Substring(requstStr.IndexOf("ticket") + 9, requstStr.LastIndexOf(',') - 1 - requstStr.IndexOf("ticket") - 9);// 获得json参数没搞懂的自己优化 return ticket; } /// <summary> /// 获取jssdk所需签名 /// </summary> /// <param name="url"></param> /// <returns></returns> public static string GetSignature(string link) { DateTime dti = DateTime.Now; dtime = dti.ToString("yyyy-MM-dd HH:mm:ss"); string noncestr = dti.ToString("yyyyMMddHHmmss"); int timestamp = 1510124527; string ticket = GetTicket(); time = "1510124527"; randstr = noncestr; string string1 = "jsapi_ticket=" + ticket + "&noncestr=" + noncestr + "&timestamp=" + timestamp + "&url=" + link; url = string1; string signature = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(string1, "SHA1"); return signature.ToLower(); // 生成后一定转换为小写 } /// <summary> /// Get方式获取url地址输出内容 /// </summary> /// <param name="url">url</param> /// <param name="encoding">返回内容编码方式,例如:Encoding.UTF8</param> public static string SendRequest(string url, Encoding encoding) { HttpWebRequest webRequest = (HttpWebRequest)WebRequest.Create(url); webRequest.Method = "GET"; HttpWebResponse webResponse = (HttpWebResponse)webRequest.GetResponse(); StreamReader sr = new StreamReader(webResponse.GetResponseStream(), encoding); string str = sr.ReadToEnd(); return str; } /// <summary> /// 将值记录到数据库中防止出现调用限制 /// </summary> /// <param name="url"></param> public static void SignatureAdd(string link) { time = ""; randstr = ""; signstr = ""; signstr = GetSignature(link); string sqlI = "insert into wxinfo(timestr,nonceStr,signature,timeS,url,link) values('" + time + "','" + randstr + "','" + signstr + "','" + dtime + "','" + url + "','" + link + "') "; int count = DbHelper.ExecuteCommand(sqlI); } /// <summary> /// 获得微信权限信息,格式:时间戳,随机数,签名 /// </summary> /// <param name="link"></param> /// <returns></returns> public static string GetWXInfo(string link) { bool result = false; // 获得最后一条新增数据 string sql = " select * from wxinfo where link='" + link + "' order by wxinfo_id desc"; DataTable dt = DbHelper.GetDataSet(sql); if (dt != null) { if (dt.Rows.Count > 0) { // 当前时间小于获得获得tincket时间时调用数据库中 if (DateTime.Now < Convert.ToDateTime(dt.Rows[0]["timeS"].ToString()).AddSeconds(7200)) { time = dt.Rows[0]["timestr"].ToString(); randstr = dt.Rows[0]["nonceStr"].ToString(); signstr = dt.Rows[0]["signature"].ToString(); url = dt.Rows[0]["url"].ToString(); result = true; } } } if (result == false) { SignatureAdd(link); } return time + "," + randstr + "," + signstr; } }
手机测试 wx.config 无反应,愿意发微信红包, 求大佬帮忙分析解决
我在微信开发工具测试, wx.config 显示ok , wx.chooseWXPay.没有此SDK或暂不支持此SDK模拟 **问题出在, 我用手机测试 (ios,android) wx.config无反应,** erro和ready均不进入 wx.chooseWXPay也无法用, 我在https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign 验证了签名是一毛一样的, 求教大佬, 我这代码是出了啥毛病 ``` <!doctype html> <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <html lang="zh-cn"> <head> <%@include file="/pc/inc/commoncontent.inc"%> <script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script> <script src="<%=contextPath%>/m/smartHotel/script/jquery.min.js" type="text/javascript"></script> <script type="text/javascript"> </script> <title>订单-支付</title> <span class="disb picNum padTB30"><i class="disib iconPic" onClick="openPic(this);" >3532rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr张</i></span> </head> <body> <script type="text/javascript"> var appId1,timeStamp1,nonceStr1,packageStr1,signType1,paySign1; $(document).ready(function () { $.ajax({ url : contextPath+ "/weixin/hotelorder/wxPay.action", type:"post", dataType:'json', //接受数据格式 async: false, data:{url:window.location.href.split('#')[0].replace(/\&/g,"%26")},//传参,建议使用json //1:手机号, 2:房间数.3单价4总价 5: 当前bedid 6 :入住人 姓名 7 发票8 入住日离开日 error:function(data){//请求失败时处理 // alert(data); window.location.href = '<%=contextPath%>/m/smartHotel/html/yysb.html'/*预订失败页*/ }, success:function(data) { if( data) { appId1 = data.pay.appId; timeStamp1 = data.pay.timeStamp; nonceStr1 = data.pay.nonceStr; packageStr1 = data.pay.package; signType1 = data.pay.signType; paySign1 = data.pay.paySign; } wx.config({ debug:false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:data.pay.appId, // 必填,公众号的唯一标识 timestamp:data.config.timestamp, // 必填,生成签名的时间戳 nonceStr:data.config.noncestr, // 必填,生成签名的随机串 signature:data.config.configSign, // 必填,签名,见附录1 jsApiList:['chooseWXPay','closeWindow'] }); wx.error(function(res){ alert("error enter"); }); wx.ready(function(){ alert("ready enter"); pay(); }); //onBridgeReady(); // alert("success inter"); } }); }); function pay() { // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。 console.log(appId1 +" / "+ timeStamp1+" / " + nonceStr1+" / "+packageStr1 +" / "+ signType1+" / "+paySign1); wx.chooseWXPay({ timestamp:timeStamp1, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符 nonceStr:nonceStr1, // 支付签名随机串,不长于 32 位 package:packageStr1, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***) signType:signType1, // 签名方式,默认为'SHA1',使用新版支付需传入'MD5' paySign:paySign1, // 支付签名 success:function(res) { alert("8888888888888"); alert(res); alert(res.errMsg); console.log(res.errMsg); // 支付成功后的回调函数 if (res.errMsg == "chooseWXPay:ok") { //支付成功 alert('支付成功'); } else { alert(res.errMsg); } } }); } function onBridgeReady(){ alert("进入了onbridgeready"); WeixinJSBridge.log("889"); WeixinJSBridge.invoke( 'getBrandWCPayRequest', { "appId":appId1, //公众号名称,由商户传入 "timeStamp":timeStamp1, //时间戳,自1970年以来的秒数 "nonceStr":nonceStr1, //随机串 "package":packageStr1, "signType":"MD5", //微信签名方式: "paySign":paySign1 //微信签名 }, function(res){ WeixinJSBridge.log(res); alert("进入了success"); alert(res.errorMsg); // 使用以下方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回 ok,但并不保证它绝对可靠。 if(res.errMsg == "get_brand_wcpay_request:ok") { alert("支付成功"); // window.location.href = "${pageContext.request.contextPath}/wx/success?orderId=${orderId}"; }else if(res.errMsg == "get_brand_wcpay_request:fail"){ alert('支付失败'); }else if(res.errMsg == "get_brand_wcpay_request:cancel"){ alert('支付取消'); }else{ alert(res.errMsg); } } ); } function openPic() { pay(); //wx.closeWindow(); } //调用模拟 回调 // $.ajax({ // url : contextPath+ "/weixin/hotelorder/moniWXPay.action", // type:"post", // dataType:'json', //接受数据格式 // async: false, // data:{parm1:getQueryString2("orderId")},//传参,建议使用json // error:function(data){//请求失败时处理 // alert(data); // }, // success:function(data) // { // if(data.result =="success") // { // window.location.href = '<%=contextPath%>/m/smartHotel/html/yycg.jsp?orderId='+getQueryString2("orderId"); // } // // } // }); function getQueryString2(name) { var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i"); var r = window.location.search.substr(1).match(reg); if(r != null) return decodeURI(r[2]); return null; } </script> </body> </html> ```
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
花了20分钟,给女朋友们写了一个web版群聊程序
参考博客 [1]https://www.byteslounge.com/tutorials/java-ee-html5-websocket-example
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
这30个CSS选择器,你必须熟记(上)
关注前端达人,与你共同进步CSS的魅力就是让我们前端工程师像设计师一样进行网页的设计,我们能轻而易举的改变颜色、布局、制作出漂亮的影音效果等等,我们只需要改几行代码,不需...
国产开源API网关项目进入Apache孵化器:APISIX
点击蓝色“程序猿DD”关注我回复“资源”获取独家整理的学习资料!近日,又有一个开源项目加入了这个Java开源界大名鼎鼎的Apache基金会,开始进行孵化器。项目名称:AP...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
编写Spring MVC控制器的14个技巧
本期目录 1.使用@Controller构造型 2.实现控制器接口 3.扩展AbstractController类 4.为处理程序方法指定URL映射 5.为处理程序方法指定HTTP请求方法 6.将请求参数映射到处理程序方法 7.返回模型和视图 8.将对象放入模型 9.处理程序方法中的重定向 10.处理表格提交和表格验证 11.处理文件上传 12.在控制器中自动装配业务类 ...
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
求小姐姐抠图竟遭白眼?痛定思痛,我决定用 Python 自力更生!
点击蓝色“Python空间”关注我丫加个“星标”,每天一起快乐的学习大家好,我是 Rocky0429,一个刚恰完午饭,正在用刷网页浪费生命的蒟蒻...一堆堆无聊八卦信息的网页内容慢慢使我的双眼模糊,一个哈欠打出了三斤老泪,就在此时我看到了一张图片:是谁!是谁把我女朋友的照片放出来的!awsl!太好看了叭...等等,那个背景上的一堆鬼画符是什么鬼?!真是看不下去!叔叔婶婶能忍,隔壁老王的三姨妈的四表...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
相关热词 如何提升c#开发能力 矩阵乘法c# c#调用谷歌浏览器 c# 去空格去转义符 c#用户登录窗体代码 c# 流 c# linux 可视化 c# mvc 返回图片 c# 像素空间 c# 日期 最后一天
立即提问