在android开发中会遇到各种SDK的接入,很是麻烦。最初在想能不能把所有的SDK都 融合到一个当中,发现有点异想天开。但是也可以解决SDK资源不小心没有引入,导致程序调用接口崩溃问题。经过查资料,还是写了一个小Demo,仅供参 考!很早之前写的了,估计移动基地SDK,有变动,不过道理是一样的。

仅以移动基地SDK举例。

1.移动支付需要的SO文件导入

    public class CarrotApplication extends Application {
//是否含有移动支付SDK
boolean useCMBilling = false;
@Override
public void onCreate() {
// TODO Auto-generated method stub
try {
Class.forName("cn.cmgame.billing.api.GameInterface");
useCMBilling = true;
} catch (ClassNotFoundException ignored) { }
if(useCMBilling){
System.loadLibrary("megjb");
}
}
}

2.初始化移动基地支付

protected void init_cmcc(String app_name, String app_company,
String telphone_number) {
try {
Object [] cmcc_init_obj = {CarrotPaySDK.mContext,app_name,app_company,telphone_number};
Class<?> [] classparam = {Activity.class,String.class,String.class,String.class};
cfcaim.invokeStaticMethod("cn.cmgame.billing.api.GameInterface","initializeApp",cmcc_init_obj,classparam);
} catch (Exception e) {
// TODO: handle exception
Log.e("init_cmcc异常捕捉", "异常:"+e.toString());
}
}

3.上面 invokeStaticMethod 的实现

    /**
* 执行某个类的静态方法
* @param className 类名
* @param methodName 方法名
* @param oArray 方法参数
* @param paramTypeArray 构造参数类型
* @author liudb
* */
public Object invokeStaticMethod(String className, String methodName,
Object[] oArray,Class<?> [] paramTypeArray) throws Exception {
Class<?> ownerClass = Class.forName(className);
Method method = ownerClass.getMethod(methodName, paramTypeArray);
return method.invoke(ownerClass, oArray);
}

4.调用支付接口

/**
* 执行移动支付
* @param isUsesim sim卡是否可用
* @param isRepeat 计费点是否可重复
* @param index 计费点编号
* @param order 订单号
* @param callback 支付回调
*/
protected void cmcc_pay(boolean isUsesim,boolean isRepeat,String index,String order,final CarrotPayCallBack callback){
try {
//这里的 callback 是自定义的回调函数,会在步骤7里介绍
cmcc_PayendHandler = new CarrotHandler(CarrotPaySDK.mContext){
@Override
public void handleMessage(Message msg) {
// TODO Auto-generated method stub
super.handleMessage(msg);
//这里处理返回结果
callback.onPayEnd(msg.what);
}
};
// 传入参数
Object [] cmcc_pay_param = {CarrotPaySDK.mContext,isUsesim,isRepeat,index,order,new Object()};
// 参数对应的TYPE
Class<?> [] cmcc_pay_paramtyp = {Context.class,boolean.class,boolean.class,String.class,String.class,Object.class};
// "IPayCallback" 是移动支付的回调函数名
cfcaim.invokeContainsInterfaceStaticMethod("cn.cmgame.billing.api.GameInterface", "doBilling", cmcc_pay_param,cmcc_pay_paramtyp,"IPayCallback",CarrotPaySdkFinal.CMCC_PAY);
} catch (Exception e) {
// TODO: handle exception
Log.e("cmcc_pay异常捕捉", "异常:"+e.toString());
}
}

5.重点就是上面 invokeContainsInterfaceStaticMethod 方法的实现

    /**
* 执行包含接口的静态方法
* @param className 类名
* @param methodName 方法名
* @param oArray 具体参数
* @param paramTypeArray 构造参数类型
* @param interfaceName 接口名
* @author liudb
* */
public Object invokeContainsInterfaceStaticMethod(String className, String methodName,
Object[] oArray,Class<?> [] paramTypeArray,String interfaceName,CarrotPaySdkFinal payType) throws Exception {
Class<?> ownerClass = Class.forName(className); Class<?>[] argsClass = new Class[oArray.length];
Method [] ms = ownerClass.getDeclaredMethods();
for (int i = 0, j = oArray.length; i < j; i++) {
argsClass[i] = oArray[i].getClass();
}
Method method = findMethod(ms, methodName, paramTypeArray, interfaceName);
Class<?> clazz = Class.forName(othre_callBack.getName());
//因为接口的最后一个参数是回调函数,所以要设置监测回调
oArray[oArray.length -1] = Proxy.newProxyInstance(
clazz.getClassLoader(),
new Class[]{clazz},
new CarrotPayCallbackMethodInterceptor(payType));
othre_callBack = null;
return method.invoke(ownerClass, oArray);
}

