一、前导

上一篇讲的不是非常好,这里再又一次讲一下。

Paypal手机支付有2种形式:

1.Mobile Express Checkout,MEC,快捷支付

2.MPL

假设採用MEC支付方式,这样的方式点击Checkoutbutton之后的页面一直到付款结束都是url的形式,必须先有Web网站的支付,所以仅仅能通过WebView的形式进行记载,使用起来和Web网站效果一样,假设载入的页面中有些内容不想显示,能够隐藏。

二、MEC支付案例

package com.sound.chinabuye.activity;

import http.HttpUrls;

import java.util.List;

import org.apache.http.cookie.Cookie;

import tool.NewTokenCallBack;
import tool.TokenTools;
import tool.UserInfo;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.AlertDialog.Builder;
import android.app.ProgressDialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.util.Log;
import android.view.KeyEvent;
import android.webkit.CookieManager;
import android.webkit.CookieSyncManager;
import android.webkit.JsResult;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Toast; import com.sound.chinabuye.R;
import com.sound.chinabuye.bean.BroadAction; public class CheckoutActivity2 extends Activity {
public static final String TAG = "CheckoutActivity2";
private WebView webView;
private List<Cookie> cookies;
private ProgressDialog dialog; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
manageActivity();
webView = new WebView(this);
webView.setWebViewClient(new MyWebViewClient());
webView.setWebChromeClient(new MyChromeClient());
WebSettings webSettings = webView.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setUseWideViewPort(false);
webSettings.setSupportZoom(false); setContentView(webView);
dialog = new ProgressDialog(this);
dialog.setMessage(getString(R.string.loading));
dialog.setCancelable(false);
// 请求获得cookies
requestData();
} private void requestData() {
TokenTools.requestNewToken(CheckoutActivity2.this, new NewTokenCallBack() { @Override
public void getNewTokenSuccess(String newAccessToken) {
if (newAccessToken != null) {
String customerid = UserInfo.getUserInfoInstance().getUserid();
String url = "http://www.chinabuye.com/service/product/listcartweb" + "?productid=64396&qty=1&customerid=" + customerid + "&ACCESSTOKEN=" + newAccessToken;
webView.loadUrl(url);
}
}
});
} @Override
protected void onDestroy() {
super.onDestroy();
CookieSyncManager.createInstance(CheckoutActivity2.this);
CookieManager cookieManager = CookieManager.getInstance();
cookieManager.removeAllCookie();
CookieSyncManager.getInstance().sync();
} private void setCookiesVia2Url(String fromUrl, String toUrl) {
CookieSyncManager.createInstance(CheckoutActivity2.this);
CookieManager cookieManager = CookieManager.getInstance();
String value = cookieManager.getCookie(fromUrl);
cookieManager.setCookie(toUrl, value);
CookieSyncManager.getInstance().sync();
} private void manageActivity() {
ActivityInstanceManager.getActivityInstanceManager().addActivity(this);
} private class MyWebViewClient extends WebViewClient {
private String currentUrl; @Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
Log.e(TAG, "start:" + url);
currentUrl = url;
// 開始跳转Paypal登录界面
if (url.contains("http://www.chinabuye.com/service/product/listcartweb")) {
dialog.show();
}
// 開始载入Place Order,包括从其它页面返回的情况和開始提交订单的情况
if (url.contains("http://www.chinabuye.com/m/paypal/express/saveOrder") || url.contains("PayerID") || url.contains("http://www.chinabuye.com/m/paypal/express/review")) {
if (dialog.isShowing()) {
dialog.dismiss();
}
dialog.show();
}
// 開始载入 下单成功的界面
if (url.contains("http://www.chinabuye.com/m/checkout/onepage/success")) {
dialog.show();
}
super.onPageStarted(view, url, favicon);
} @Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
Log.e(TAG, "load:" + url);
/** 这里不做不论什么拦截操作 ***/
// view.loadUrl(url);
// return true;
return super.shouldOverrideUrlLoading(view, url);
} @Override
public void onPageFinished(WebView view, String url) {
Log.e(TAG, "finish:" + url);
if (url.contains("customerid")) {
String url2 = "http://www.chinabuye.com/m/checkout/cart";// 这个直接使用Web购物车,測试没问题
String url3 = "http://www.chinabuye.com/paypal/express/shortcut";// 这个直接拦截到登录界面,临时没发现问题
setCookiesVia2Url(url, url3);
view.loadUrl(url3);
}
// paypal登录界面载入完成
if (url.contains("https://www.paypal.com/au/cgi-bin/webscr") && url.contains("#m")) {
dialog.dismiss();
}
// Place Order界面载入完成
if (url.contains("http://www.chinabuye.com/m/paypal/express/review")) {
// 虽然在这之前已经进行了隐藏操作,可是偶尔还是会出现没有隐藏的情况,这里又一次载入一次
hidePlaceOrderJS(view);
dialog.dismiss();
}
// 下单成功的界面载入完成
if (url.contains("http://www.chinabuye.com/m/checkout/onepage/success")) {
// 虽然在这之前已经进行了隐藏操作,可是偶尔还是会出现没有隐藏的情况,这里又一次载入一次
hideSaveOrderJS(view);
dialog.dismiss();
// 发送广播,清空购物车
Intent intent = new Intent();
intent.setAction(BroadAction.EMPTY);
CheckoutActivity2.this.sendBroadcast(intent);
Log.e("sendbroad", "buy.success");
}
// 用户邮箱信息为空
if (url.contains("http://www.chinabuye.com/m/customer/account/edit")) {
Toast.makeText(CheckoutActivity2.this, "Invalid email address NULL", 0).show();
}
super.onPageFinished(view, url);
} // 处理在浏览器中的按键事件
@Override
public boolean shouldOverrideKeyEvent(WebView view, KeyEvent event) {
if (event.equals(KeyEvent.KEYCODE_BACK) && view.canGoBack()) {
view.goBack();
return true;
} else if (event.equals(KeyEvent.KEYCODE_BACK)) {
CheckoutActivity2.this.finish();
return true;
}
return super.shouldOverrideKeyEvent(view, event);
} // 载入页面资源时会调用,比方载入图片时,每载入一张图片会调用一次
@Override
public void onLoadResource(WebView view, String url) {
// Log.e(TAG, "loadResource:" + url);
// Web购物车
if (currentUrl.contains("http://www.chinabuye.com/m/checkout/cart")) {
hideMCartJS(view);
} // Place Order
if (currentUrl.contains("http://www.chinabuye.com/m/paypal/express/review")) {
hidePlaceOrderJS(view);
}
// 下单成功的页面
if (currentUrl.contains("http://www.chinabuye.com/m/checkout/onepage/success")) {
hideSaveOrderJS(view);
}
// 改动地址的时候,最先调用的是该方法,为了体验好,这里先显示对话框
if (url.contains("http://www.chinabuye.com/m/paypal/express/ajaxEditAddress")) {
dialog.show();
}
super.onLoadResource(view, url); }
} // 隐藏M Cart界面的头部和底部
private void hideMCartJS(WebView view) {
view.loadUrl("javascript:window.handler.show(document.getElementById('topheader').style.display='none');");
view.loadUrl("javascript:window.handler.show(document.getElementById('footer').style.display='none');");
} // 隐藏Place Order界面
private void hidePlaceOrderJS(WebView view) {
// 隐藏用户和logo信息
view.loadUrl("javascript:window.handler.show(document.getElementById('topheader').style.display='none');");
// 隐藏placeorder之后
view.loadUrl("javascript:window.handler.show(document.getElementById('iph_menu').style.display='none');");
// 隐藏最底部联系我们等信息
view.loadUrl("javascript:window.handler.show(document.getElementById('footer').style.display='none');");
// 隐藏Review Review Order和Shipping Reminders信息
view.loadUrl("javascript:window.handler.show(document.getElementById('paypal_page_head').style.display='none');");
view.loadUrl("javascript:window.handler.show(document.getElementById('paypal_important').style.display='none');");
// 细节隐藏
// view.loadUrl("javascript:window.handler.show(document.getElementById('paypal_change_shipping_address').style.display='none');");
view.loadUrl("javascript:window.handler.show(document.getElementById('paypal_change_payment_method').style.display='none');");
view.loadUrl("javascript:window.handler.show(document.getElementById('paypal_edit_shopping_cart').style.display='none');");
} // 隐藏Save Order界面
private void hideSaveOrderJS(WebView view) {
view.loadUrl("javascript:window.handler.show(document.getElementById('topheader').style.display='none');");
view.loadUrl("javascript:window.handler.show(document.getElementById('footer').style.display='none');");
view.loadUrl("javascript:window.handler.show(document.getElementById('iph_menu').style.display='none');");
view.loadUrl("javascript:window.handler.show(document.getElementsByClassName('button-set')[0].style.display='none');"); } private class MyChromeClient extends WebChromeClient { // 处理javascript中的confirm,确认
// 登录界面有该对话框
// 继续页面有该对话框
@Override
public boolean onJsConfirm(WebView view, String url, String message, final JsResult result) {
Builder builder = new Builder(CheckoutActivity2.this);
builder.setTitle("Confirm Dialog");
builder.setMessage("Cancle the purchase and return to the ShoppingCart");
Log.e(TAG, "Mesage:" + message);
Log.e(TAG, "JsResult:" + result.toString());
builder.setPositiveButton(R.string.ok, new AlertDialog.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// result.confirm();
// 拦截确定button
Intent intent = new Intent(CheckoutActivity2.this, CartActivity.class);
startActivity(intent);
finish();
}
});
builder.setNegativeButton(R.string.cancel, new AlertDialog.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// 拦截取消button
result.cancel();
}
});
builder.setCancelable(false);
builder.create();
builder.show();
return true;
}
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if(keyCode == KeyEvent.KEYCODE_BACK){
//这样会出现非常多奇怪的问题,还是直接结束
// if(webView.canGoBack()){
// webView.goBack();
// }else{
// CheckoutActivity2.this.finish();
// }
CheckoutActivity2.this.finish();
return true;
}
return super.onKeyDown(keyCode, event);
}
}

