微信 及支付宝 支付接口 功能

1:首页需要了解支付宝跟微信的开发文档,这里就贴上文档网址,不做过多描述

 微信:https://pay.weixin.qq.com/wiki/doc/api/index.html

支付宝:https://open.alipay.com/developmentDocument.htm

2:业务流程

    首先不管是支付宝还是微信,在对应不同的场景支付的时候都会有不同的接口,这里需要注意,常见的:app支付,H5支付,小程序支付,官网支付,还有线下O2O的扫码支付,JsAPI支付(这个是网页版的H5但是不是在公众号里面)等等。

   一: 先说支付宝   服务端 3个方法, 一个在唤醒支付之前调用的,第一个方法也是最重要的方法,因为另外2个方法是处理自业务流程的,也就是回调方法,我这边 支付方法名字取得为:WepayActiveReady  里面需要一些跟你业务相关的参数,

那为什么是2个回调方法呢?

那是支付宝防止你的 同步回调 失败,那么就再每隔一段时间调用你的异步回调方法,来更新你本地订单状态(当然其他你想要实现的页面功能都可以在异步方法实现),

那怎么调用异步方法呢?  

刚才说了,在唤醒支付之前需要调用第一个支付方法,这个方法里面在

 

前端调用页面如下:

在前端确认支付的时候,调用的方法,调用服务端方法 返回一个 xml格式。主要是需要服务端返回下面列表:

{
    "Result": true,
    "Data": "http://wappaygw.alipay.com/service/rest.htm?format=xml&partner=2088101632346510&req_data=<auth_and_execute_req><request_token>UTPa9c3e7c3e17447968ac9e739e2c43f44$00</request_token></auth_and_execute_req>&sec_id=MD5&service=alipay.wap.auth.authAndExecute&v=2.0&sign=e8f3b11ab0165761d8e5a3d301eaae82"
}

前端直接调用这个 Data的url 就可以唤醒支付宝的request_token 里面 就有你需要传的 异步回调,同步回调,只不过这里通过加密了。另外,本地订单号,金额,描述等一些必须字段,都是加密在这个属性里面。后台会生产一个taken传给前端。调用用这个链接http://wappaygw.alipay.com/service/rest.htm?后面配置参数来唤醒支付。

如何生产token  这个可以支付宝开发参考文档。

生成返回的Url,Url返回客户端,客户端直接调用这个Url就可以做唤醒功能了。

用户唤醒成功,支付完成,

如何生产返回的URL:

上面代码里面主要方法:

alipay_wap_trade_create_direct  生成token

alipay_Wap_Auth_AuthAndExecute 生成URL

1.2就会调用同步回调方法:Alipay_ActiveReturn

这个方法是因为是支付宝回调的方法,

所以不会在方法里面带参数的,那么如何取参数呢?

所以这里需要用到上下文,this.HttpContext,通过解析上下文客户获取到你需要的订单单号,

并且需要做签名校验,安全通过之后,再操作业务流程。

获取淘宝的上下文的签名:

 string aliSign = context.Request["sign"];

并且通过获取参数,生产本地的sign

 

 解析方法:

     string out_trade_no = context.Request["out_trade_no"];
     string request_token = context.Request["request_token"];

 

 

 

二 :微信支付:

微信支付

微信支付分很多种不同场景支付方式,每种支付方式传的参数是不完全一致的,

分别有App支付,H5支付,JsAPI支付,小程序支付,人脸支付,付款码支付 ,Native支付。

调用接口都是一个:    

        /// <summary>
        /// 统一支付接口
        /// </summary>
        const string UnifiedPayUrl = "https://api.mch.weixin.qq.com/pay/unifiedorder";

 

这里主要以JSAPI支付方式讲解:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_1

记住,微信支付,需要先给支付账号做很多处理,包含授权,申请,微信审核,整个流程下来非常麻烦,如果不熟悉的开发估计要1-2周才会全部弄好,因为微信审核一般都要等3天。

申请的微信账号,登入上线会有流程操作,如何申请支付功能开通的流程。按照上面的链接操作就可以,

微信支付文档里面的流程图,贴一下:

 微信支付也 是相同的流程,先客户端调用 服务端方法来唤醒支付:但是微信一般只有2个方法,

一个唤醒方法,一个回调方法,

唤醒方法返回值就是:

{
    "Result": true,
    "Data": {
        "appId": "wx330c5becf5a36a7f",
        "timeStamp": "1588063109",
        "nonceStr": "1068c6e4c8051cfd4e9ea8072e3189e2",
        "package": "prepay_id=",
        "signType": "MD5",
        "paySign": "31D1E4BB436A94D27B3178595395C403"
    }
}

上面参数说明: 这个是返回给客户端的一个json

Data里面是 Appid  这个是跟微信申请的商家支付账号的appid。

