paypal IPN返回
1.设定返回的地址
目标:登录paypal-->用户信息-->我的销售工具-->即时付款通知-->编辑并填写url
填写的URL必须为公网的,不能为局域网,要不就无法接收到paypal发送的信息
2.编写IPN.jsp (此代码为官方代码)
- //从 PayPal 出读取 POST 信息同时添加变量„cmd‟
- Enumeration en = request.getParameterNames();
- String str = "cmd=_notify-validate";
- while (en.hasMoreElements()) {
- String paramName = (String) en.nextElement();
- String paramValue = request.getParameter(paramName);
- str = str + "&" + paramName + "="
- + URLEncoder.encode(paramValue, "utf-8");
- //此处的编码一定要和自己的网站编码一致,不然会出现乱码,paypal回复的通知为‘INVALID’
- }
- System.out.println("paypal传递过来的交易信息:" + str);
- //建议在此将接受到的信息 str 记录到日志文件中以确认是否收到 IPN 信息
- //将信息 POST 回给 PayPal 进行验证
- //设置 HTTP 的头信息
- //在 Sandbox 情况下,设置:
- URL u = new URL("https://www.sandbox.paypal.com/cgi-bin/webscr");
- //正式环境
- // URL u = new URL("https://www.paypal.com/cgi-bin/webscr");
- URLConnection uc = u.openConnection();
- uc.setDoOutput(true);
- uc.setRequestProperty("Content-Type",
- "application/x-www-form-urlencoded");
- PrintWriter pw = new PrintWriter(uc.getOutputStream());
- pw.println(str);
- pw.close();
- //接受 PayPal 对 IPN 回发的回复信息
- BufferedReader in = new BufferedReader(new InputStreamReader(
- uc.getInputStream()));
- String res = in.readLine();
- in.close();
- //将 POST 信息分配给本地变量,可以根据您的需要添加
- //该付款明细所有变量可参考:
- //https://www.paypal.com/IntegrationCenter/ic_ipn-pdt-variable-reference.html
- String itemName = request.getParameter("item_name");//商品名
- String itemNumber = request.getParameter("item_number");//购买数量
- String paymentStatus = request.getParameter("payment_status");//交易状态
- String paymentDate = request.getParameter("payment_date");//交易时间
- String paymentAmount = request.getParameter("mc_gross");//交易钱数
- String paymentCurrency = request.getParameter("mc_currency");//货币种类
- String txnId = request.getParameter("txn_id");//交易id
- String receiverEmail = request.getParameter("receiver_email");//收款人email
- String payerEmail = request.getParameter("payer_email");//付款人email
- if (res == null || res == "")
- res = "0";
- //…
- //获取 PayPal 对回发信息的回复信息,判断刚才的通知是否为 PayPal 发出的
- if (res.equals("VERIFIED")) {
- //检查付款状态
- //检查 txn_id 是否已经处理过
- //检查 receiver_email 是否是您的 PayPal 账户中的 EMAIL 地址
- //检查付款金额和货币单位是否正确
- //处理其他数据,包括写数据库
- } else if (res.equals("INVALID")) {
- //非法信息,可以将此记录到您的日志文件中以备调查
- } else {
- //处理其他错误
- }
注意:paypal回复的通知为'VERIFIED',也不一定代表此次交易成功,要判断是否交易成功通过下面语句,判断交易状态是否成功。
- String paymentStatus = request.getParameter("payment_status");//交易状态 Completed 代表交易成功