上面这个案例是我在app中实际使用到的,没有发现有什么问题。做MEC支付,主要思想是过滤URL,进行对话框的显示和消失、页面隐藏操作等,中间涉及JS。

Paypal-Express Checkout快捷支付方式的android端开发心得(二)的更多相关文章

  1. JMessage Android 端开发详解

    目前越来越多的应用会需要集成即时通讯功能,这里就为大家详细讲一下如何通过集成 JMessage 来为你的 App 增加即时通讯功能. 首先,一个最基础的 IM 应用会需要有哪些功能? 用户注册 / 登 ...

  2. Android NFC开发(二)——Android世界里的NFC所具备的条件以及使用方法

    Android NFC开发(二)--Android世界里的NFC所具备的条件以及使用方法 NFC的应用比较广泛,而且知识面也是比较广的,所以就多啰嗦了几句,我还还是得跟着官方文档:http://dev ...

  3. Android ROM开发(二)——ROM架构以及Updater-Script脚本分析,常见的Status错误解决办法

    Android ROM开发(二)--ROM架构以及Updater-Script脚本分析,常见的Status错误解决办法 怪自己二了,写好的不小心弄没了,现在只好重新写一些了,上篇简单的配置了一下环境, ...

  4. Vue项目用于Ios和Android端开发

    起因 前公司商城App项目使用的是H5开发,有微信公众号.Ios和Android三个版本,H5版本是自己写的一套框架,已经用了有些年头了,承载不下不断涌现出的新需求.而Ios和Android端通过we ...

  5. Android NDK 开发(二) -- 从Hlello World学起【转】

    转载请注明出处:http://blog.csdn.net/allen315410/article/details/41805719  上篇文章讲述了Android NDK开发的一些基本概念,以及NDK ...

  6. Android studio使用心得(二)— 打包签名apk发布

    1.—–Android Studio菜单   Build->Generate Signed APK 2.——Create new.. 3.——-跟eclipse里面一样,添加keystore 信 ...

  7. android ndk开发(二)实现一个官方demo

    实现了一个官方的demo:bitmap-plasma(水波纹) 源代码就在samples文件夹下,可以自己去找. 界面: 建立项目的步骤和配置环境不明白的可以去看:http://www.cnblogs ...

  8. 微信支付(APP支付)-服务端开发(二 )

    如果你已经可以微信支付成功,那么你已经成功90%,剩下的就是订单确认问题了. 接上一篇文章,今天我们来谈一谈,订单查询与确认: APP端支付成功之后,会再次向服务端发起请求,确认付款订单时候成功,同时 ...

  9. go语言游戏服务端开发(二)——网络通信

    一.网络层 网络游戏客户端除了全局登录使用http请求外,一般通过socket长连接与服务端保持连接.go语言的net包提供网络socket长连接相关操作. 对于服务端,一般经历 Listen.Acc ...

