android招商银行“一网通”开发详解

android端集成“一网通”支付的demo
https://github.com/ycwmuyi/yiwangtongDemo/

这段时间公司在做招商银行"一网通"支付的开发工作,当中有些遇到的坑跟大家分享一下,还有就是网上相关可参考的文章确实不多,所以写点自己的心得提高一下大家的效率。文章可是有提供本人写的一个“一网通”支付的demo,感兴趣的同学可以clone下来看看,如果有什么写的不好的地方欢迎指教。

“一网通”与支付宝支付,微信支付的差异###

已支付宝为例解释一下第三方app是如何调取支付宝完成支付动作的,微信和支付宝大体逻辑相似,有些不一样的地方后面会做说明。

“支付宝”支付分两种情况:

你的手机已安装支付宝app######

当第三方app发起支付动作,第三方app内集成的支付宝的sdk会通过进程间的通讯把相关的支付信息传给支付宝app,支付宝app完成支付动作后,再通过进程间的通讯告诉第三方app支付的结果。(支付宝实现进程间的通讯是通过handler实现,而微信是通过aidl实现,个人觉得支付宝的实现方式更利于我们程序员开发)

你的手机没有安装支付宝app######

那这个时候怎么办呢?当然不用担心,支付宝的sdk里集成了一个h5页面,如果发现你的手机没有安装支付宝app,那这个时候它就会唤起这个h5页面让用户通过这个h5页面完成支付动作,当然这种方式肯定是没有直接用支付宝app方便的。

说了这么多好像跟“一网通”没有半毛钱关系,先别急,现在开始来说说“一网通”。其实“一网通”和我上面说的两种情况中的第二种是一样的,不同的是支付宝已经把他封装成sdk,可以很方便的提供给开发者使用,而“一网通”只是提供了一个键盘的sdk其他的相关逻辑(如:webview的加载,签名,加密,支付结果的回调出里)都要开发者自行解决。说道这是不是感觉有点坑。

“一网通”开发步骤##

1.接入“一网通”的键盘

这里其实没什么好讲的官方有提供demohttp://121.15.180.72/OpenAPI2/Download.aspx
原理是通过重写WebViewClient的shouldOverrideUrlLoading(WebView view, String url)的方法(这个在 android5.0以后就被shouldOverrideUrlLoading(WebViewWebResourceRequest)取代了)。

@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
@Override
public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
    // 使用当前的WebView加载页面
    CMBKeyboardFunc kbFunc = new CMBKeyboardFunc((Activity) view.getContext());
    if(kbFunc.HandleUrlCall(view, request.getUrl().toString()) == false) {
        return super.shouldOverrideUrlLoading(view, view.getUrl());
    }else {
        return true;
    }
}


@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
    DebugLog.e("shouldOverrideUrlLoading: "+url);
    // 使用当前的WebView加载页面
    CMBKeyboardFunc kbFunc = new CMBKeyboardFunc((Activity) view.getContext());
    if(kbFunc.HandleUrlCall(view, url) == false) {
        return super.shouldOverrideUrlLoading(view, url);
    }else{
        return true;
    }
}

#######2,如何加载WebView
因为现在有很多app开发是h5和native的混合开发,加载的“一网通”支付链接是通过form请求

<form action="请求地址" method="post" >
<input type="hidden" name="jsonRequestData" value='以上json字符串' />
</form>

如果是h5跳转用上面的方式
如果是native加载webview使用下面的方式

String jsondata =   "jsonRequestData="+josn参数;
webview.postUrl(payUrl,jsondata.getBytes());

payUrl是“一网通”的接口链接

3,签名的生成

“一网通”要求将所有的请求参数按英文字母的升序排列拼接再加上私钥后生成签名,然后将所有参数生成json格式请求。这边我是将所有参数放到一个javabean中,然后通过反射的方式获取所有的字段和字段值的list,然后对list进行排序,最后遍历拼接,看代码吧。

 /**
 * 获得一网通接口的相关参数的签名
 * @param obj
 * @return
 */
public static String getSign(Object obj){
    Field[] fields =obj.getClass().getDeclaredFields();
    List<String> valueNameList = new ArrayList<String>();
    Map<String,String> valueMap = new HashMap<>();
    for(int i= 0;i<fields.length;i++){
        try {
            System.out.println("name:"+fields[i].getName()+" value:"+fields[i].get(obj));
            valueNameList.add(fields[i].getName());
            valueMap.put(fields[i].getName(),  fields[i].get(obj)==null?"":(String)fields[i].get(obj));
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        }
    }
    System.out.println("参数个数:"+valueNameList.size());
    //按英文字母升序排序
    Collections.sort(valueNameList, new Comparator<String>() {
        @Override
        public int compare(String o1, String o2) {
            return o1.compareToIgnoreCase(o2);
        }
    });
    StringBuilder sb = new StringBuilder();
    for (int i = 0;i<valueNameList.size();i++) {
        String valueName = valueNameList.get(i);
        String value = valueMap.get(valueName);
        sb.append(valueName+"="+value+"&");
    }
    sb.append(YWTConfig.privateKey);
    System.out.println(sb.toString());
    // 创建加密对象
    MessageDigest messageDigest = null;
    try {
        messageDigest = MessageDigest.getInstance("SHA-256");
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
    // 传入要加密的字符串,按指定的字符集将字符串转换为字节流
    try {
        messageDigest.update(sb.toString().getBytes("UTF-8"));
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    }
    byte byteBuffer[] = messageDigest.digest();
    // 將 byte数组转换为16进制string
    String sign = hexString(byteBuffer);
    System.out.println(sign.toString());
    return sign;

}

最后通过gson输出对应json格式的数据就好了。

4.监听支付成功
1489738192(1).png

再请求支付的参数中有这样一个参数returnUrl,这是一个跳转链接,当完成支付时“一网通”会跳转到这个链接,这对webApp固然是很好的,但是如果是原生app意味着我必须通过监听webview的链接跳转,当监听到的跳转链接是returnUrl时就意味着支付成功了。(个人建议可以监听onPageStart()方法来进行判断时候支付完成,当然如果有大神还有更好的方法欢迎指教)

备注:第一次写博客,肯定有多不足的地方,希望大家多谅解,多指教。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,948评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,371评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,490评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,521评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,627评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,842评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,997评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,741评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,203评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,534评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,673评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,339评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,955评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,770评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,000评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,394评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,562评论 2 349

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,799评论 25 707
  • 最近刚做的一网通支付。mark一下。 我这里做的是2.0版本的一网通支付 一网通开放平台 http://58.61...
    AddisonLi阅读 3,316评论 9 1
  • 【墨竹的菜园】0124——接近年底了,创新者团队将以合作入股的方式,与合作方共同打造两个餐饮品牌。 从单纯...
    墨竹的菜园阅读 396评论 0 0
  • 你是冬日里的阳光,温暖她的心却走不进你的心! 你是霸道小魔王,却霸占不了她的心,她的情! 或许她...
    林小妹LXM阅读 246评论 8 2
  • 你说你热爱春天和原野,后来你离开了再熟悉不过的生活,你戴了一块儿表,背了一个双肩包,那个背影定格在我们这群朋友的记...
    面壁yang阅读 202评论 0 2