Paypal-Express Checkout快捷支付方式的android端开发心得(二)
一、前导
上一篇讲的不是非常好,这里再又一次讲一下。
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端开发心得(二)的更多相关文章
- JMessage Android 端开发详解
目前越来越多的应用会需要集成即时通讯功能,这里就为大家详细讲一下如何通过集成 JMessage 来为你的 App 增加即时通讯功能. 首先,一个最基础的 IM 应用会需要有哪些功能? 用户注册 / 登 ...
- Android NFC开发(二)——Android世界里的NFC所具备的条件以及使用方法
Android NFC开发(二)--Android世界里的NFC所具备的条件以及使用方法 NFC的应用比较广泛,而且知识面也是比较广的,所以就多啰嗦了几句,我还还是得跟着官方文档:http://dev ...
- Android ROM开发(二)——ROM架构以及Updater-Script脚本分析,常见的Status错误解决办法
Android ROM开发(二)--ROM架构以及Updater-Script脚本分析,常见的Status错误解决办法 怪自己二了,写好的不小心弄没了,现在只好重新写一些了,上篇简单的配置了一下环境, ...
- Vue项目用于Ios和Android端开发
起因 前公司商城App项目使用的是H5开发,有微信公众号.Ios和Android三个版本,H5版本是自己写的一套框架,已经用了有些年头了,承载不下不断涌现出的新需求.而Ios和Android端通过we ...
- Android NDK 开发(二) -- 从Hlello World学起【转】
转载请注明出处:http://blog.csdn.net/allen315410/article/details/41805719 上篇文章讲述了Android NDK开发的一些基本概念,以及NDK ...
- Android studio使用心得(二)— 打包签名apk发布
1.—–Android Studio菜单 Build->Generate Signed APK 2.——Create new.. 3.——-跟eclipse里面一样,添加keystore 信 ...
- android ndk开发(二)实现一个官方demo
实现了一个官方的demo:bitmap-plasma(水波纹) 源代码就在samples文件夹下,可以自己去找. 界面: 建立项目的步骤和配置环境不明白的可以去看:http://www.cnblogs ...
- 微信支付(APP支付)-服务端开发(二 )
如果你已经可以微信支付成功,那么你已经成功90%,剩下的就是订单确认问题了. 接上一篇文章,今天我们来谈一谈,订单查询与确认: APP端支付成功之后,会再次向服务端发起请求,确认付款订单时候成功,同时 ...
- go语言游戏服务端开发(二)——网络通信
一.网络层 网络游戏客户端除了全局登录使用http请求外,一般通过socket长连接与服务端保持连接.go语言的net包提供网络socket长连接相关操作. 对于服务端,一般经历 Listen.Acc ...
随机推荐
- JAVA Socket(多个客户同时连接,信息共享) client (java/ruby)
第一步 充分理解Socket 1.什么是socket 所谓socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄.应用程序通常通过"套接字" ...
- 50 tips of JavaScript
50 tips of JavaScript,这些坑你都知道吗? 1.在局部作用域中,使用var操作符定义的变量将成为定义该变量的作用域中的局部变量,省略var的会创建全局变量:在全局作用域中,不管是否 ...
- TCP closing a connection
client closes socket: clientSocket.close(); step1 :client sends TCP FIN control segment to server st ...
- Mina框架断包、粘包问题解决方式
Mina框架断包.粘包问题解决方式 Apache Mina Server 是一个网络通信应用框架,也就是说,它主要是对基于TCP/IP.UDP/IP协议栈的通信框架(当然.也能够提供JAVA 对象的序 ...
- Sesson禁止使用Cookie
于WebRoot文件夹MEAT-INF新建文件夹context.xml 增加<context path="XXX" cookies='false"> 更改To ...
- CentOS 如何使用第三方软件库-EPEL与RPMForge、RPMFusion软件库
在CentOS下运行yum install flash-plugin或yum install mplayer的时候,提示库里没有找到这个软件?为什么会这样?因为CentOS是RHEL编译过来的,去掉了 ...
- Oracle语句集锦
创建用户并赋予dba权限 1)进入cmd 2)sqlplus / as sysdba 或者 sqlplus sys/密码 as sysdba SQL> conn sys/wcq123@orcl ...
- C 一个字符串有三段,第一段原样输出,第二段为要输出字符串的长度,第三段为依据第二段长度补齐第一段
C 一个字符串有三段,第一段原样输出.第二段为要输出字符串的长度,第三段为依据第二段长度补齐第一段 比如:输入abc 11 12.输出abc12121212 #include<stdio.h&g ...
- HDU 1661 Assigments 贪心法题解
Problem Description In a factory, there are N workers to finish two types of tasks (A and B). Each t ...
- 使用JS或jQuery模拟鼠标点击a标签事件代码
原文 使用JS或jQuery模拟鼠标点击a标签事件代码 这篇文章主要介绍了使用JS或jQuery模拟鼠标点击a标签事件代码,需要的朋友可以参考下 <a id="alink" ...