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.htmlString 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");//交易idString receiverEmail = request.getParameter("receiver_email");//收款人emailString payerEmail = request.getParameter("payer_email");//付款人emailif (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 代表交易成功