6.还有如何捕获回调的接口返回的参数 CarrotPayCallbackMethodInterceptor 类的实现

    public class CarrotPayCallbackMethodInterceptor implements InvocationHandler {
CarrotPaySdkFinal csf;
public CarrotPayCallbackMethodInterceptor (CarrotPaySdkFinal paytype){
csf = paytype;
}
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
// TODO Auto-generated method stub
switch (csf) {
case CMCC_PAY:
//在这里获得回调函数返回的参数,通过自定义carrotSdkHelper发送给callback处理返回结果
for(int j = 0; j < args.length;j++){
if(args[j].getClass().getName().equalsIgnoreCase("java.lang.Integer")){
Integer result = (Integer)args[j];
switch (result) {
case 1:
Message msg_cmcc_success = new Message();
msg_cmcc_success.what = CarrotPaySDK.CARROT_PAY_SUCCESS;
CarrotPaySDK.carrotSdkHleper.cmcc_PayendHandler.sendMessage(msg_cmcc_success);
break;
case 2:
Message msg_cmcc_faild = new Message();
msg_cmcc_faild.what = CarrotPaySDK.CARROT_PAY_FAILD;
CarrotPaySDK.carrotSdkHleper.cmcc_PayendHandler.sendMessage(msg_cmcc_faild);
break;
default:
Message msg_cmcc_faild2 = new Message();
msg_cmcc_faild2.what = CarrotPaySDK.CARROT_PAY_FAILD;
CarrotPaySDK.carrotSdkHleper.cmcc_PayendHandler.sendMessage(msg_cmcc_faild2);
break;
}
}
}
break;
case OTHER_PAY:
Log.e("___________OTHER_______________", "____________________"+method.getName()); for(int j = 0; j < args.length;j++){
Log.e("___________OTHER_______________"+args[j].getClass().getName(), "____________________"+args[j].toString()); }
Log.e("___________OTHER_______________", "______333333______________");
break;
default:
break;
} return null;
} }

7.(1)callback 类的介绍

    public interface CarrotPayCallBack {
public void onPayEnd(int isSuccess);
}

(2)具体实现新建一个CarrotPayCallBack,传到4步骤的方法里

    new CarrotPayCallBack() {  

                    @Override
public void onPayEnd(int isSuccess) {
// TODO Auto-generated method stub
switch (isSuccess) {
case CarrotPaySDK.CARROT_PAY_SUCCESS:
Toast.makeText(getApplicationContext(), "支付成功", Toast.LENGTH_SHORT).show();
break;
case CarrotPaySDK.CARROT_PAY_CANCEL:
Toast.makeText(getApplicationContext(), "支付取消", Toast.LENGTH_SHORT).show();
break;
case CarrotPaySDK.CARROT_PAY_FAILD:
Toast.makeText(getApplicationContext(), "支付失败", Toast.LENGTH_SHORT).show();
break;
case CarrotPaySDK.CARROT_PAY_UNKNOW:
Toast.makeText(getApplicationContext(), "未知错误", Toast.LENGTH_SHORT).show();
break;
default:
break;
}
}
}

8.代码已经提交到github,如有需要请移驾 https://github.com/liudb5/MyTestPay

9.已经在CSDN发过这个 http://blog.csdn.net/liudb5/article/details/49739873

