模拟支付页面跳转通知的实例详解
这篇文章主要为大家详细介绍了如何使用SignalR发送页面跳转通知的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
微信商城使用支付宝支付的时候,需要有个过度页面提示用户用浏览器打开页面去支付,等用户在浏览器支付完之后再打开微信(微信此时依旧显示的是过度页面),过度页面需要跳转到订单详情页面。那么这个过度页面怎么知道需要跳转呢?
目前能想到的就是用SigbalR发送通知告诉那个过度页面去跳转.
第一步,先添加SigbalR相关dll.
第二步,自定义hub
public class myHub:Hub { public override Task OnConnected() { return base.OnConnected(); } }
第三步,自定义UserIdProvider,因为我们需要给指定用户发送跳转的通知
public class CustomerUserIdProvider: IUserIdProvider { public string GetUserId(IRequest request) { //获取当前登录用户 var customer = EngineContext.Current.Resolve<IWorkContext>().CurrentCustomer; if(customer==null) { return ""; }else { //返回当前登录用户id return customer.Id.ToString(); } } }
第四步,在startup里注册我们自定义的UserIdProvider
//SignlR var idProvider = new CustomerUserIdProvider(); GlobalHost.DependencyResolver.Register(typeof(IUserIdProvider), () => idProvider); app.MapSignalR();
第五步,在支付宝支付完成异步通知加上这行代码发送通知,并且传入订单单号参数,这里给order customerid的用户发送通知,order customerid和当前登录者的id是一样的。所以能接收到信息。
var myHub = GlobalHost.ConnectionManager.GetHubContext<myHub>(); myHub.Clients.User(order.OrderCustomerId.ToString()).redirctOrderDetails(order.OrderNumber);
第六步,在在过度页面接受执行
// 声明一个代理引用该集线器,记得$.connection.后面的方法首字母必须要小写,这也是我为什么使用别名的原因 var chat = $.connection.chinookHub; // 这里是注册集线器调用的方法,和1.0不同的是需要chat.client后注册,1.0则不需要 chat.client.redirctOrderDetails = function (oerderNumber) { window.location.href = "/Customer/MyOrderDetails?page=4&orderNumber=" + oerderNumber; }; chat.client.redirctMoneyAccountDetail = function () { window.location.href = "/Customer/AccountDetail/Money"; }; // 启动连接 $.connection.hub.start();
这样,就可以完美的实现支付完成后跳转页面了。目前没想到更好的办法了。
【相关推荐】
2. ASP.NET教程
以上是模拟支付页面跳转通知的实例详解的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

PHP页面跳转函数详解:header、location、redirect等函数的页面跳转技巧,需要具体代码示例引言:在开发Web网站或应用时,页面之间的跳转是一个必不可少的功能。PHP提供了多种方式来实现页面跳转,其中包括header函数、location函数以及一些第三方库提供的跳转函数,如redirect。本文将详细介绍这些函数的使用方

标题:使用uniapp实现页面跳转动画效果近年来,移动应用的用户界面设计已经成为吸引用户的重要因素之一。页面跳转动画效果在提升用户体验和可视化效果方面起着重要的作用。本文将介绍如何使用uniapp实现页面跳转动画效果,并提供具体的代码示例。uniapp是一个基于Vue.js开发的跨平台应用开发框架,可以通过一套代码编译生成小程序、H5、App等多个平台的应用

标题:PHP代码示例:使用POST方式传参并实现页面跳转的方法在Web开发中,经常会涉及到如何通过POST方式传递参数,并在服务器端进行处理后实现页面跳转的需求。PHP作为一种流行的服务器端脚本语言,提供了丰富的函数和语法来实现这一目的。下面将通过一个实际的示例来介绍如何使用PHP来实现这一功能。首先,我们需要准备两个页面,一个用来接收POST请求并处理参数

如何在Vue中使用路由实现页面跳转?随着前端开发技术的不断发展,Vue.js已经成为了目前最热门的前端框架之一。而在Vue开发中,实现页面跳转是必不可少的一部分。Vue提供了VueRouter来管理应用的路由,通过路由可以实现页面之间的无缝切换。本文将介绍如何在Vue中使用路由实现页面跳转,并附有代码示例。首先,在Vue项目中安装vue-router插件。

微信小程序实现页面跳转动画效果在微信小程序中,页面跳转是一项非常常见的功能。为了提升用户体验,我们可以通过添加动画效果来让页面切换更加流畅和生动。下面我将介绍如何使用微信小程序的API来实现页面跳转动画效果,并附上具体的代码示例。首先,我们需要了解微信小程序中页面的生命周期函数。在页面即将被展示时,可以通过监听页面的onShow生命周期函数来实现页面跳转动画

UniApp是一款跨平台开发框架,可以用于快速开发小程序、App、H5等多端应用。但是在使用UniApp开发过程中,我们也会遇到一些问题,其中一个常见问题就是报错信息“无法找到'xxx'页面跳转”。那么,我们该如何解决这个问题呢?首先,我们需要明确什么造成了这个问题。这个问题一般是由于页面的路径设置错误导致的。在UniApp中,我们通常使用路由(router

uniapp中如何实现页面跳转和导航uniapp是一款支持一次编码多端发布的前端框架,它基于Vue.js,开发者可以使用uniapp快速开发移动端应用。在uniapp中,实现页面跳转和导航是非常常见的需求。本文将介绍uniapp中如何实现页面跳转和导航,并提供具体的代码示例。一、页面跳转使用uniapp提供的方法进行页面跳转uniapp提供了一组方法用于实现

使用Golang实现页面跳转的最佳实践在开发web应用程序时,页面跳转是一个常见的功能需求。在Golang中,我们可以使用一些库来实现页面跳转,例如使用Gin框架来处理路由和页面跳转。本文将介绍如何在Golang中实现页面跳转的最佳实践,同时给出具体的代码示例。Gin框架简介Gin是一个用Go语言编写的web框架,功能强大且易
