PayPal 国际支付接口安全可行性平台(电子商务)集成解决方案

news/2024/7/6 13:40:58 标签: 电子商务, 平台, payment, sandbox, input, website

IPN的原理很简单,就是当产生了一个交易之后,交易状态发生变化时,如用户已经付款、或者退款、撤销时,Paypal利用常用的HTTP POST方

式,将交易的一些变量提交给网站的某个页面(称之为IPN Handler),当这个页面接受到请求时候,将这些数据原封不动加上一个指示验证

的cmd=_notify-validate,POST回Paypal的接口地址,如果数据正确,那么Paypal返回字符串VERIFIED,否则为INVALID,如果结果为

VERIFIED,那么你的程序就可以使用这些数据进行操作。
但代码的调试是一件很痛苦的事情,因为作为第三方开发人员,不可能开两个帐号,每次测试还要之间交易一些钱,所以Paypal专门开发了

Sandbox给开发人员进行开发,首先到https://developer.paypal.com/ 注册一个开发帐号,好了之后再进入Sandbox建立测试用的Paypal虚拟

帐号(至少应该建立一个Business的和一个Personal的),这种账号注册方法和Paypal的流程一样,信息可以是假的,包括银行帐号、信用卡

(其实Paypal Sandbox会自动生成一些随机的号码)。接下来需要激活Paypal Sandbox的虚拟帐号,注意,这里不管你在Paypal Sanbox注册

时填什么邮件地址,有任何发送到虚拟帐号所填邮箱的邮件都存会在开发帐号的管理界面中的Email页(导航栏上有)中。登录Sandbox的虚拟

Paypal环境,还需要验证虚拟帐号的银行,这里可以随便填,然后通过Add Funds来给账户充值(想填多少填多少)

关于IPN的详细设置

登录至Paypal后台,进入My Account->Profile页面,点击Instant Payment Notification,如下图: 

然后就会出现下面的页面了,点击Edit按钮,如下图:

然后就会出现下面的页面了,在页面里面那个选框处打勾,并在下面的Notification URL 处填写:http://您的网站地址/index.php?gOo=cGF5cGFsX3JlcGx5LnBocA& 然后点击Save按钮,如下图:

然后页面就会提示你:“You have successfully activated Instant Payment Notification.”

接下来再次进入My Account->Profile页面,点击Website Payment Preferences ,如下图:


然后就会进入Website Payment Preferences页面,在里面要做四件事情:
1:Auto Return 后面打勾选择On
2:Return URL 后面输入:http://您的网站地址/index.php?gOo=cGF5cGFsX3JlcGx5X3JldHVybi5waHA&
3:Payment Data Transfer 后面打勾选择On
4:上面都做好之后,点击页面最下面的Save按钮
如下图:

保存之后页面立即跳转到My Account->Profile,并且提示您设置成功,里面还会有一串identity token号码,那个就是私钥,如下图:



当然,这个私钥(identity token)不会只出现这一次的,在您设置完之后,您可以仍然进入Website Payment Preferences页面去查看它,它就在Payment Data Transfer那一个区块,如下图:

接下来,我们测试的时候,应该将Paypal接口的地址设置为https://www.sandbox.paypal.com/cgi-bin/webscr
最后基本的流程为:

用户在我们的网站上选择商品、放入购物车,然后检查准备支付
网站根据购物车中的商品,生成Paypal的支付表单(也是提交到上面IPN用的Paypal接口地址),包含了此次交易的一些信息(下次会专门找

机会解释一下)。并在自己的数据库中生成一张订单记录。
Paypal在Session中记录下这些交易信息

用户用Paypal账户登录Paypal(Sandbox用Sandbox的虚拟帐号),复查明细,点击Pay按钮
Paypal进行交易处理,如果我们的Paypal收款帐号在接受帐款上没有什么问题(没有特别的需要Accept的地方),交易完成,那么Paypal会发

送一个IPN,并发送提示邮件。
我们IPN Handler接受到信息,首先向Paypal进行校验,如果信息正确,然后根据信息和自己数据库中进行比对,如果无误,可以将支付信息

保存,并修改订单状态。
然后Paypal会显示一个界面表示交易完成,此时如果用户点击“Return”按钮,Paypal会将用户送回我们网站指定地点。
我们网站迎接用户回来,向用户表示感谢,并进行提醒,给出订单号等等。

如果明文形式的话,就和压缩包里面的paypal.htm文件一般

<!--
第一个是模拟测试
https://www.sandbox.paypal.com/cgi-bin/webscr
第二个是真实的
https://www.paypal.com/cgi-bin/webscr
-->
<form target="paypal" action="https://www.sandbox.paypal.com/cgi-bin/webscr" method="post">
<input type="image" src="https://www.sandbox.paypal.com/en_US/i/logo/paypal_logo.gif" border="0" name="submit" alt="PayPal