java 反射调用支付SDK的更多相关文章

  1. Java 反射 调用私有域和方法(setAccessible)

    Java 反射 调用私有域和方法(setAccessible) @author ixenos AccessibleObject类 Method.Field和Constructor类共同继承了Acces ...

  2. 利用java反射调用类的的私有方法--转

    原文:http://blog.csdn.net/woshinia/article/details/11766567 1,今天和一位朋友谈到父类私有方法的调用问题,本来以为利用反射很轻松就可以实现,因为 ...

  3. 通过Java反射调用方法

    这是个测试用的例子,通过反射调用对象的方法.     TestRef.java import java.lang.reflect.Method; import java.lang.reflect.In ...

  4. java反射调用dubbo接口

    需求:项目增加幂等 场景:1.三个项目:a .b.c2.a项目加幂等3.b项目dubbo调用项目a的时候超时没有获取返回结果,增加重试机制(非立即重试,3min or 5min 后重试)4.c项目是一 ...

  5. Java 反射 调用私有构造方法

    单例类: package singleton; public class SingletonTest { // 私有构造方法 private SingletonTest(){ System.out.p ...

  6. java黑魔法-反射机制-02-通过Java反射调用其他类方法

    package com.aaron.reflect; import java.lang.reflect.Method; import java.lang.reflect.InvocationTarge ...

  7. java反射调用api

    cglib的fastmethod 简单示例: FastClass serviceFastClass = FastClass.create(Person.class); Person p = new P ...

  8. JAVA反射调用方法

    1.用户类 package com.lf.entity; import com.lf.annotation.SetProperty; import com.lf.annotation.SetTable ...

  9. Java 反射调用的一种优化

    写一些Java框架的时候,经常需要通过反射get或者set某个bean的field,比较普通的做法是获取field后调用java.lang.reflect.Field.get(Object),但每次都 ...

随机推荐

  1. Ubuntu 12安装Virtualbox

    用aptitude或者apt-get安装Virtualbox,安装过程中会报:”No suitable module for running kernel found [fail]“,安装未成功. 在 ...

  2. SQL server 连接查询

    1.join on     左右拼接查询 2.union 上下拼接    注意:所拼接的列的数据类型要一致

  3. python换行写入文件

    今天用python做写入文件时,碰到,写入的东西不能换行,打开写入的文件都是一行.后来发现需要在写入的字符后面加上+'\n'. 另外python需要追加写入文件的时候,是用这个方法f = open(' ...

  4. js之script属性async与defer

    概念 默认情况下js的脚本执行是同步和阻塞的,但是 <script> 标签有 defer 和 async 属性, 这可以改变脚本的执行方式,这些都是布尔类型了,没有值,只需要出现在 < ...

  5. 裸机编程与OS环境编程的有关思考

    这里的所谓的裸机编程指的是为“无OS支持的硬件系统编程”,而实际的编程工作肯定需要一个环境,通常这样的情况中,编程和编译的环境叫做“宿主机”,最终的程序在“目标机”上运行(交叉编译).而OS环境编程指 ...

  6. 成为Web开发人员的7个简单步骤

    你想成为一名 Web 开发人员,但现在你面前有这样一个问题,那就是你没有在高科技行业工作的经验.你上了一些课程,也花了时间在个人编码项目上,但是你的简历上关于“经验”的部分仍然不为企业承认.过渡到一个 ...

  7. Linux学习笔记25——命名管道(FIFO)

    1 命名管道(FIFO) 管道应用的一个重大缺陷就是没有名字,因此只能用于亲缘进程之间的通信.后来从管道为基础提出命名管道(named pipe,FIFO)的概念,该限制得到了克服.FIFO不同于管道 ...

  8. HDOJ 1081(ZOJ 1074) To The Max(动态规划)

    Problem Description Given a two-dimensional array of positive and negative integers, a sub-rectangle ...

  9. MIPI DSI协议介绍

    此文根据网上的资料翻译和整理而来 一.MIPI MIPI(移动行业处理器接口)是Mobile Industry Processor Interface的缩写.MIPI(移动行业处理器接口)是MIPI联 ...

  10. 转:昨天去参加adobe AIR发布会

    昨天去参加adobe AIR发布会 2008-03-05 12:23 12547人阅读 评论(33) 收藏 举报 adobeairsliverlightwpf微软互联网 首先申明:我不是adobe雇佣 ...