zoukankan      html  css  js  c++  java
  • Announcing Mobile SDK V2.0

    As you might have read over at our PayPal Forward Blog it’s time to celebrate for PayPal | Developer. One year ago we relaunched our Developer Platform with way clearer documentation, new REST APIs and our CardIO-enhanced Mobile SDK that allows for frictionless payments on Android and iOS.

    Today I want to quickly elaborate on an amazing new feature of our mSDK version 2.0 called Future Payments that allows for great use-cases like subscription payments without requiring the user to re-authorize each payment by logging in again. Great experiences like the ones that you can find when using Uber can be created by using this kind of payment. By authorizing the application once to handle future transaction the user grants the application a revokable token that will be passed in all future transactions and therefore skips the login step.

    Implementing this step is actually very easy as our SDK got even easier with version 2. First of all we need to change the configuration of the SDK slightly. In the following examples I will showcase how to do so when working on Android apps – bear in mind that implementing this feature in iOS is equally easy to handle:

      private static PayPalConfiguration config = new PayPalConfiguration()
      .environment(CONFIG_ENVIRONMENT)
      .clientId(CONFIG_CLIENT_ID)
      // The following are only used in PayPalFuturePaymentActivity.
      .merchantName("Innovative cab app")
      .merchantPrivacyPolicyUri(Uri.parse("https://www.example.com/privacy"))
      .merchantUserAgreementUri(Uri.parse("https://www.example.com/legal"));

    If you’ve worked with our SDK prior this version you will see that the configuration got much easier by removing all Intent Extras and adding dedicated methods for initializing the SDK.

    After the user logged in an OAuth 2.0 authorize token is being returned which can be exchanged against a short-lived access token. Furthermore a refresh token is being returned which we will need to acquire a new access token once the previous one becomes invalid.

      Intent intent = new Intent(MyActivity.this, PayPalFuturePaymentActivity.class);
      startActivityForResult(intent, REQUEST_CODE_FUTURE_PAYMENT);
    view rawintent.java hosted with ❤ by GitHub

    By using the startActivityForResult mechanism we receive the PayPalAuthorization in onActivityForResult:

      @Override
      protected void onActivityResult(int requestCode, int resultCode, Intent data) {
      if (requestCode == REQUEST_CODE_FUTURE_PAYMENT) {
      if (resultCode == Activity.RESULT_OK) {
      PayPalAuthorization auth = data
      .getParcelableExtra(PayPalFuturePaymentActivity.EXTRA_RESULT_AUTHORIZATION);
      if (auth != null) {
      String authorization_code = auth.getAuthorizationCode();
      // send authorization code to server to receive the access & refresh code
      }
      }
      }
      }

    The payment is being handled on server-side – to do so we hand over the app’s correlation ID and payment details to the backend. To acquire the correlation ID we leverage a method that we introduced with version 2.0 of the SDK:

      String correlationId = PayPalConfiguration.getApplicationCorrelationId(this);

    It is required that the application provides a way to revoke the token on client-side to ensure a user-friendly experience.

    We are looking forward to bringing even more great features to the SDK and are as always keen for your feedback!

    Best regards,
    Tim

  • 相关阅读:
    Tomcat报错:The valid characters are defined in RFC 7230 and RFC 3986
    MySQL 大数据量表最优分页方法
    Tomcat、Nginx/Openresty 隐藏版本号,使用nginx来统一显示错误页面
    理解领域驱动设计
    Windows+.NetCore+git+IIS在Jenkins上的自动化部署入门
    Oracle 函数wmsys.wm_concat中文乱码解决
    Springboot 在Filter 中通过@Autowired注入Bean,打包war部署为空值解决
    Java线程处理Future
    springboot打包war部署到weblogic,涉及Filter以及Filter中的@Value处理
    解决mybatisplus分页查询不起作用
  • 原文地址:https://www.cnblogs.com/android-blogs/p/6409212.html
Copyright © 2011-2022 走看看