Я постараюсь перейти прямо к делу. В настоящее время я работаю с PayPal IPN и никогда раньше не сталкивался с этой проблемой. Я использовал PayPal IPN, и мои реализации всегда были одинаковыми. Однако на этот раз он дает очень странные результаты.
В настоящее время я размещаюсь на WinHost.com
Используемый код:
public void MakeHttpPost()
{
ErrorLog log = new ErrorLog();
//Post back to either sandbox or live
string strSandbox = "https://www.sandbox.paypal.com/cgi-bin/webscr";
string strLive = "https://www.paypal.com/cgi-bin/webscr";
HttpWebRequest req = (HttpWebRequest)WebRequest.Create(strSandbox);
//Set values for the request back
req.Method = "POST";
req.ContentType = "application/x-www-form-urlencoded";
byte[] param = HttpContext.Current.Request.BinaryRead(HttpContext.Current.Request.ContentLength);
string strRequest = Encoding.ASCII.GetString(param);
strRequest += "&cmd=_notify-validate";
req.ContentLength = strRequest.Length;
//for proxy
//WebProxy proxy = new WebProxy(new Uri("http://url:port#"));
//req.Proxy = proxy;
//Send the request to PayPal and get the response
StreamWriter streamOut = new StreamWriter(req.GetRequestStream(), System.Text.Encoding.ASCII);
streamOut.Write(strRequest);
streamOut.Close();
StreamReader streamIn = new StreamReader(req.GetResponse().GetResponseStream());
string strResponse = streamIn.ReadToEnd();
streamIn.Close();
log.error = strResponse;
log.Insert();
if (strResponse == "VERIFIED")
{
PaypalPaymentHistory PPH = new PaypalPaymentHistory();
PPH.LastName = HttpContext.Current.Request["last_name"];
PPH.FirstName = HttpContext.Current.Request["first_name"];
PPH.State = HttpContext.Current.Request["address_state"];
PPH.Zipcode = HttpContext.Current.Request["address_zip"];
PPH.Address = HttpContext.Current.Request["address_street"];
PPH.UserName = HttpContext.Current.Request["option_name2"];
PPH.PaymentStatus = HttpContext.Current.Request["payment_status"];
PPH.SelectedPackage = HttpContext.Current.Request["option_selection1"];
PPH.PayerStatus = HttpContext.Current.Request["payer_status"];
PPH.PaymentType = HttpContext.Current.Request["payment_type"];
PPH.PayerEmail = HttpContext.Current.Request["payer_email"];
PPH.ReceiverId = HttpContext.Current.Request["receiver_id"];
PPH.TxnType = HttpContext.Current.Request["txn_type"];
PPH.PaymentGross = HttpContext.Current.Request["payment_gross"];
PPH.Insert();
}
else if (strResponse == "INVALID")
{
//log for manual investigation
}
else
{
//log response/ipn data for manual investigation
}
}
Идея заключается в том, что я проверю состояние заказа, а затем вставлю или не вставлю запись в базу данных, но этот код все еще находится в тестах, поэтому ничего не является официальным.
Проблема, с которой я сталкиваюсь, заключается в том, что при запуске через песочницу и осуществлении платежа через мой сайт PayPal отправляет запрос IPN. Запись попадает в базу данных, и все данные отправляются обратно правильно, однако PayPal показывает, что сообщение IPN «Сбой» и всегда застревает на «Повторная попытка». Однако я получаю «ПРОВЕРЕНО» обратно в strResponse. Это, в свою очередь, вызывает до 8 записей за транзакцию. Ошибка, о которой сообщает PayPal: 500 - Внутренняя ошибка сервера. Любая помощь будет безумно цениться, так как до этого момента это был двухдневный марафон по головокружению!
Спасибо за любую помощь или решения!
P.S. Я прочитал почти каждый вопрос IPN о стеке потока и ничего подобного не видел.