一、流程
- 向招行申请测试对接一网通,招行提供一网通测试信息
- 按照招行一网通开放文档用测试信息一步一步进行,保留测试结果
- 向招行提交测试报告并申请生产状态信息
- 修改测试信息为生产信息,开始使用
二、Android端对接
1 按照Android对接文档导入lib,res和Manifest里的配置
2 添加一网通支付界面 包括Title(便于返回)和webview(加载一网通支付)
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<include layout="@layout/layout_title" />
<ProgressBar
android:id="@+id/progressBar"
style="@style/ProgressBar_Mini"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:max="100"
android:maxHeight="@dimen/dp_3"
android:minHeight="@dimen/dp_3"
android:visibility="gone" />
<WebView
android:id="@+id/webView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white"
android:scrollbars="none" />
</LinearLayout>
3 添加activity处理数据
- 主要是WebViewClient
webView = (WebView) findViewById(R.id.webView);
bar = (ProgressBar) findViewById(R.id.progressBar);
WebSettings set = webView.getSettings();
set.setJavaScriptEnabled(true);
set.setSaveFormData(false);
set.setSavePassword(false);
set.setSupportZoom(false);
webView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
CMBKeyboardFunc kbFunc = new CMBKeyboardFunc(TestActivity.this);
if (url.equalsIgnoreCase("http://cmbnprm/")) {//这里是最后返回商户按钮的屏蔽
finish();
}
return kbFunc.HandleUrlCall(webView, url) || super.shouldOverrideUrlLoading(view, url);
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
bar.setVisibility(View.VISIBLE);
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
bar.setVisibility(View.GONE);
}
});
webView.setWebChromeClient(new WebChromeClient() {
@Override
public void onProgressChanged(WebView view, int newProgress) {
super.onProgressChanged(view, newProgress);
bar.setProgress(newProgress);
}
});
- 自动提交
private String getHtml(String data) { String html = "<form id=\"paysubmit\" name=\"paysubmit\" action=\"http://61.144.248.29:801/netpayment/BaseHttp.dll?MB_EUserPay\"\n" + " method=\"post\">\n" + " <input type=\"hidden\" name=\"jsonRequestData\" value='" + data + "'/>\n" + " <input style=\"display: none\" type=\"submit\" value=\"提交\" />\n" + "</form>\n" + "<script>document.forms['paysubmit'].submit();</script>"; return html;}
- webView.loadData(getHtml(由服务器返回),”text/html”,”utf-8”);
三、服务器对接流程
- 导入服务器Demo
- 修改配置信息为招行提供的测试信息
- 按照招行开放文档对接支付API 和 支付成功回调 签约成功回调(* 注意 测试回调使用ip+端口方式 * **)
- 为移动端提供提交数据接口
招行一网通开放文档地址点此打开招行一网通开放文档