在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. Life Forms

    poj3294:http://poj.org/problem?id=3294 题意:就是求n个串的中一个最大的子串,这个子串在超过n/2的串中出现. 题解:这是一道好题.首先一种解法就是用后缀数组来搞 ...

  2. css li 列表

    ul,li{list-style-type:none;padding:0;margin:0}

  3. jQuery&HTML&CSS3实现垂直手风琴折叠菜单方法讲解

    在网页制作中我们常常需要折叠式的菜单,在折叠菜单中,手风琴特效的菜单是非常受欢迎,下面就讲解使用jQuery+HTML+CSS3实现垂直手风琴折叠菜单的方法. jQuery实现垂直手风琴折叠菜单示例代 ...

  4. java 集合框架图

    Java平台提供了一个全新的集合框架.“集合框架”主要由一组用来操作对象的接口组成.不同接口描述一组不同数据类型. Java 2集合框架图集合接口:6个接口(短虚线表示),表示不同集合类型,是集合框架 ...

  5. Hadoop 新 MapReduce 框架 Yarn 详解

    Hadoop 新 MapReduce 框架 Yarn 详解: http://www.ibm.com/developerworks/cn/opensource/os-cn-hadoop-yarn/ Ap ...

  6. Hadoop的文件读写操作流程

    以下主要讲解了Hadoop的文件读写操作流程: 读文件 读文件时内部工作机制参看下图: 客户端通过调用FileSystem对象(对应于HDFS文件系统,调用DistributedFileSystem对 ...

  7. unity3d 制造自己的水体water effect(二)

    前篇:unity3d 制造自己的水体water effect(一) 曲面细分:Unity3d 使用DX11的曲面细分 PBR: 讲求基本算法 Unity3d 基于物理渲染Physically-Base ...

  8. java基础(七)面向对象(二)

    这里有我之前上课总结的一些知识点以及代码大部分是老师讲的笔记 个人认为是非常好的,,也是比较经典的内容,真诚的希望这些对于那些想学习的人有所帮助! 由于代码是分模块的上传非常的不便.也比较多,讲的也是 ...

  9. Hdu 5036-Explosion 传递闭包,bitset,期望/概率

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=5036 Explosion Time Limit: 6000/3000 MS (Java/Others)   ...

  10. nginx安装lua-nginx-module模块

    转载注明地址:http://www.cnblogs.com/dongxiao-yang/p/5312285.html 本文主要采用手动源码安装的方式将lua-nginx模块编译到nginx源码内部 一 ...