is the safer, easier way to pay - PayPal">
<!--一次购买
<input type="hidden" name="add" value="1">-->
<!--这里是不用它集成的购物车,如果代码是 value="_cart"表示用paypal已经做好的购物车. -->
<input type="hidden" name="cmd" value="_xclick">
<!--卖家的PAYPAL帐户-->
<input type="hidden" name="business" value="Seller_1199323809_biz@126.com">
<!--这个是从我网站传递过来的商品名和订单号 -->
<input type="hidden" name="item_name" value="BoAo International Trading 20071212s1p1u1">
<input type="hidden" name="item_number" value="20071212s1p1u1">
<!--这个是价格,如何传递就不用说了吧~ -->
<input type="hidden" name="amount" value="15">
<!--商品数量 -->
<input type="hidden" name="quantity" value="1">
<!--货币类型 CNY:人民币,USD:美元-->
<input type="hidden" name="currency_code" value="USD">
<!--取消交易并要返回的位置-->
<input type="hidden" name="cancel_return" value=" http://www.hotweb.net.cn/?state=null">
<!--交易完后自动返回的位置-->
<input type="hidden" name="return" value="http://www.hotweb.net.cn/?state=OK">

<input type="hidden" name="no_shipping" value="1">
<input type="hidden" name="charset" value="UTF-8">
<input type="hidden" name="notify_url" value="http://www.hotweb.net.cn/?state=notify">
<input type="hidden" name="add" value="1">
<input type="hidden" name="no_note" value="1">
<input type="hidden" name="bn" value="PP-BuyNowBF">

</form>

--------------------

文件夹和文件的一些简要说明:[App_Code] 放了几个必要的类
[Bin]  存放了支付接口的解密加密的一个DLL文件
[EWPcert] 系统所需要用到的安全证书
CheckOut.aspx 相当于B2C网站的购物车,程序从这里开始
NotifyUrl.ashx 2次POST安全性验证页面,比较重要
PDTResponse.aspx用于返回信息的页面,我们可以通过这个页面来实现,吧交易的一系列信息存入自己的数据库用于验证用户是否已经支付

---------[App_Code]-----------
ButtonEncryption.cs  加密【CHECK OUT】按钮的密码字符串,相当于吧明文的一些基本参数直接加密了
Constants.cs  全局变量,用于存放一些PAYPAL设置的基础信息
NVPCodec.cs  代码转换
Utils.cs  用于安全验证时候用的

---------[EWPcert]-----------
sandbox_cert_pem.txt  PAYPAL的公共证书
sdk-ewp.p12  一个类似似有的证书吧,这个到不是很了解

至于其他的,请大家看程序吧

点击下载


http://www.niftyadmin.cn/n/1412531.html

相关文章

SPOJ Another Longest Increasing Subsequence Problem 三维最长链

SPOJ Another Longest Increasing Subsequence Problem 传送门&#xff1a;https://www.spoj.com/problems/LIS2/en/ 题意&#xff1a; 给定 N个数对 \((x_i,y_i)\)&#xff0c;求最长上升子序列的长度。上升序列定义为满足\((x_i,y_i)\)对i<j 有 \(x_i<x_j\) 且 \(y_i&l…

The Google File System论文理解

原文链接&#xff1a;http://nil.csail.mit.edu/6.824/2020/papers/gfs.pdf 目录 相关背景介绍 框架介绍 设计前提 动作接口 结构 Master作用介绍 ChunkSize设置问题 MetaData介绍 Operation Log和CheckPoint 一致性模型 系统交互 Lease and Mutation Order Reco…

Mysql客户端中文乱码问题解决

另一篇一样的&#xff1a; http://www.cnblogs.com/charlesblc/p/5973488.html 在Linux机器上使用Mysql客户端访问获取中文有时候是乱码&#xff0c;如下&#xff1a; mysql> select * from t_user; ---------------------------------------------------------------------…

[原创]JEECMS 自定义标签调用广告版位下的所有广告(利用广告管理管理首页幻灯片)...

转载&#xff1a;https://www.cnblogs.com/jifeng/p/4117709.html EECMS自带的只有[cms_advertising]标签&#xff0c;并且官方没有给文档&#xff0c;用法: [cms_advertising id3] <img src"${(tag_bean.attr.image_url)!?html}" width"${(tag…

分布式博主记录

最近在学习MIT6.824的时候自己对内容进行了一定的总结&#xff0c;在这个过程中也发现了很多别的写分布式内容的博主&#xff0c;参考了他们的系列文章&#xff0c;这里对他们的博客地址进行汇总&#xff0c;便于自己以及访客以后更好的学习分布式相关的内容 BrianLeeLXT - 博…

如何设置国际PayPal

Paypal有两种支付接口方式:Auto return和IPN方式. IPN方式通过服务器端直接提交信息的方式,最大限度的避免了由于用户中途关闭浏览器等引起的掉单但如果您是个人免费PAYPAL帐户,就只能使用Auto Return方式. IPN只对Business 或 Premier PayPal account开放 下面分别说一下两种支…

html 去掉input 获取焦点时的边框

html中&#xff0c;当input标签获取焦点的时候&#xff08;例如&#xff0c;当光标放在input框中准备输入值时&#xff09;&#xff0c; input标签外围会出现边框&#xff0c;有的时候我们需要去掉这个边框&#xff0c;可以使用css的outline:none;属性将其去掉, 只需要在为inpu…

vue源码分析系列:用sourcemap调试源码

参考连接 https://blog.csdn.net/a419419/article/details/91493026 关键操作 需在package.json 中的script dev 添加 "dev": "rollup -w -c scripts/config.js --environment TARGET:web-full-dev --sourcemap", 使用webpack--dev-server 搭建本地环境 安…