支付宝怎么设置密码(支付宝登录界面怎么设置密码)

支付是一个安全等级很高的场景,系统间交互的每一条数据的泄露都有可能造成及其大的损失。因此支付时系统间交互的每一条数据都会采取加密措施。这里梳理一下支付宝支付时用到的加密规则,请大家参考。

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

图片来自 Pexels

什么是签名?

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

在了解签名前,先回顾一下支付的交互流程。如上图所示,支付的过程中可以大概分为六个步骤:

用户选择自己的商品提交订单。

商家服务器将商品信息和所需要的金额发给支付宝,生成支付宝订单。

支付宝订单返回成功之后生成一个支付页面,方便手机支付或者网页支付。

手机调起支付宝 App 进行支付。

输入支付密码发送给支付宝服务器。

支付宝服务器转账成功,告知商家服务器某个订单的金额转账成功。

这 6 个步骤中,最为重要的是步骤 2 和步骤 6。拆解如下:

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

商家服务器和支付宝服务器交互的过程中传输的信息异常敏感,所以,在交互时必须防止中间人对于信息的篡改。例如步骤 2 将商品的金额改为 0,支付宝就误认为是转账 0 元。

数字签名解决了交互时这一安全问题。它可以验证一条消息或者文档的真实性。

在支付宝支付的接口中,有一个 sign 参数用来填写签名。这个签名作用是为了防止信息伪造。通过这种方式可以有效的防止消息在传递过程中被篡改。

签名实现原理

签名原理

数字签名是一个信息安全的保障,它的实现依赖于双方系统的密钥。

签名过程如下:

计算希望签名的文档的散列。不论输入文档的长度如何,输出长度总是固定的。比如,使用 SHA256 就是 256 位。

对结果散列和一些额外的元数据进行编码。比如,接收方需要知道你使用的散列算法,否则不能处理签名。

使用私钥加密编码过的数据,其结果就是签名,可以追加到文档中作为身份验证的依据。

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

验证签名(验签):接收方接收文档并使用相同的散列算法独立计算文档散列。

接着,她使用公钥对消息进行解密,将散列解码出来,再确认使用的散列算法是否正确,解密出的散列是否与本地计算的相同。

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

非对称加密

支付宝采用 RSA 非对称加密对信息进行签名。非对称加密是由一个公钥和一个私钥组成,一般代码中命名为 public key 和 private key。

非对称加密的特点是:私钥加密的信息只有公钥才能解密,公钥加密的信息只能有私钥才能解密。

一般会将私钥进行保留,开发时一般会放在配置文件中,安全级别和数据库账号密码一样。

公钥会交给其他系统,这样系统间交互时中间人不知道密钥的情况下,是无法破解交互的信息的。

发送方只要保证私钥不泄露,任何人发送给接收方的信息在签名验证时都无法匹配成功。

支付宝的实现签名的方式也大致如此,支付宝在信息交互的时候两个很重要的名词支付宝公钥和应用公钥,这两个秘钥总是让人混淆。

这是因为支付宝提供了两套 RSA 加密。一套是用来保证步骤 2 统一下单接口时的信息安全,另一套是用来保证步骤 6 回调时的信息安全。

如下图,步骤 2 商户服务器通过红色应用私钥(priv key 2)计算签名,支付宝通过红色应用公钥(pub key 2)进行验签。

步骤 6 支付宝服务器通过蓝色支付宝私钥(priv key 6)计算签名,商家通过蓝色支付宝公钥(pub key 6)验证签名。

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

了解了签名计算原理之后,再去管理平台设置 App 信息的时候就游刃有余了,我以沙箱环境为例子。

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

如上图,说明使用 RSA2 加密方式,HASH 算法采用 SHA256。进入设置之后要设置应用公钥和保存支付宝公钥。

应用公钥和应用私钥,这两个需要自己生成一对,保证步骤 2 的安全。生成方式跳转支付宝开放平台开发助手。

支付宝公钥和支付宝私钥是支付宝提供的,私钥支付宝自己保留的,和自己服务器的应用私钥一样,人家不会提供出来。公钥复制下来用于在回调时进行签名的认证。

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

对称加密

签名虽然可以防止中间人的信息篡改,但是无法防止中间人信息查看。比如步骤 2 中,向支付宝发送的商品金额,中间人即可获取每天中该商家交易的金额。

信息在网络中传输感觉是一个虚无缥缈的过程,网络中信息有可能被不法分子进行拦截。

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

因此在支付的过程中,会推荐使用 HTTPS 协议进行交互,使得交互的信息加密传输。

而且,支付宝的很多接口还支持使用 AES 加密之后进行传输,使得信息更加安全。

AES 加密是一种对称加密算法,对称加密算法相对于非对称加密要简单一点。系统间只存在一个密钥,这个密钥可以用来加密也可以用来解密。

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

