iOS
In this topic, you'll learn how to integrate the bank SDK into an iOS client so that you can payment cashier pages in a mobile application.
Before integrating the SDK, ensure that you have completed the following tasks:
- Install Xcode 12 or a higher version.
- Use iOS 11 or a higher version.
Integrate the SDK by following these steps:
Import the SDK package
After you download the SDK package in Alipay Developer Center, add AMSComponent.framework and AlipayWebView.framework to your project, add AlipayWebView.framework/IWebContainer.bundle and AMSComponent.framework/AMSComponent.bundle, and go to Build Settings > Linking > Other Linker Flags to add -ObjC.
 
                         
                        Display available payment methods
After you have obtained available payment methods by contacting Alipay Technical Support, you can display the payment methods in the following modes:
- Single bank mode: Display the payment methods by bank.
- Bank type mode: Display the payment method by bank type, such as mobile banking app, online banking, and bank transfer.
- Bank country mode: Desplay the payment methods by bank country, such as Thailand and Indonesia.
Note: In the bank type mode, payment methods cannot be displayed under the mobile banking app type on web clients.
 
                        Create an SDK instance by using the AMSComponentCheckout()method:
- Create an instance for cashier pages. The instance contains the following parameter:	- configuration: A required object belonging to the AMSConfiguration type. The object must contain all configuration parameters.
 
- Create the AMSConfigurationclass, which must contain the following parameters:- locale: An optional string belonging to the NSString type, which is used by the merchant client to identify the language of the buyer's browser. Specify this parameter to ensure that the SDK displays pages in the correct language. The valid values are as follows. If any other values are passed, English will be used as the default language.		- en_US: English
- in_ID: Indonesian
- th_TH: Thai
 
- options: An optional parameter belonging to the NSDictionary type. It is used to specify whether to use the default loading pattern and the sandbox environment. Valid values are:		- "sandbox", "true": Sandbox environment
- "sandbox", "false": Production enviroment
- "showLoading", "true": Use the default loading pattern.
- "showLoading", "false": Do not use the default loading pattern.
 
 
- locale: An optional string belonging to the NSString type, which is used by the merchant client to identify the language of the buyer's browser. Specify this parameter to ensure that the SDK displays pages in the correct language. The valid values are as follows. If any other values are passed, English will be used as the default language.		
- Create an instance of the AMSLoggerProtocol interface, which is used to manage log output. It contains the following method:	- logWithName(): Optional. It is a callback function that is used to output logs by default.
 
- 
After the user selects the payment method and your client detects the payment button click event, your server sends a createPaymentSession request. Get the paymentSesssionData value from the createPaymentSession response and use it in Step 5.
Pass the following parameters in your createPaymentSession request:
- 	paymentRequestId: The unique ID assigned by a merchant to identify a payment request. 
- 	productCode: Represents the payment product that is being used. The value is fixed as AGREEMENT_PAYMENT.
- 	paymentNotifyUrl: The URL that is used to receive the payment result notification. 
- paymentRedirectUrl: The merchant page URL that the user is redirected to after the payment is completed.
- paymentAmount: The payment amount that the merchant requests to receive in the order currency.
- order.orderAmount: The order amount on the merchant's part. During sales promotion, the orderAmount value may differ from the paymentAmount value.
- order.orderDescription: The order description.
- order.referenceOrderId: The order ID on the merchant's side. Alipay suggests using one referenceOrderId for multiple paymentRequestIds when there are multiple payment requests for a single order.
- paymentMethod.paymentMethodType: Specify it as BANK.
- paymentMethod.paymentMethodMetaData:	- To display payment methods in the single bank mode, specify bankName as a bank name.
- To display payment methods in the bank type mode, specify paymentMethodCaregory as a payment method type. Valid values are BANK_TRANSFER,MOBILE_BANKING_APP, andONLINE_BANKING.
- To display payment methods in the bank country mode, specify paymentMethodRegion as a country. Valid values are THandID.
 
Render the payment pages
Use the createComponent method in the configuration object.
- Create a configuration object by using the paymentSessionData parameter: Pass the paymentSessionData value obtained in Step 4 to the paymentSessionData parameter of the createComponentmethod.
- Call the createComponentmethod to initialize the SDK.
Obtain a payment result
When the payment reaches a final status of success or failure, Alipay sends an asynchronous notification through the notifyPayment API to paymentNotifyUrl that you pass through the createPaymentSession API. When you receive the notification from Alipay, you must return a response as instructed in Requirements. You can also obtain the payment result by calling the inquiryPayment API.
The SDK provides the following status codes:
- 	SDK_START_OF_LOADING: The loading animation starts to play during the payment component creation.
- 	SDK_END_OF_LOADING: The loading animation ends during the payment component creation.
The SDK provides the following error codes:
- 	SDK_INTERNAL_ERROR: The internal error of the SDK occurs. Contact Alipay Technical Support to resolve the issue.
- 	SDK_CREATEPAYMENT_PARAMETER_ERROR: The parameters passed into theAMSCheckoutmethod are incorrect. Ensure the parameters are passed correctly and send a new request.
- 	SDK_CALL_URL_ERROR: The payment method client failed to be revoked. Contact Alipay Technical Support to resolve the issue.
- 	SDK_INTEGRATION_ERROR: Dependencies are not found. Ensure that the dependencies are added correctly and retry the integration process.