免签支付口令红包流程

主要流程如下:
1:提示用户通过二维码跳转到红包界面(或者直接提示客户在支付宝搜索口令红包),发送一个口令红包,生成口令并回填给服务器
红包操作
口令红包
2:服务器推送口令给App,App 通过Hook 自动领取口令红包

hook代码
3:回调服务器订单支付成功!

4:实际效果测试地址

http://mpay.php05.cn

口令因为每个订单口令不一样 所以基本可做到一对一 100%不丢单,暂时来说是比较好用的方式!

关键代码,下面有测试地址

 /**
     * 领取口令红包
     * @param context
     * @param cmd
     */
    public static void openCmdHB(Context context, String cmd) {

        try {


            ClassLoader classLoader = context.getClassLoader();


            Class d = classLoader.loadClass("com.alipay.mobile.redenelope.proguard.u.c");




            Object dObj = XposedHelpers.newInstance(d,context, "EnvelopeHome");

            Object da = XposedHelpers.getObjectField(dObj, "a");
            String db = (String) XposedHelpers.getObjectField(dObj, "c");

            HashMap v3_4 = new HashMap();
            String user = Tools.getLoginId(classLoader);
            String appkey = context.getPackageManager().getPackageInfo(context.getPackageName(), 0).versionName;
            ((Map) v3_4).put("user", user);
            ((Map) v3_4).put("appkey", appkey);
            ((Map) v3_4).put("pageName", "EnvelopeHome");
            ((Map) v3_4).put("refPageName", "");
            XposedHelpers.callMethod(da, "onPage", context, v3_4, false );


            String oneid_ua_data = (String) XposedHelpers.callMethod(dObj, "a");

            Class ShortCodeEnterRequest = classLoader.loadClass("com.alipay.giftprod.biz.front.models.ShortCodeEnterRequest");
            Object ShortCodeEnterRequestObj = XposedHelpers.newInstance(ShortCodeEnterRequest);

            HashMap hashMap = new HashMap();
            XposedBridge.log("oneid_ua_data:" + oneid_ua_data);
            hashMap.put("oneid_ua_data", oneid_ua_data);


            XposedHelpers.setObjectField(ShortCodeEnterRequestObj, "extInfo", hashMap);
            XposedHelpers.setObjectField(ShortCodeEnterRequestObj, "shortCode", cmd);

            Class ShortCodeEnterService = classLoader.loadClass("com.alipay.giftprod.biz.front.rpc.ShortCodeEnterService");
            Object ShortCodeEnterServiceObj = getRpcProxy(getAlipayApplication(classLoader), ShortCodeEnterService);


            Object ShortCodeEnterRsqObj = XposedHelpers.callMethod(ShortCodeEnterServiceObj, "shortCodeEnter", ShortCodeEnterRequestObj);
            XposedBridge.log("openCmdHB:" + new Gson().toJson(ShortCodeEnterRsqObj));
            boolean success = XposedHelpers.getBooleanField(ShortCodeEnterRsqObj, "success");
            String resultCode = (String) XposedHelpers.getObjectField(ShortCodeEnterRsqObj, "resultCode");
            String resultDesc = (String) XposedHelpers.getObjectField(ShortCodeEnterRsqObj, "resultDesc");
            String resultView = (String) XposedHelpers.getObjectField(ShortCodeEnterRsqObj, "resultView");
            String prodCode = (String) XposedHelpers.getObjectField(ShortCodeEnterRsqObj, "prodCode");
            String url = (String) XposedHelpers.getObjectField(ShortCodeEnterRsqObj, "url");


            if (!success) {

                XposedBridge.log("openCmdHB 口令红包打开失败 resultDesc:" + resultDesc);
                XposedBridge.log("openCmdHB 口令红包打开失败 resultView:" + resultView);
                XposedBridge.log("openCmdHB 口令红包打开失败 resultCode:" + resultCode);

                if(resultView.startsWith("已经错"))
                {
                    String dd=resultView.substring(resultView.indexOf("已经错"),4).replace("已经错","");
                    XposedBridge.log("openCmdHB 口令红包打开失败 已经错次数:"+dd + resultCode);
                }

                return;
            }

            Uri uri = Uri.parse(url);
            String bizType = uri.getQueryParameter("bizType");
            String crowdNo = uri.getQueryParameter("crowdNo");
            String sign = uri.getQueryParameter("sign");
            String prevBiz = uri.getQueryParameter("prevBiz");
            String universalDetail = uri.getQueryParameter("universalDetail");
            String target = uri.getQueryParameter("target");

            XposedBridge.log("openCmdHB  bizType:" + bizType);
            XposedBridge.log("openCmdHB  crowdNo:" + crowdNo);
            XposedBridge.log("openCmdHB  sign:" + sign);
            XposedBridge.log("openCmdHB  universalDetail:" + universalDetail);
            XposedBridge.log("openCmdHB  target:" + target);

            new ReceiveCrowdTask(classLoader, crowdNo, null, sign, prevBiz, null, null, null, null, null,context,cmd).execute();
        } catch (Exception e) {
        }
    }

整套测试地址
http://admin.php05.cn/pay

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值