在与支付宝交互的信息可以通过 AES 加密。防止信息的泄露,官方对接口的解释如下:

若 OpenAPI 无 bizContent 传参则无法使用 AES 密钥加密,否则会报错,当前 API 不支持加密请求。

例如:alipay.user.info.share(支付宝会员授权信息查询接口)未使用 bizContent 传参则无法使用 AES 密钥加密。

AES 和 RSA 关系

支付宝怎么设置密码(支付宝登录界面怎么设置密码)

AES 密钥是对接口请求和响应内容进行加密,密文无法被第三方识别,从而防止接口传输数据泄露。

RSA 密钥是对接口请求和响应内容进行签名,开发者和支付宝开放平台分别加签验签,以确认接口传输的内容没有被篡改。不论接口内容是明文还是密文,RSA 均可正常签名。

开发者可对请求参数先做 AES 加密,然后对密文进行 RSA 签名。


秒鲨号所有文章资讯、展示的图片素材等内容均为注册用户上传(部分报媒/平媒内容转载自网络合作媒体),仅供学习参考。用户通过本站上传、发布的任何内容的知识产权归属用户或原始著作权人所有。如有侵犯您的版权,请联系我们反馈!本站将在三个工作日内改正。
(0)

大家都在看

  • 复刻表西铁城9015机芯质量好吗?买表体验告诉你

    我不会花言巧语,一向实事求是。在我这里我可以确保物超所值,诚信与你 品质保证 复刻表9015机芯质量怎么样,9015机芯虽说是日本机芯,但质量还是比较靠谱的,价格也没有那么廉价,不…

    2022年6月6日 投稿
  • 下载工具哪个好(最好用的下载软件排名)

    一、前言 平时我们在访问一些国外网站的时候难免会出现访问延迟甚至是下载到一半就无法下载的尴尬,比如我用360浏览器下载docker,如图: 看到这感人的速度,不禁让我流下了悔恨的泪…

    2023年2月14日 投稿
  • 广州有什么地方好玩的景点(2022广州旅游必去景点)

    广州别名羊城,地处广东中南部,珠江三角洲中北缘,是中国的南大门,国家的经济、金融、贸易、航运和会展中心。 1. 天气:中国光、热和水资源最丰富的地区之一,降水充沛,冬季气温在10度…

    2022年8月9日 投稿
  • 深圳孤儿院电话和地址(孤儿院的孩子们)

    晚上10点半,位于梅州市大埔县湖寮镇黎家坪坝岗街的大埔县福利院还亮着灯。陈霞正在为上小学的孩子辅导作业。十余年前,她也在同样的地点、同样的灯光下一次次翻过书页。 大埔县福利院。 1…

    2022年8月21日 投稿
  • 基金a和c的区别(基金A类和C类哪个划算)

    最近有个小伙伴问我:我想定投2年,买A类基金好还是C类基金好? 我一拍脑袋,脱口而出:这本质上就是个费率问题啊,而且你准备投2年,时间不短,肯定是A类好啊! 不过,她又“杠”了一下…

    2022年4月26日
  • 穿越三国小说排行榜(穿越三国写得最好的小说)

    一:我的父亲是赵云 简介:公元263年,司马昭遣三路大军伐蜀,姜维令牙门将赵广断后——。 成为赵云次子,赵广逆势而起,挽救蜀汉覆亡结局,吊打司马家弱晋、改变五胡乱华悲剧、再建煌煌盛…

    2022年6月6日 投稿
  • 微信提现怎么免手续费(微信提现怎么免手续费)

    微信作为国内最大的社交软件,在生活上给予了我们极大的便利,然而哪怕是微信也有一些让人蛋疼的“缺点”。我们都知道从银行卡转钱到微信并不用收取手续费,但如果从微信零钱中提现到银行卡就需…

    2022年6月4日 投稿
  • 苹果平板充不进电是什么原因(苹果平板充不进电)

    在我们日常使用手机或平板的时候,突然充不进电或者充电速度突然很慢,这些情况你在使用中是否遇到过?今天跟大家聊一聊充电这点事。 问题分析 一、原装充电器坏了。充电器包括充电头和数据线…

    2022年6月6日
  • 六畜指的是什么?(“六畜”是指哪几种动物?)

    六畜指的是什么?(“六畜”是指哪几种动物?) 我们常说“五谷丰登,六畜兴旺”,之前已经介绍过“五谷”了,那这“六畜”又分别是什么呢? WwW.KeMAoWANG.org。CN 和“…

    2022年5月25日
  • 最贵的狗(十大最贵的狗)

    相信有许多人喜欢狗狗,事实上,地球上有超过339种已被确认的狗狗品种,它们之中有一些拥有非常奇特的外观和令人惊讶的特征。当然,它们大多数都是通过人为培育而来的。然而,如果想要养一些…

    2022年6月21日 投稿
品牌推广 在线咨询
返回顶部