Search code examples
phpformspayment-gatewayposting

PHP product listing page total amount to post to payment form


i am using a SIM API to run credit card payments through my site. Specifically Authorize.net

I have a one product with a product listing a quantity field and a purchase button.

I need the amount that posts to be updated if the customer changes the quantity.

Here is my code:

        <?php
// This sample code requires the mhash library for PHP versions older than
// 5.1.2 - http://hmhash.sourceforge.net/

// the parameters for the payment can be configured here
// the API Login ID and Transaction Key must be replaced with valid values
$loginID        = "0000000";
$transactionKey = "00000000000000";
$amount         = "3.99";
$description    = "This is a Sample Transaction";
$label          = "Purchase"; // The is the label on the 'submit' button
$testMode       = "false";
// By default, this sample code is designed to post to our test server for
// developer accounts: https://test.authorize.net/gateway/transact.dll
// for real accounts (even in test mode), please make sure that you are
// posting to: https://secure.authorize.net/gateway/transact.dll
$url            = "https://test.authorize.net/gateway/transact.dll";

// If an amount or description were posted to this page, the defaults are overidden
if (array_key_exists("amount",$_REQUEST))
    { $amount = $_REQUEST["amount"]; }
if (array_key_exists("amount",$_REQUEST))
    { $description = $_REQUEST["description"]; }

// an invoice is generated using the date and time
$invoice    = date(YmdHis);
// a sequence number is randomly generated
$sequence   = rand(1, 1000);
// a timestamp is generated
$timeStamp  = time();

// The following lines generate the SIM fingerprint.  PHP versions 5.1.2 and
// newer have the necessary hmac function built in.  For older versions, it
// will try to use the mhash library.
if( phpversion() >= '5.1.2' )
    { $fingerprint = hash_hmac("md5", $loginID . "^" . $sequence . "^" . $timeStamp . "^" . $amount . "^", $transactionKey); }
else 
    { $fingerprint = bin2hex(mhash(MHASH_MD5, $loginID . "^" . $sequence . "^" . $timeStamp . "^" . $amount . "^", $transactionKey)); }
?>

<!-- Print the Amount and Description to the screen. -->
Amount: <?php echo $amount; ?> <br />
Description: <?php echo $description; ?> <br />

<!-- Create the HTML form containing necessary SIM post values -->
 <FORM method='post' action='https://test.authorize.net/gateway/transact.dll' >
<!--  Additional fields can be added here as outlined in the SIM integration
 guide at: http://developer.authorize.net -->
    <input type='hidden' name='x_login' value='<?php echo $loginID; ?>' />
    <input type='hidden' name='x_amount' value='<?php echo $amount; ?>' />
    <input type='hidden' name='x_description' value='<?php echo $description; ?>' />
    <label>Quantity:</label><input type="text" name="quantity'" value="1" size="2" maxlength="3" />
    <input type='hidden' name='x_invoice_num' value='<?php echo $invoice; ?>' />
    <input type='hidden' name='x_fp_sequence' value='<?php echo $sequence; ?>' />
    <input type='hidden' name='x_fp_timestamp' value='<?php echo $timeStamp; ?>' />
    <input type='hidden' name='x_fp_hash' value='<?php echo $fingerprint; ?>' />
    <input type='hidden' name='x_test_request' value='<?php echo $testMode; ?>' />
    <input type='hidden' name='x_show_form' value='PAYMENT_FORM' />
    <input type="hidden" name="x_logo_URL" value="https://secure.authorize.net/mgraphics/logo_322583_1.jpg">
    <input type='submit' value='<?php echo $label; ?>' />
</form>

I am a beginner at php so any help understanding the would be appreciated. S=I have tried amount= 3.99 * 'quantity' and that did nothing.

Thanks. -Ann


Solution

  • I think you should give your form a name, and make Amount: <?php echo $amount; ?> into Amount: <span id='totalCost'>?php echo $amount; ?></span>

    then add this in the html head:

    <script type='text/javascript>
    function updateAmount(){
        var amount = document.formName.amount.value;
        var quantity = document.formName.quantity.value;
        var total = amount * quantity;
        document.getElementById("totalCost").value.write(total);
    }
    </script>
    

    and add an onChange param on your input form.

    <label>Quantity:</label><input type="text" name="quantity'" value="1" size="2" maxlength="3" onChange="updateAmount()"/>
    

    Hope that helps point you in the right direction.