程序ajax请求公共组件app-jquery-http.js中url参数部分的项目应用
结合微信登录以及微信支付的案例:= =||| (案例比较奇葩复杂)
简述项目流程:
1.获取用于公众号支付的openid(公众平台):在微信内置浏览器中打开网页链接,刚进入页面就通过微信公众平台获取该微信用户的code,拿到code传给后台,换取用户的openid。
2.微信登录(开放平台):微信登录通过微信开放平台,由于第一步公众平台拿到的code会混淆开放平台的code,导致用户使用微信登录失败,就需要使用该插件将url参数重置。
3.微信支付(公众平台):像后台传输步骤一获取的openid,以及其他参数,完成微信公众号支付。
代码如下:
1.获取用于公众号支付的openid:
$(function() { function isWeiXin() { //判断是否为微信环境
var ua = window.navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i) == 'micromessenger') {
return true;
} else {
return false;
}
}
if(isWeiXin()) { //只在微信环境中获取openid,普通的浏览器也获取不到啊!
var openid = $.cookie("geekbar_weixinid"); // Jquery-cookie插件用于存储获取到的openid,一开始这里肯定是null。
if(openid != null && openid != '') {
return;
}
var code = $.HTTP.getUrlParam("code"); //获取当前页面链接中的参数code!一开始这里肯定是null。
if(code == undefined || code == null) {
var sendUrl = location.href; //redirect_uri(授权后重定向的回调链接地址):当前页面。
sendUrl = $.HTTP.setUrlParam(sendUrl,"xz","public"); //给当前页面的url添加一个参数xz=public,提示是公众平台,避免与开放平台搞混淆。
//拼接后的地址(例):www.baidu.com?xz=public,对链接本身没有任何影响。
sendUrl =encodeURIComponent(sendUrl); //处理该地址为格式要求的样式,点击查看微信公众平台文档要求。 //var sendUrl = encodeURIComponent(location.href);
var requrl = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid=appid&redirect_uri=' +
sendUrl + '&response_type=code&scope=snsapi_base&state=wx#wechat_redirect'; location.href = requrl; //刷新后页面链接后便拼接了公众平台获取的code,同时进入else
return; } else { $.ajax({
url: '../common/user/wx/getopenid?code=' + code, //将公众平台code传给后台,获取用于公众号支付的openid
success: function(data) {
$.cookie("geekbar_weixinopenid", data.data, { //成功后将openid(代码中的data.data)存入缓存中去。使用jquery-cookie插件。
expires: 1
});
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
var info = "XMLHttpRequest:" + JSON.stringify(XMLHttpRequest) +
" ;textStatus:" + textStatus + "; errorThrown:" +
JSON.stringify(errorThrown) + "; 【" + opt.url + "】";
alert(info);
if(opt.error != undefined)
opt.error(XMLHttpRequest, textStatus, errorThrown);
else {
console.error("请求错误", "系统发生请求错误,请联系管理员解决。");
}
}
}); } } else {
console.log("当前环境不是微信环境")
} });
2.微信登录(开放平台)
$("#wchartLogin").on("click", function() { var sendUrl = location.href; //受到步骤一的影响,页面链接后拼接的是公众平台获取的code,xz参数。即xxxx.jsp?code=publiccode&xz=public&state=wx
sendUrl = $.HTTP.setUrlParam(sendUrl, "xz", "open"); //重置xz参数:xxxx.jsp?code=publiccode&xz=open&sate=wx
sendUrl = $.HTTP.deleteUrlParam(sendUrl, "code"); //删除公众平台code参数:xxxx.jsp?xz=open&state=wx (最为重要,是混淆开放平台code的元凶!)
sendUrl = $.HTTP.deleteUrlParam(sendUrl, "state"); //删除state参数:xxxx.jsp?xz=open
sendUrl = $.HTTP.setUrlParam(sendUrl, "ls", "wx"); //增添ls参数:xxxx.jsp?xz=open&ls=wx (后台设置的,没有此参数不行)
sendUrl = encodeURIComponent(sendUrl); //处理成redirect_uri的标准格式。
requrl = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid=appid&redirect_uri=' + sendUrl + '&response_type=code&scope=snsapi_login&state=wx#wechat_redirect';
location.href = requrl; //就可以成功登录了!
return;
});
3.微信支付(公众平台):
<input type="radio" value="WeiXinPub" name="payType" checked="checked">
<script>
$(function(){
$("#payFBtn").on("click",function(){
var payType=$("#payChooseList input[name=payType]:checked").val();
if(payType==undefined||payType==null||payType==''){
alert("请选择支付类型!");
return;
}
pay('{{orderNo}}',payType);
}) })
</script>
function pay(orderNo, payChannel) {
$.HTTP.obj({
url: "../rest/order/pay",
ajaxData: {
orderNo: orderNo,
payChannel: payChannel,
wxOpenId: $.cookie("geekbar_weixinid"), //将获取到的公众平台的openid传给后台。只有有用户openid才能支付。
success_url: encodeURI(location.href)
},
success: function(data) { if(data) {
switch(payChannel) { case "AlipayWap": var pos = JSON.stringify(data);
pingpp.createPayment(pos, function(result, err) {
alert(result);
alert(err.msg);
alert(err.extra);
if(result == "success") { } else if(result == "cancel") { }
});
break; case "WeiXinPub":
var pos = JSON.stringify(data); pingpp.createPayment(pos, function(result, err) {
/*alert(result);
alert(err.msg);
alert(err.extra);*/
if(result == "success") {
//alert(result);
} else if(result == "fail") {
alert(err.msg);
// charge 不正确或者微信公众账号支付失败时会在此处返回
} else if(result == "cancel") {
// 微信公众账号支付取消支付
result = '您已取消支付';
alert(result);
}
});
break; } } else {
alert("支付异常");
} }
})
}
程序ajax请求公共组件app-jquery-http.js中url参数部分的项目应用的更多相关文章
- 程序ajax请求公共组件-- app-jquery-http.js
$.HTTP = { getUrlParam : function (name) { var reg = new RegExp ("(^|&)" + name + &quo ...
- 程序ajax请求公共组件:app-jquery-http.js
// --------网络操作-------------------- $.HTTP = { getUrlParam : function(name) { var reg = new RegExp(& ...
- jquery或js 获取url参数
<script type="text/javascript"> function getUrlParam(name) { var reg = new RegExp(&q ...
- jquery截取地址栏中url参数的值
<script> /*http://127.0.0.9/index.php?s=/Home/Index/fangguan_shuju&zc=2*/ function getQuer ...
- Ajax请求(二)--JQuery的Ajax请求方法
JQuery库的Ajax请求的几种方法: 1. load( url, [data], [callback] ) :载入远程 HTML 文件代码并插入至 DOM 中. 参数含义: url (String ...
- 2.jquery在js中写标准的ajax请求
$(function(){ $.ajax({ url:"http://www.microsoft.com", //请求的url地址 dataType:"json" ...
- 文件上传时jquery.form.js中提示form.submit SCRIPT5: 拒绝访问
利用其它控件触发file的click事件来选择文件后,使用jquery.form.js中的submit方法提交时IE报错:form.submit SCRIPT5: 拒绝访问,其它浏览器正常, < ...
- jquery.fileupload-image-editor.js 中actions.resizeImage
https://github.com/ChuckForkJS/jQuery-File-Upload/blob/master/js/jquery.fileupload-image-editor.js a ...
- 详解Ajax请求(三)——jQuery对Ajax的实现及serialize()函数对于表单域控件参数提交的使用技巧
原生的Ajax对于异步请求的实现并不好用,特别是不同的浏览器对于Ajax的实现并不完全相同,这就意味着你使用原生的Ajax做异步请求要兼顾浏览器的兼容性问题,对于java程序员来讲这是比较头疼的事情, ...
随机推荐
- ibatis resultMap 结果集映射
1.结果集映射 就是将返回的记录,逐个字段映射到java对象上:如果数据库字段与java对象的成员变量名对应的话,则使用resultClas即可 2.实现 结合 ibatis初探这篇文章中提到的pro ...
- cin详解(cin.get()、cin.getline()、cin.clear()、cin.sync())
在C中,输入输出用scanf和printf,在输入数据的同时还需说明数据的类型,如果输入数据较多,那就很麻烦,而C++中也有相似的东西cin和cout,它们来自C++的一个名叫" iostr ...
- Haproxy的安装和配置示例
1.ha proxy简介ha proxy是一个开源的,高性能的,基于tcp第四层和http第七层应用的负载均衡软件优点:可靠性和稳定性非常好 最高可以同时维护40000-50000个 ...
- easyui easyui-filebox 显示中文
<input class="easyui-filebox" name="uploadFile" id="uploadFileid" d ...
- JS定时器的使用--数码时钟
<title>无标题文档</title> <script> function toDou(n){ if(n<10){ return '0'+n; }else{ ...
- android sql Cursor
Cursor 是每行的集合. 使用 moveToFirst() 定位第一行. 你必须知道每一列的名称.你必须知道每一列的数据类型.Cursor 是一个随机的数据源. 所有的数据都是通过下标取得. Cu ...
- Java 8新特性探究(九)跟OOM:Permgen说再见吧
PermGen space简单介绍 元空间(MetaSpace)一种新的内存空间诞生 PermGen 空间的状况 Metaspace 内存分配模型 Metaspace 容量 Metaspace 垃圾回 ...
- HDU 2444 The Accomodation of Students
首先是要构造二分图,然后二分图的最大匹配. 还有没完全证明过我的方法的正确性,但是AC了..... #include<cstdio> #include<cstring> #in ...
- FTP 7.5 自定义扩展功能
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...
- xdebug 安装
如果是这样的话,请参考 http://www.mengyunzhi.com/share/php/107-xdebug.html 进行xdebug的安装.