开发者社区> 行者武松> 正文

Android下集成Paypal支付

简介:
+关注继续查看

近期项目需要研究paypal支付,官网上的指导写的过于复杂,可能是老外的思维和中国人不一样吧。难得是发现下面这篇文章:

http://www.androidhive.info/2015/02/Android-integrating-paypal-using-PHP-MySQL-part-1/

在这篇文章的基础上,查看SDK简化了代码,给出下面这个例子,测试通过。

其实集成paypal还是非常简单的,真正的输入账户、付款都在SDK自带的Activity和service上完成,我们要做的事情,是从自己的Activity跳转过去,跳转的同时带一个Payment参数(即付款明细),Paypal SDK处理完后,会回到你的Activity(此时已经完成支付)。

在上面提到的那篇文章中,流程是这样的:

 

这里服务端通过android端传回的paymentID(类似流水号),获取支付明细判断是否为正确单据。但要注意的是此时支付已经完成,在实际应用中(根据官网SDK)的说法,主要是卡流程的下一步,比如物流发货。

 

在编写代码前要准备如下:

1、在https://developer.paypal.com中注册一个开发账号(通常是卖家),这个账号提供一个客户ID和密码,需要写在代码里,买家实际上是支付到客户ID和密码生成的账户;

2、在上面这个页面下,Paypal提供了沙盒功能,通过沙盒你可以虚拟一个买家账号,供测试所用;

3、新建一个Android工程,在里面整合android paypal的SDK;

备注:根据我实际的操作,eclipse没法导入该jar包,会一直提示没有定义的类,可能是因为SDK是由Gradle构建的原因。在stackoverflow上说用android studio不会出现类似问题,我本地是用的IDEA,也一样OK。

 

下面把主要代码附带如下,之前要注意在manifest中增加权限和SDK中涉及的Activity和Service。

复制代码
public class MyActivity extends Activity {

    private static final String TAG = "MainActivity";
    private Button button;

    private static final int REQUEST_CODE_PAYMENT = 1;
    private static PayPalConfiguration paypalConfig = new PayPalConfiguration()
            .environment(PayPalConfiguration.ENVIRONMENT_SANDBOX)
            .clientId(Config.PAYPAL_CLIENT_ID);
    private List<PayPalItem> productsInCart = new ArrayList<PayPalItem>();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        button = (Button) findViewById(R.id.button);
        button.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                addToCart(new Product("1", "sinny", "fredric_sinny", null, new BigDecimal(1), "1232131"));

                PayPalPayment thingsToBuy = prepareFinalCart();

                Intent intent = new Intent(MyActivity.this,
                        PaymentActivity.class);

                intent.putExtra(PayPalService.EXTRA_PAYPAL_CONFIGURATION, paypalConfig);

                intent.putExtra(PaymentActivity.EXTRA_PAYMENT, thingsToBuy);

                startActivityForResult(intent, REQUEST_CODE_PAYMENT);
            }
        });

    }

    private PayPalPayment prepareFinalCart() {

        PayPalItem[] items = new PayPalItem[productsInCart.size()];
        items = productsInCart.toArray(items);

        // Total amount
        BigDecimal subtotal = PayPalItem.getItemTotal(items);

        // If you have shipping cost, add it here
        BigDecimal shipping = new BigDecimal("0.0");

        // If you have tax, add it here
        BigDecimal tax = new BigDecimal("0.0");

        PayPalPaymentDetails paymentDetails = new PayPalPaymentDetails(
                shipping, subtotal, tax);

        BigDecimal amount = subtotal.add(shipping).add(tax);

        PayPalPayment payment = new PayPalPayment(
                amount,
                Config.DEFAULT_CURRENCY,
                "Description about transaction. This will be displayed to the user.",
                PayPalPayment.PAYMENT_INTENT_SALE);

        payment.items(items).paymentDetails(paymentDetails);

        payment.custom("This is text that will be associated with the payment that the app can use.");

        return payment;
    }

    public void addToCart(Product product) {
        PayPalItem item = new PayPalItem(product.getName(), 1,
                product.getPrice(), Config.DEFAULT_CURRENCY, product.getSku());

        productsInCart.add(item);

        Toast.makeText(getApplicationContext(),
                item.getName() + " added to cart!", Toast.LENGTH_SHORT).show();
    }

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

        super.onActivityResult(requestCode, resultCode, data);

        PaymentConfirmation confirm = data
                .getParcelableExtra(PaymentActivity.EXTRA_RESULT_CONFIRMATION);

        String paymentId;
        try {
            paymentId = confirm.toJSONObject().getJSONObject("response")
                    .getString("id");

            String payment_client = confirm.getPayment().toJSONObject()
                    .toString();

            Log.e(TAG, "paymentId: " + paymentId + ", payment_json: "
                    + payment_client);
        } catch (JSONException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}
复制代码

其他:

1、后台的接口都是标准的REST的接口,我例子里没有实现,但要注意的是node的SDK包在windows7下是不可用的,好像是里面一个CRC的包不支持,在Linux下没问题。

2、该程序运行后,会跳转到Paypal界面,你可以用沙盒里注册的虚拟买家账号登陆消费,消费完后在paypal网站上可以查到相应记录:

 

https://developer.paypal.com/

paymentwall.com


原文链接:[http://wely.iteye.com/blog/2382628]

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Android 集成 Flutter | 与交互
Android 集成 Flutter | 与交互
251 0
Android 友盟简单快速集成
Android 友盟简单快速集成
156 0
Android推送集成方案总结
刚做完推送集成方案,记录下坑。 这里记录的特性和使用时针对写blog时采用的sdk的,具体使用流程和限制还请参考官方给出的sdk. #### 1、推送规则 小米手机用小米推送; 华为手机用华为推送; 其他手机用友盟推送。
135 0
安卓集成环信
安卓集成环信
76 0
Android 小米推送服务集成
Android 小米推送服务集成
184 0
Android OPPO推送服务集成
Android OPPO推送服务集成
269 0
Android 华为推送服务集成
Android 华为推送服务集成
243 0
Android Studio集成友盟SDK
在企业开发中往往会给开发人员提出很多的开发要求,如做商城APP的时候,产品经理希望统计某个商品的购买量,或者运营的同事要求你统计APP的启动数,新增客户量,有时候开发人员需要监控APP在用户手中的使用情况,这个时候我们就需要集成友盟SDK来帮助我们解决这些问题
70 0
Android 信鸽推送集成
Android 信鸽推送集成
112 0
Android集成Bmob后端云
Android集成Bmob后端云
115 0
Android三步集成阿里热修复——Sophix
Android三步集成阿里热修复——Sophix
539 0
Flutter集成百度语音识别(Android端)实战
Flutter集成百度语音识别(Android端)实战
684 0
Android之表单验证,Validation三方集成。
Android之表单验证,Validation三方集成。
179 0
关于安卓mvvm基础库集成
安卓mvvm基础库集成
63 0
关于安卓集成Bugly热更新后,补丁包合成失败问题
安卓集成Bugly热更新后,补丁包合成失败问题
183 0
+关注
行者武松
杀人者,打虎武松也。
文章
问答
视频
相关电子书
更多
蚂蚁聚宝Android秒级编译——Freeline
立即下载
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
相关镜像