模擬支付頁面跳轉通知的實例詳解

Y2J
發布: 2017-05-09 11:03:49
原創
2182 人瀏覽過

這篇文章主要為大家詳細介紹如何使用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();
登入後複製

這樣,就可以完美的實現支付完成後跳轉頁了。目前沒想到更好的辦法了。

【相關推薦】

1. ASP.NET免費影片教學

2. ASP.NET教學

#3. 極客學院ASP.NET影片教學

#

以上是模擬支付頁面跳轉通知的實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!