2010-05-14 20 views
92

Tengo problemas para elegir entre la Notificación de pago instantánea (IPN) y la Transferencia de datos de pago (PDT) de PayPal.IPN contra PDT en Paypal

Básicamente, los usuarios compran un producto único en mi sitio, pagan en PayPal y vuelven a mi sitio. Entiendo cómo funciona IPN, pero ahora veo que podría desencadenar las diversas acciones que ocurren después de una compra exitosa más fácilmente con PDT, ya que los datos se devuelven allí y en ese momento (en lugar de necesitar un oyente por separado) .

Sin embargo, la documentación de PDT de PayPal contiene esta críptica línea: "PDT no está destinado a ser utilizado con tarjetas de crédito o transacciones de Express Checkout". ... pero no puedo encontrar nada más sobre el tema.

  1. ¿Las tarjetas de crédito REALMENTE no están destinadas a ser utilizadas con PDT? Me gustaría más que una oración.

  2. ¿Eso significa que un usuario debe tener/crear una cuenta de PayPal para pagar?

  3. ¿Significa que si quiero permitir que los usuarios paguen con sus cuentas de PayPal Y/O con tarjetas de crédito directamente, debo implementar IPN?

¿Alguien que haya pasado por esto amablemente arrojará algo de luz?

+0

Encontré una página web que realmente explica esto mejor. [PayPal IPN y PDT:? ¿Cómo funciona] [1] [1]: http://webmasters.stackexchange.com/questions/21634/paypal-pdt-and-ipn-how -does-it-work –

+0

En cuanto a la pregunta 2, hay una configuración 'Cuenta de PayPal opcional' en' Mis preferencias de venta> Preferencias del sitio web' que puede activar para no obligar a los clientes a crear/tener una cuenta de PayPal, es decir. pagar con tarjeta de crédito/débito. – kaiyaq

Respuesta

108

Las API para PDT e IPN son similares. La principal diferencia es cuando recibes la notificación. Por esa razón, recomendaría implementar ambos.

  • Con PDT recibe la notificación al instante y puede hacer cualquier procesamiento adicional requerido y mostrar al usuario una página de confirmación.
  • Con IPN, se garantiza que se le notificará que el pago se recibió incluso si la computadora del usuario explota antes de que pueda enviarle el PDT.

Implementa ambos y obtén lo mejor de ambos mundos. Pero si solo está haciendo uno, IPN es confiable.

Una pega: si implementa ambos, existe la posibilidad de que sus pagos se procesen dos veces. Asegúrese de que eso no ocurra. La aplicación que escribí maneja el PDT y el IPN de forma casi idéntica (la parte de fondo es la misma) y ese código adquiere un bloqueo por usuario web en la base de datos, de modo que si el mismo usuario intenta enviar el mismo pago varias veces, solo se puede procesar una vez Una vez procesado, el resultado de ese proceso se reutiliza para cualquier intento posterior de procesarlo.

Editar Una cosa más: IPN lleva más información que la PDT. Hay muchos mensajes diferentes que puede recibir de IPN, como notificación de devolución de cargo, etc., y por lo tanto, debería implementarlo.


sistema PDT de PayPal envía confirmaciones de pedidos con sitios comerciales que utilizan PayPal Pago estándar y permite que las autentican esta información. Dichos sitios pueden mostrar estos datos localmente en una página de "confirmación de pedido".

Cuándo se usa PDT?

IPN proporciona las mismas capacidades descritas anteriormente. Entonces, ¿cuándo debería elegir PDT en lugar de IPN?

Con PDT, su sitio es notificado inmediatamente cuando un cliente realiza el pago. Con IPN, sin embargo, hay un retraso material entre el momento en que un cliente completa el pago y el momento en que su sitio recibe la notificación de este evento.

Por lo tanto, el uso de la TFD si su sitio incluye una función que requiere notificación de pago inmediato.

Por ejemplo, considere una tienda de música digital. Con PDT, esta tienda puede permitir a los clientes descargar sus compras de inmediato, ya que PDT envía confirmaciones de pedidos de inmediato. Con IPN, tal cumplimiento inmediato de orden no es posible.

Ventajas del IPN

PDT tiene un una gran debilidad: envía confirmaciones de pedido una vez y sólo una vez. Como resultado, cuando PDT envía una confirmación, su sitio debe estar ejecutándose; de lo contrario, nunca recibirá el mensaje.

Con IPN, por el contrario, la entrega de confirmaciones de pedidos está prácticamente garantizada desde IPN vuelve a enviar una confirmación hasta que su sitio acusa recibo. Por esta razón, PayPal recomienda que implemente IPN en lugar de PDT.

Otra ventaja del IPN es que envía muchos tipos de notificaciones, mientras que sólo PDT envía confirmaciones de pedido. Por lo tanto, al usar IPN, su sitio puede recibir, por ejemplo, notificaciones de devolución de cargo y confirmaciones de pedidos. Nota: Si su sitio debe ser notificado de pagos de inmediato, puede implementar tanto IPN como PDT. Sin embargo, si lo hace, su sitio recibirá dos confirmaciones de pedidos por cada venta. Como resultado, debe tener cuidado de actuar (por ejemplo, enviar un producto) en una sola copia de un mensaje de confirmación determinado.

Documentation Here

+2

Gracias, ya veo.Básicamente, vincula las actualizaciones de la base de datos al IPN (ya que siempre se procesará) y vincula las confirmaciones del usuario solo a PDT (por ejemplo, verifica si el IPN procesó el pago en una página pendiente) ....? – Tom

+1

+1 para implementar tanto IPN como PDT, lo hemos hecho y funciona bien. –

+3

@Tom: mi implementación es: cuando aparece una PDT o una IPN, lea los parámetros y trate de procesar el pago. El procesador A) bloquea otro procesamiento simultáneo (para ese usuario) y B) comprueba si ya se ha procesado. Una vez finalizado el procesamiento, con la IPN terminada, con PDT muestra al usuario una página de confirmación o recibo o lo que sea. Tanto el lado de PDT como el lado de IPN pueden funcionar correctamente si el otro lado está abajo, pero se obtiene una buena confiabilidad al tener ambos. Un porcentaje bastante alto de usuarios no hace clic antes de que llegue el IPN. –

0

Re 1. PDT está destinado para su uso con retroceso automático para la función de Pagos en el sitio. Auto Return redirecciona al sitio PDT después de pagarle dinero al vendedor. Lamentablemente, no es posible utilizar esa función junto con la cuenta de PayPal opcional: se usa para habilitar el pago con tarjeta de crédito. Aquí hay una nota de PayPal: 'Si ha activado Auto Return y ha optado por activar la cuenta de PayPal Opcional para usuarios nuevos, un nuevo usuario no será redirigido automáticamente a su sitio web, pero se le dará la opción de regresar'. El usuario tendrá la opción de volver a su sitio (paso PDT) o permanecer en el sitio de PayPal. Para resumir cuando se paga con tarjeta de crédito, el usuario puede omitir el paso PDT si el usuario no hace clic en "regresar al enlace de la tienda".

respecto a 2. Corresponde a lo que pagan opciones hacen que desea permitir. Si desea permitir el pago sin una cuenta de PayPal, puede habilitar Account Optional. Si desea permitir que solo los usuarios con cuentas de PayPal deshabiliten esa función. Puede haber más opciones.

Re 3. En el caso de que necesite para desencadenar la acción después de la compra con éxito. La forma recomendada sería implementar IPN. PDT no funciona en todos los casos y no garantiza la entrega de mensajes. Aquí hay un enlace al doc que cubre ese tema PDT vs IPN.

Cuestiones relacionadas