5

是否有任何工作示例可以使用 Android Deep Link 集成 UPI 支付网关。我通过了 NPCI 规范并没有成功实施它。交易未完成。

protected override void OnActivityResult(int requestCode, Result resultCode, Intent data)
    {
        base.OnActivityResult(requestCode, resultCode, data);
        Console.WriteLine("Request Code:" + requestCode);
    }

    private void RunUPI(string MobileNo)
    {
        var UPIUri = Android.Net.Uri.Parse("upi://pay?pa=xxx@xxxx&pn=xxxxxx&mc=null&tid=null&tr=test101&tn=This%20is%20test%20payment&am=10&mam=null&cu=INR&url=null");
        Intent intent = new Intent();
        intent.SetAction(Intent.ActionView);
        intent.SetData(UPIUri);
        var activities = PackageManager.QueryIntentActivities(intent, PackageInfoFlags.MatchDefaultOnly);
        var isIntentSafe = activities.Count > 0;
        if (true == isIntentSafe)
        {
            var chooser = Intent.CreateChooser(intent, "Pay With");
            chooser.SetFlags(ActivityFlags.NewTask);
            // Verify the intent will resolve to at least one activity
            if (chooser.ResolveActivity(PackageManager) != null)
            {
                txnUPIRequestCode = 0;
                StartActivityForResult(chooser, txnUPIRequestCode);
            }
        }
    }
4

2 回答 2

9

您的问题与UPIAndroid 如何管理Activity结果和Intents 无关。

如果调用者(在本例中为您的)正在从正在启动的活动(在本例中为UPI PSP )请求结果,则您不能使用。[资源]Intent.FLAG_ACTIVITY_NEW_TASKActivity

所以一个简单的解决方案是简单地创建Uri并启动Intent没有标志的。在java中看起来像:

private void launchUPI(){
  // look below for a reference to these parameters
  Uri uri = Uri.parse("upi://pay").buildUpon()
    .appendQueryParameter("pa", "xxx@xxxxx")
    .appendQueryParameter("pn", "XYZXYZ")
    .appendQueryParameter("tn", "Pay for in-app purchase")
    .appendQueryParameter("am", "20")
    .appendQueryParameter("cu", "INR")
    .build();

  Intent upiPayIntent = new Intent(Intent.ACTION_VIEW);
  upiPayIntent.setData(uri);

  Intent chooser = Intent.createChooser(upiPayIntent, "Pay with");

  if(null != chooser.resolveActivity(getPackageManager())) {
    Log.d(TAG, "UPI Payment resolved to activity");
    startActivityForResult(chooser, REQ_UPIPAYMENT);
  } else {
    Log.d(TAG, "No activity found to handle UPI Payment");
  }
}

@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  super.onActivityResult(requestCode, resultCode, data);

  if(REQ_UPIPAYMENT == requestCode){
    if(RESULT_OK == resultCode){
      Log.d(TAG, "UPI Payment successfull");
    } else {
      Log.d(TAG, "UPI Payment failed");
    }
  }
}

请求参数而言,以下是我从UPI DeepLinking Specification page获得的简单参考。

  • pa: UPI 收款人的虚拟地址(收款人
  • pn:收款人姓名。可以是商家或商店的名称。
  • tn: 交易记录。交易的简单描述,例如应用内商品的支付、账单支付等。
  • am:十进制格式的交易金额。
  • cu:交易中使用的货币。目前仅支持 INR。

使用上述参数,您可以为PSP应用程序(PayTM 或银行应用程序等应用程序)创建支付请求静态模式。

要在动态模式下创建付款请求,您还需要添加以下内容:

  • tr: 交易参考。您对系统中交易的内部参考。

更新 1

正如评论中提到的 OP,要从PSP应用程序返回响应,例如事务 ID 等,我们可以使用Intent传入的onActivityResult()when RESULT_OK == resultCode

@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  super.onActivityResult(requestCode, resultCode, data);

  if(REQ_UPIPAYMENT == requestCode){
    if(RESULT_OK == resultCode){
      Log.d(TAG, "UPI Payment successfull");
      String transId = data.getStringExtra("response");
    } else {
      Log.d(TAG, "UPI Payment failed");
    }
  }
}
于 2018-03-01T06:08:15.083 回答
0

您可以列出设备上所有 UPI 应用程序,并使用任何应用程序发起交易。

这是您可以用来获取所有 UPI 应用程序的功能。

private fun upiApps(context: Context): MutableList<PaymentUpiOption> {

    val upiOptions = mutableListOf<PaymentUpiOption>()

    // Set Parameters for UPI
    val payUri = Uri.Builder()

    payUri.scheme("upi").authority("pay")
    payUri.appendQueryParameter("pa", "")
    payUri.appendQueryParameter("pn", "")
    payUri.appendQueryParameter("tid", "")
    payUri.appendQueryParameter("mc", "")
    payUri.appendQueryParameter("tr", "")
    payUri.appendQueryParameter("tn", "")
    payUri.appendQueryParameter("am", "")
    payUri.appendQueryParameter("cu", "")

    val paymentIntent = Intent(Intent.ACTION_VIEW)
    paymentIntent.data = payUri.build()

    val appList = context.packageManager.queryIntentActivities(paymentIntent, 0)
    for (i in appList) {
        // this is a custom model class
        val paymentUpiOption = PaymentUpiOption(
            i.loadLabel(context.packageManager).toString(),
            i.activityInfo.packageName,
            i.loadIcon(context.packageManager),
            "upiTxn",
            "UPI"
        )
        upiOptions.add(paymentUpiOption)
    }
    return upiOptions
}
于 2020-08-11T14:18:47.243 回答