ios 支付宝h5页面支付,支付完成后回调实现记录

1、调用服务器端接口,支付宝返回一段HTML,然后将HTML用UIWebview加载一下
注意:服务器端接口一定是调用支付宝h5接口,和pc端有区别,要不然下面的操作不会再进行了
下面是服务器端接口主要代码

private string mobile_submit_alipay(HttpContext context, string WIDout_trade_no, string WIDsubject
    , string WIDtotal_amount, string WIDshow_url, string WIDbody)
{
    DefaultAopClient client = new DefaultAopClient(config.gatewayUrl, config.app_id, config.private_key, "json", "1.0", config.sign_type, config.alipay_public_key, config.charset, false);

    // 外部订单号,商户网站订单系统中唯一的订单号
    string out_trade_no = WIDout_trade_no.Trim();
    // 订单名称
    string subject = WIDsubject.Trim();
    // 付款金额
    string total_amout = WIDtotal_amount.Trim();
    // 商品描述
    string body = WIDbody.Trim();
    // 支付中途退出返回商户网站地址
    string quit_url = WIDshow_url.Trim();

    // 组装业务参数model
    AlipayTradeWapPayModel model = new AlipayTradeWapPayModel();
    model.Body = body;
    model.Subject = subject;
    model.TotalAmount = total_amout;
    model.OutTradeNo = out_trade_no;
    model.ProductCode = "QUICK_WAP_WAY";
    model.QuitUrl = quit_url;

    AlipayTradeWapPayRequest request = new AlipayTradeWapPayRequest();
    // 设置支付完成同步回调地址
    request.SetReturnUrl("http://域名/pay/alipay/wap/Return_url.aspx");
    // 设置支付完成异步通知接收地址
    request.SetNotifyUrl("http://域名/pay/alipay/wap/Notify_url.aspx");
    // 将业务model载入到request
    request.SetBizModel(model);

    AlipayTradeWapPayResponse response = null;
    try
    {
        response = client.pageExecute(request, null, "post");
        return response.Body;
    }
    catch (Exception ex)
    {
    }

    return "";
}

服务端接口返回具体html为:

<form id='alipaysubmit' name='alipaysubmit' action='https://openapi.alipay.com/gateway.do?charset=UTF-8' method='post'><input type='hidden'  name='app_id' value='app_id值'/><input type='hidden'  name='biz_content' value='{\"body\":\"\",\"out_trade_no\":\"ts_20181210105054227474\",\"product_code\":\"QUICK_WAP_WAY\",\"quit_url\":\"\",\"subject\":\"test alipay\",\"total_amount\":\"0.01\"}'/><input type='hidden'  name='charset' value='UTF-8'/><input type='hidden'  name='format' value='json'/><input type='hidden'  name='method' value='alipay.trade.wap.pay'/><input type='hidden'  name='notify_url' value='http://域名/wap/Notify_url.aspx'/><input type='hidden'  name='return_url' value='http://域名/wap/Return_url.aspx'/><input type='hidden'  name='sign_type' value='RSA'/><input type='hidden'  name='timestamp' value='2018-12-10 10:50:54'/><input type='hidden'  name='version' value='1.0'/><input type='hidden'  name='sign' value='PT9+xaDcwa8/omrvweIWexW+kdwVya7As1cnAfYgRhwkoPKB0H/pFNm6HdIiTLaQFjoiRONB7yYc8rKeY04+yCtqkanrO0WZO6/QVZzpWtHVttykRNtdBdXTAmQALXBepf2EbKgIY02/M1szr7UrUTc0QVrfkZ+7ODAWFGT7QW17zu5lV5JOZCZtcfTRk5CfVzDJMTsQlDItarWJkzpLFsncGW44wkn8+UmF/DHvRrgI87ILmQyhXcocrpV2Sf0vHzyQqcnHh64r3rIdzqVUGqzATfTzuN+Dg64UGN0bQDFZz5Arj+xMqak62b+PZN/ciPdf+Cw1HZkKcMNF/ahKIA=='/><input type='submit' value='post' style='display:none;'></form><script>document.forms['alipaysubmit'].submit();</script>

将上述html加载到webview里面后,webview会进行几次跳转,最终可以获取到一段跳转到支付宝的代码如下:

alipay://alipayclient/?%7B%22requestType%22%3A%22SafePay%22%2C%22fromAppUrlScheme%22%3A%22alipays%22%2C%22dataString%22%3A%22h5_route_token%3D%5C%22RZ24aCETVKzE9Sm6Y9I5ROlaBO9xhImobilecashierRZ24%5C%22%26is_h5_route%3D%5C%22true%5C%22%22%7D

替换跳转代码

[url stringByReplacingOccurrencesOfString:@"%22alipays%22" withString:@"%22testmobilepay%22"]

testmobilepay为你项目中设置的urlschemes


image.png

注意这个地方设置的urlscheme不能有特殊字符
对上述代码进行[UrlEncode编码/解码]后得到:

alipay://alipayclient/?{"requestType":"SafePay","fromAppUrlScheme":"alipays","dataString":"h5_route_token=\"RZ24OeCaraWz233HQyQ7yavoAFEJaQmobilecashierRZ24\"&is_h5_route=\"true\""}

字符替换完之后代码:

alipay://alipayclient/?%7B%22requestType%22%3A%22SafePay%22%2C%22fromAppUrlScheme%22%3A%22testmobilepay%22%2C%22dataString%22%3A%22h5_route_token%3D%5C%22RZ24aCETVKzE9Sm6Y9I5ROlaBO9xhImobilecashierRZ24%5C%22%26is_h5_route%3D%5C%22true%5C%22%22%7D

然后用

BOOL bSucc = [[UIApplication sharedApplication] openURL:[NSURL URLWithString:new_url]];

跳转到支付宝,支付宝支付完成后,即会跳转回你的app了

具体参考了简书里面一篇文章
//www.greatytc.com/p/0d8dd04fe94e
大家也可以去参考一下

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

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明先生_X自主阅读 15,992评论 3 119
  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,761评论 2 59
  • 今天是圣诞日,没有雪,没有礼物,没有城市的热闹与喧嚣,在这远离家乡的一隅倒也清静安宁,可以有时间凝神静气地去想一些...
    悠然心会阅读 219评论 0 0
  • 许是我昨天对天的聒噪惹的天的不满了,清晨时已四时过半,窗外仍迷迷瞪瞪的透着些昏糊的夜色,一点儿也没有往日里的清明悦...
    曰日如歌阅读 219评论 0 1