微信H5支付参考(android)

android webview 微信h5支付

原因

由于原生app支付需要验证包名和签名,如果要做的是sdk,给所有其他应用来接入,所以选择了更为方便接入的h5支付

流程

  • 首先在官网申请账号相关信息,比如本地需要的授权域名REFERER字段申请入口
  • 客户端封装相应参数提交给后台,后台调用微信api生成订单(需要获取客户端ip等,微信会验证下单和支付环境是否一致,细节参考文档)
  • 客户端拿到后台在微信生成的订单,用webview加载调起微信发起支付

要点

以下调起方式存在问题,部分手机调不起微信支付,有可能是有些手机webview无法获取重定向回调,中间考虑用http去拿到重定向的地址,然后用webview去加载,果然成功调起(那时微信h5支付还没对外开放),不料一周之后微信在js中添加Fingerprint2()验证,导致前后环境不一致,无法支付

 Map<String, String> extraHeaders = new HashMap<>();
 extraHeaders.put("Referer", SDKConfigs.REFERER);
 webView.loadUrl(orderUrl, extraHeaders);

解决方案,通过js去加载后台在微信生成的订单地址,当然也可以像微信提供的H5参考demo一样,http://wxpay.wxutil.com/mch/pay/h5.v2.php,下单和调起支付操作都由H5页面调起,获取中转地址也在h5页面中操作,然后用webview装在整个H5页面

String html = "<script>window.location.href='" + orderUrl + "';</script>";
webView.loadDataWithBaseURL(SDKConfigs.REFERER, html, "text/html", "utf-8", null);

另外要注意的是有些手机浏览器https需要验证证书,解决方案如下

 @Override
 public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
     //部分手机浏览器不支持https,所以此处需要接受证书
     handler.proceed();
 }

代码

客户端发起支付代码片段

    /**
     * 调起微信客户端发起支付
     * @param context 上下文
     * @param orderUrl  服务器下完单微信返回的订单地址
     */
    public static void jumpWxByOrderUrl(final Activity context, final String orderUrl) {
        final WebView webView = new WebView(context);
        WebSettings webSettings = webView.getSettings();
        webSettings.setSupportZoom(true);
        webSettings.setAppCacheEnabled(false);
        webSettings.setCacheMode(WebSettings.LOAD_DEFAULT);
        webSettings.setAllowFileAccess(true);
        webSettings.setDefaultTextEncodingName("utf-8");
        webSettings.setJavaScriptEnabled(true);
        webView.setWebChromeClient(new WebChromeClient() {
            @Override
            public void onReceivedTitle(WebView view, String title) {
                super.onReceivedTitle(view, title);
            }

        });
        webView.setWebViewClient(new WebViewClient() {
            public boolean shouldOverrideUrlLoading(WebView view, String newUrl) {
                LogUtils.e("shouldOverrideUrlLoading==>newUrl", newUrl);
                //String tempUrl = newUrl.replaceAll("%3D", "=");
                Uri uri = Uri.parse(newUrl);
                if ("weixin".equals(uri.getScheme())) {
                    //用浏览器打开中转地址,调起微信客户端发起支付
                    Intent intent = new Intent(Intent.ACTION_VIEW);
                    intent.setData(uri);
                    context.startActivity(intent);
                    return true;
                } else {
                    return false;
                }
            }

            @Override
            public void onReceivedError(WebView view, int errorCode,
                                        String description, String failingUrl) {
                super.onReceivedError(view, errorCode, description, failingUrl);
            }

            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);

            }

            @Override
            public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
                //部分手机浏览器不支持https,所以此处需要接受证书
                handler.proceed();
            }

        });
        //部分机型调不起打开微信中转页面,所以这里利用js代码来加载订单地址
        String html = "<script>window.location.href='" + orderUrl + "';</script>";
        webView.loadDataWithBaseURL(SDKConfigs.REFERER, html, "text/html", "utf-8", null);

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 170,569评论 25 707
  • 1.微信app支付 微信的app支付适用于单个的app,比如公司是做app的,一共没有几个app,每个申请一个支付...
    恶魔殿下_HIM阅读 12,841评论 11 29
  • 程序设计如何学习 首先我们要了解一些关于程序设计基本概念。 计算机现已广泛应用于社会生活的各个领域,成为大众化的现...
    骑士恨煎蛋阅读 800评论 0 0
  • 我提着皮箱在前头走,她不紧不慢地跟在后面、似乎与我刻意保持着一段距离。走上站台,只有中年站务员在懒洋洋地踱着步,本...
    肇英阅读 296评论 0 2
  • 近日,香港城市大学EMBA校友团就来到了专注于计算视觉的手机厂商ivvi进行了参观调研,并达成了一系列合作。 这一...
    可能是90后最会买手机的阅读 1,726评论 0 0