timestamp  是时间戳   

nonceStr 是一个随机串  

package   获取prepay_id

signType 加密方法

paySign 这个是最重要的,里面加密了很多参数信息,包含回调方法,订单,金额  等

这里面的PaySign里面会有一个prepay_id参数,而prepay_id参数里面有一个notify_url回调方法路径,这里输入回调方法路径,就可以在微信支付完成后回调。

微信需要注意:不很多不同的支付方法,JSAPI跟H5支付是有区别的,不同的场景,会有不同的支付方法,否则调用就会失败,

 

二:H5支付:

文档:https://pay.weixin.qq.com/wiki/doc/api/H5.php?chapter=9_20&index=1

跟JSAPI的主要区别,就是在后面的参数上面,

第一:因为H5支付是不需要 传 openid这个参数。所以可以在前端不需要传Code这个参数,

第二:新增了一个必转参数:场景信息

scene_info = "{'h5_info':{ 'type':'Wap','wap_url':'https://i.998.com','wap_name': 'H5活动订单'} }";

其他的基本不需要修改,如果业务一致,完全可以放在一个参数里面。分不同的区分,可以使用委托实现,不同逻辑分支,担任可以用Type区分或者是判断是否传了Code,这里是个人书写习惯问题。

 

这里有一个题外话需要注意下,就是用Postman调式接口的是,在Body里面书写参数,注意下,这里的参数不能用复制的方式直接把其他地方的复制过来,要手动一个个写,否则转到服务端,全部都是null,这个是一个比较坑的地方。

 

 

 

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/40771.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android应用程序如何调用支付宝接口

最近在做一个关于购物商城的项目&#xff0c;项目里面付款这块我选的是调用支付宝的接口&#xff0c;因为用的人比较多。 在网上搜索了以下&#xff0c;有很多这方面的教程&#xff0c;但大部分教程过于陈旧&#xff0c;而且描述的过于简单。而且支付宝提供的接口一直在更新&am…

小编和ChatGPT聊了下智能运维,大家看看能不能把专家替了?

近日&#xff0c;聊天机器人ChatGPT爆火&#xff0c;仅仅推出2个月&#xff0c;其月活跃用户就成功过亿&#xff0c;成为历史上增长最快的消费者应用程序。连一向高调的马斯克在使用ChatGPT都直呼“好到吓人”&#xff0c;甚至断言&#xff1a;“我们离强大到危险的AI不远了。”…

外贸单证制作常用名称中英互译表

外贸单证制作对于外贸人来说会遇到的样式很多&#xff0c;因此在进行这项工作的过程中&#xff0c;会有很多专业单证英文名称&#xff0c;对于这些名称的了解就很重要。这里汇信外贸管理软件整理了包含390种常用外贸单证名称的中英互译表&#xff0c;大家来分享吧&#xff01; …

广外2023口译(非英专)复习资料以及模考反馈

大家好&#xff0c;有几位同学想让我更新一下口译&#xff0c;本人听译情况&#xff08;四级听力209&#xff0c;六级听力197&#xff0c;广外笔译94&#xff09; here I come&#xff01;还是个人复习向&#xff0c;现在这个节点了&#xff0c;平时没练的话就只能求保命了。 …

香港中文大学计算机辅助翻译课程,港中文翻译(MA in Translation)专业申请解析...

原标题&#xff1a;港中文翻译(MA in Translation)专业申请解析 最近随着《亲爱的翻译官》的热播&#xff0c;翻译专业也重新受到大家的关注&#xff0c;下面我们就给大家介绍香港中文大学翻译硕士(Master of Arts in Translation)。 项目时长&#xff1a;1年 学费&#xff1a;…

【打卡帖】7日玩转ESP32——(第2日) GPIO输入,按键的长按和短按

文章目录 一、硬件准备二、知识要点三、参考例程四、今日作业五、参考答案5.1 知识点5.2 中断方式5.3 定时扫描 六、打卡~ 一、硬件准备 开发板上面有一个Boot Button按键。 从原理图可以看出&#xff0c;按键按下时&#xff0c;GPIO9是低电平。按键弹起时&#xff0c;GPIO是…

006. esp32 下载--第二版

1. 先按boot键&#xff08;不放开&#xff09;&#xff0c;再按 复位按键&#xff0c;按下&#xff0c;放开。会进入下载模式。如果进入下载模式失败。 重复&#xff0c;按住Boot键不放&#xff0c;复位按键&#xff0c;按下&#xff0c;放开。 2.下载图示如下&#xff1a; …

基于ESP32的硬件项目教程(三)ESP32的引脚说明及数字信号读写操作

