この記事では主に、SignalR を使用してページジャンプ通知を送信する方法に関する関連情報を詳しく紹介します。興味のある友人は参考にしてください。
WeChat モールでの支払いに Alipay を使用する場合は、移行ページでは、ユーザーがブラウザでページを開いて支払いを行うように求められ、ユーザーがブラウザで支払いを完了するまで待ってから WeChat を開きます (この時点でも、WeChat には移行ページが表示されます)。注文詳細ページ。では、この過剰なページは、ジャンプする必要があることをどのようにして知るのでしょうか?
今考えられる唯一のことは、SigbalR を使用して遷移ページにジャンプするよう通知を送信することです
最初のステップ、最初に SigbalR 関連の DLL を追加します
。ハブ
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 をスタートアップに登録します
//SignlR var idProvider = new CustomerUserIdProvider(); GlobalHost.DependencyResolver.Register(typeof(IUserIdProvider), () => idProvider); app.MapSignalR();
5 番目のステップ、Alipay で非同期支払いを完了します。通知を送信するには、このコード行を通知に追加し、注文番号パラメーターを渡します。ここで、注文した顧客 ID は注文したユーザーに送信されます。現在のログインの 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. 3.
Geek Academy ASP.NET のビデオ チュートリアル
以上が模擬決済ページジャンプ通知例を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。