WeChat モールでの支払いに Alipay を使用する場合、ユーザーにブラウザでページを開いて支払いを行い、ユーザーがブラウザで支払いを完了した後に WeChat を開くように促す遷移ページが必要です (WeChat は引き続き表示されます)この時点では遷移ページ)、遷移ページは注文詳細ページにジャンプする必要があります。では、この過剰なページは、ジャンプする必要があることをどのようにして知るのでしょうか?
今考えられるのは、SigbalR を使って遷移ページにジャンプするように通知することです
最初のステップは、まず SigbalR 関連の DLL を追加することです
2 番目のステップはカスタマイズすることです。ハブ
public class myHub:Hub { public override Task OnConnected() { return base.OnConnected(); } }
3 番目のステップ、指定されたユーザーにジャンプ通知を送信する必要があるため、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(); } } }
4 番目のステップ、カスタマイズされた UserIdProvider をstartup
//SignlR var idProvider = new CustomerUserIdProvider(); GlobalHost.DependencyResolver.Register(typeof(IUserIdProvider), () => idProvider); app.MapSignalR();
ステップ 5、Alipay の支払いが非同期で完了した後に通知を送信するコード行を追加し、注文番号パラメーターを渡します。ここでは、customerid を注文したユーザーに通知が送信されます。注文の 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();
このようにして、支払い完了後のページジャンプを完璧に実現できます。現時点ではこれより良い方法が思いつきません。
以上がこの記事の全内容です。皆さんの学習に役立つことを願っています。また、皆さんも PHP 中国語 Web サイトをサポートしていただければ幸いです。
SignalR によるページジャンプ通知の送信に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。