引脚说明 以下图为例 图片下方的英文部分已经有了介绍&#xff0c;本文将进行一次简述。 此型号开发板一共38个引脚&#xff0c;除去电源引脚外&#xff0c;可用IO引脚为34个&#xff0c;在图中有GPIO6~GPIO11等6个引脚标注有红色“&#xff01;”&#xff0c;这6个引脚常作为…

【填坑】ESP32 bootloader初探(上)

前言 大名鼎鼎的乐鑫ESP8266 WIFI模组你应该不陌生&#xff0c;不用我多说了。在这之后乐鑫还更迭了更多高性能的芯片型号&#xff0c;比如这次我要记录的ESP32-C3&#xff0c;搭载近期很火的RISC-V指令集处理器&#xff0c;支持2.4G wifi、BLE-5&#xff0c;拥有丰富应用场景…

ESP32初级入门

1.下载的时候如果出现不能下载&#xff0c;那是因为没复位&#xff0c;在出现connect时按住板子上的boot按键&#xff0c;出进度了然后松开&#xff0c;就会正常下载。 2.点灯和uno一样&#xff0c;直接在setup里面设置管脚模式&#xff0c;在loop里面赋值就行&#xff0c;根本…

ESP32 Secure Boot和Flash加密

ESP32的代码是存在外部Flash中&#xff0c;如果不加密&#xff0c;很容易被窃取代码。 ESP32的secure boot和flash加密是两个功能&#xff0c;但是要配合一起使用&#xff0c;其加密效果才好。 一、初次加密。 这里只写可重复烧写的加密方式&#xff0c;其加密步骤如下&…

ESP32修改BootLoader:在boot中添加GPIO和IIC驱动方式

ESP32修改BootLoader&#xff1a;在boot中添加GPIO和IIC驱动方式 1. ESP Bootloader简介 ESP32有着强大的引导加载程序&#xff08;Bootloader&#xff09;功能&#xff1a; 主要执行以下任务&#xff1a; 内部模块的最小化初始配置&#xff1b; 根据分区表和 ota_data&#…

ESP32 基础篇: 启动时 rst cause 和 boot mode

本文参考 ESP32 技术参考手册 和 ESP32-WROOM-32 datasheet 简介 在 ESP32 启动时, ROM CODE 会读取 GPIO 状态和 rst cause 状态, 进而决定 ESP32 工作模式。 通过了解和掌握 rst cause 和 boot mode, 有助于定位某些系统问题。 例如: ESP32 启动时会有如下打印: rst:0x1 (…

微信小程序 自动对对联

微信小程序 自动对对联 微信扫描二维码体验吧

使用scoped让样式只对当前页面其作用时/deep/ 可以使其对子组件起作用

官方文档https://vue-loader.vuejs.org/guide/scoped-css.html#mixing-local-and-global-styles 使其样式只对当前页面起作用 影响到里面的子组件

uniapp-微信小程序,对子组件实现onShow效果

背景&#xff1a;使用uni-app开发一个微信小程序&#xff0c;使用的vue子组件&#xff0c;发现在子组件里面不能使用onShow生命周期&#xff0c;但是可以在page里面可以调用&#xff0c;需要在使用uni.navigateBack()返回后&#xff0c;该组件能请求接口数据刷新 解决&#xf…

基于强化学习的大规模多任务机器人训练

发布人:Google 机器人团队高级研究员 Karol Hausman 和研究员 Yevgen Chebotar 通用机器人要想发挥最大的作用,就需要能够完成一系列的任务,如清洁、维护和运送。但是,使用离线强化学习 (RL)(智能体使用以前收集的数据开展训练,在试验和错误中学习的一种方法)来训练,即…

数据库MySQL详解

全网最详细MySQL教程&#xff0c;应付大学考试、考研复试、求职笔试应该说是完全足够的&#xff0c; 有兴趣的朋友可以看我的MySQL专栏&#xff0c;都是MySQL原理和底层一点的东西&#xff0c;可能比一般的面试文都深入。 本文篇幅较长&#xff0c;笔误之处在所难免&#xff0c…

关于对Vue中slot插槽理解

关于slot插槽理解 1.何时需要使用插槽 在开发中&#xff0c;我们需要将共性内容抽取到组件中&#xff0c;将不同的暴露为插槽。 插槽的益处便是&#xff0c;一旦预留了插槽&#xff0c;使用者便可以根据自己的需求来决定插槽中插入的的内容2. slot的基本使用 <div idapp&…

记录一次 AGP 调研过程中的思考,我从一个事故搞出了一个故事!

背景 看过我博客的老铁应该知道&#xff0c;我在 18 年五月写过一个小 gradle 插件https://github.com/yanbober/app-tiny-R-gradle-plugin&#xff0c;其作用就是将 app 生成的 R 常量进行内联操作。对&#xff0c;就是前不久很火的滴滴 booster 和字节跳动 ByteX 提供的 R 资…