随机推荐

  1. 阿里云server(ECS)优惠券领取

    CoderMan的博客也是放置在阿里云的ECS上.速度绝对是刚刚的,大家打开的速度肯定不会慢. 有些同志们至今可能还在用虚拟主机吧,其实阿里云server真心不贵,有俩种计费方式:各自是按月计费和按流 ...

  2. Spring Security 3.2.x与Spring 4.0.x的Maven依赖管理

    原文链接: Spring Security with Maven原文日期: 2013年04月24日翻译日期: 2014年06月29日翻译人员: 铁锚 1. 概述 本文通过实例为您介绍怎样使用 Mave ...

  3. 数据库的group by 分组

    有一个表 查询结果为 用下面的代码写 select COUNT( case NumName when 'a' then NumName end ) as 'aaa', COUNT( case NumN ...

  4. 编C语言单元测试框架CUnit方法库

    /*********************************************************************  * Author  : Samson  * Date   ...

  5. SQL Server :理解数据记录结构

    原文:SQL Server :理解数据记录结构 在SQL Server :理解数据页结构我们提到每条记录都有7 bytes的系统行开销,那这个7 bytes行开销到底是一个什么样的结构,我们一起来看下 ...

  6. javascript - 浏览TOM大叔博客的学习笔记

    part1 ---------------------------------------------------------------------------------------------- ...

  7. Linux下 目录 压缩 解压缩 打包

    http://blog.sina.com.cn/s/blog_7479f7990100zwkp.html tar -zcvf /home/xahot.tar.gz /xahot    tar -zcv ...

  8. Codeforces Round #191 (Div. 2) D. Block Tower

    D. Block Tower time limit per test 2 seconds memory limit per test 256 megabytes input standard inpu ...

  9. [2014 Regional]牡丹江 H Hierarchical Notation 做题记录

    主妇:老年人谁是炮灰牡丹江,我们的团队只是做同步大赛 他决定开爆震H什么时候,A 5min 1Y.I在该限制后,纠结了很久30min+ 1Y,神继续承担各种位置卡D在,hpp见B我认为这是非常熟悉的研 ...

  10. java反编译

    反编译工具下载地址 http://download.csdn.net/detail/u011110110/8621653 反编译方法: 第一步:你先把下载的包的后缀名改成.zip第二步:到网上搜索de ...