V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
ufo22940268
V2EX  ›  Node.js

在集成支付宝的时候碰到 RSA 解密的问题

  •  
  •   ufo22940268 · 2015-04-09 14:35:04 +08:00 · 5458 次点击
    这是一个创建于 3519 天前的主题,其中的信息可能已经有所发展或是发生改变。
    我现在要对支付宝的notify_url进行验秘的阶段。但是很奇怪的事情是支付宝的公钥进行解密的时候一直报一个错。RSA解密用的库是ursa



    代码:



    我实在太菜了,这种问题都解决不了
    第 1 条附言  ·  2015-04-10 13:11:38 +08:00
    问题解决了。

    先贴上解决的代码:




    问题主要是因为我对RSA的理解错误。我以为RSA既能通过公钥加密然后私钥解密,可以反过来进行。正如1L,2L所说,这是不对的。

    但是RSA可以用公钥加密,然后再通过公钥来验秘。

    原理如下:


    之后有空的时候我会做一个nodejs的demo出来
    2 条回复    2015-04-10 07:25:48 +08:00
    lingxi27
        1
    lingxi27  
       2015-04-09 15:14:06 +08:00   ❤️ 1
    RSA有多种padding算法, 你试图解密使用的padding算法和加密的padding算法不一致

    你的库应该可以通过某个参数选择padding算法
    janxin
        2
    janxin  
       2015-04-10 07:25:48 +08:00   ❤️ 1
    RSA的基本概念要搞清楚,公钥用来加密,私钥用来解密
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5354 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 08:10 · PVG 16:10 · LAX 00:10 · JFK 03:10
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.