免签支付口令红包流程

23 篇文章 0 订阅

主要流程如下:
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

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
消息口令红包v1.3.4正版源码打包是将这个红包系统的源代码整理成一个可发布和使用的包的过程。 首先,需要对源代码进行版本控制,确保是最新的v1.3.4版本。然后,将所有的源代码文件进行整理和清理,删除不必要的文件和代码片段,以减小包的体积。 接下来,对源代码进行编译和构建。这包括将源代码翻译成机器可以理解的二进制文件,并将所有依赖的库和资源文件打包到一起。确保所有的依赖项都被正确地包含在内,以确保最终的打包可以完整地运行。 在这个过程中,还需要对代码进行测试和调试,以确保打包后的系统没有问题或错误。这包括运行各种测试用例和模拟不同的使用情况,以保证系统的稳定性和可靠性。 一旦代码通过了所有的测试和调试,就可以开始打包了。将编译后的二进制文件和所有的依赖项一起打包,并进行压缩,以减小包的大小。同时,还可以加入一些必要的文档、说明和证书,以提供给用户使用和参考。 最后,对打包后的文件进行发布和分发。可以将打包后的文件上传到一个适当的平台或存储介质中,如可信赖的软件分发网站或云存储服务,并提供下载链接或订阅服务,使用户可以方便地获取红包系统的最新版本。 以上就是消息口令红包v1.3.4正版源码打包的过程。通过整理源代码、编译构建、测试调试和最终的打包发布,可以将红包系统制作成一个易于使用和分发的软件包,方便用户下载和安装。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值