无法使用PayPal立即购买按钮在ASP.NET中的单个页面上工作

时间:2009-07-20 17:13:21

标签: asp.net paypal

我承认我是asp.net和网络表单的菜鸟。我遇到了在单个页面上加入一些PayPal“立即购买”按钮的问题。基本上,问题是无论点击哪个“立即购买”按钮,用户都会被Paypal购买由页面上最后一个按钮代表的产品。

我的第一个按钮的代码是这样的......

<input type="hidden" name="cmd" value="_s-xclick">
<input type="hidden" name="hosted_button_id" value="ABC123">
<asp:ImageButton runat="server" id="PPImageButton1" PostBackUrl="https://www.paypal.com/cgi-bin/webscr" ImageUrl="https://www.paypal.com/en_US/i/btn/btn_buynow_SM.gif"/>

我的第二个按钮类似于......

<input type="hidden" name="cmd" value="_s-xclick">
<input type="hidden" name="hosted_button_id" value="ABC456">
<asp:ImageButton runat="server" id="PPImageButton2" PostBackUrl="https://www.paypal.com/cgi-bin/webscr" ImageUrl="https://www.paypal.com/en_US/i/btn/btn_buynow_SM.gif"/>

如何让第一个按钮发送值ABC123到PayPal服务而不是ABC456?

提前致谢。

6 个答案:

答案 0 :(得分:1)

按钮的POST内容是围绕提交按钮的FORM标记中的每个输入。因此,要让每个按钮提交一组单独的隐藏字段,您需要以单独的形式包装按钮和所需的隐藏字段:

<form ... >
<input type="hidden" name="cmd" value="_s-xclick">
<input type="hidden" name="hosted_button_id" value="ABC123">
<asp:ImageButton runat="server" id="PPImageButton1" PostBackUrl="https://www.paypal.com/cgi-bin/webscr" ImageUrl="https://www.paypal.com/en_US/i/btn/btn_buynow_SM.gif"/>
</form>

<form ... >
<input type="hidden" name="cmd" value="_s-xclick">
<input type="hidden" name="hosted_button_id" value="ABC456">
<asp:ImageButton runat="server" id="PPImageButton1" PostBackUrl="https://www.paypal.com/cgi-bin/webscr" ImageUrl="https://www.paypal.com/en_US/i/btn/btn_buynow_SM.gif"/>
</form>

答案 1 :(得分:1)

我的noob解决方案是从aspx页面中删除每个立即购买按钮及其相关字段,并将每个集合放在一个单独的html页面中。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>first button</title>
</head>

<body>
<form action="https://www.paypal.com/cgi-bin/webscr" method="post" target="paypal">
<input type="hidden" value="_s-xclick" name="cmd" /> <input type="hidden" value="???????" name="hosted_button_id" /> 
<table>
<tbody>
<tr>
<td><input type="hidden" value="Member name" name="on0" />Member name</td>

<td><input maxlength="60" size="30" name="os0" /></td></tr>
<tr>
<td><input type="hidden" value="Membership No. (if known)" name="on1" />Membership No. (if known)</td>
<td><input maxlength="60" size="6" name="os1" /></td></tr></tbody></table>
<input type="image" alt="PayPal - The safer, easier way to pay online." src="https://www.paypal.com/en_GB/i/btn/btn_cart_LG.gif"  name="submit" /> <img height="1" alt="" src="https://www.paypal.com/en_GB/i/scr/pixel.gif" width="1" border="0"/> </form>

</body>
</html>

在aspx页面中删除按钮和其他字段的位置,插入一个指向html页面的iframe,如下所示:

<iframe width="600" height="" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="mybuttonpage1.htm"></iframe>

答案 2 :(得分:0)

这不是你的按钮发送值 - 它是它的形式,和/或它背后的代码。 你可以:

  1. 发布表单代码?
  2. 发布此页面的代码?

答案 3 :(得分:0)

以下是使用PayPal和ASP.NET时的多形式问题的解决方案:

http://www.codersbarn.com/post/2008/03/08/Solution-to-ASPNET-Form-PayPal-Problem.aspx

答案 4 :(得分:0)

我讨论了将PayPal代码插入ASP.NET页面的问题的几种解决方法,并在http://blackbeltcoder.com/Articles/ecommerce/quick-and-dirty-buy-now-buttons-in-asp-net的文章中提出了一种不同的方法。

最后,您不需要使用表单,因为PayPal允许您使用常规锚链接。

答案 5 :(得分:0)

我能够通过从jQuery中删除DOM中的所有其他按钮容器来实现它。在容器中添加一个类,并将一个CssClass添加到ImageButton,“PayPalImageButtons”

<div>
    Buy This First Product Below
</div>
<div class="ManualPurchase PayPalButtons">
    <input type="hidden" name="cmd" value="_s-xclick" />
    <input type="hidden" name="hosted_button_id" value="ABC123" />
    <asp:ImageButton CssClass="PayPalImageButtons" runat="server" id="PPImageButton1" PostBackUrl="https://www.paypal.com/cgi-bin/webscr" ImageUrl="https://www.paypal.com/en_US/i/btn/btn_buynow_SM.gif" />
</div>

<div>
    Buy This Second Product Below
</div>
<div class="ManualPurchase PayPalButtons">
    <input type="hidden" name="cmd" value="_s-xclick" />
    <input type="hidden" name="hosted_button_id" value="ABC456" />
    <asp:ImageButton CssClass="PayPalImageButtons" runat="server" id="PPImageButton1" PostBackUrl="https://www.paypal.com/cgi-bin/webscr" ImageUrl="https://www.paypal.com/en_US/i/btn/btn_buynow_SM.gif" />
</div>

和jQuery

<script type="text/javascript">
    function pageLoad() {
        $(".PayPalImageButtons").click(function (e) {
            $(this).parent().addClass("keep");
            $(".PayPalButtons").not(".keep").remove();
        });
    }
</script>

我的下一步是处理已删除的元素高度,并在加载PayPal页面时可能是一个Please Wait对话框