html5数字输入类型步骤属性乘以数字100

时间:2017-06-19 15:51:58

标签: php mysql html5

以下是简单的代码:

 Amount: <input type='number' step="0.01" min="1" max="500" name='pr_amount' id='pr_amount' /><br>

此表单是使用PHP在MYSQL数据库中插入数据。 INPUT 1.50输出数据库150.00

如何解决这个问题?我需要在php编码部分使用$ pr_amount / 100类型的代码,还是有其他方法。没有步骤=&#34; 0.01&#34;它没有取小数点或美元的分值。

PHP部分: payment.inc.php

      if (isset($_POST['pr_amount'], $_POST['pr_processor'],$_POST['pr_comment'])) {
// Sanitize and validate the data passed in
$pr_amount = filter_input(INPUT_POST, 'pr_amount', FILTER_SANITIZE_NUMBER_FLOAT);
$pr_processor = filter_input(INPUT_POST, 'pr_processor', FILTER_SANITIZE_STRING);
$pr_comment = filter_input(INPUT_POST, 'pr_comment', FILTER_SANITIZE_STRING);
$user_id = htmlentities($_SESSION['user_id']);

// for checking minimum payout allowed
         if ($pr_amount < 1) {
    // If it's not, something really odd has happened
    $error_msg_payout .= '<p class="error">Minimum Payout is $1.00, for INR withdraw Minimum payout is Rs.100</p>';
}
   if(empty($pr_amount || $pr_comment)) {
  $error_msg_payout .= '<p class="error">User must input all field</p>';
   }

// checking if pr amount is above the available balance
$stmt_balance = $mysqli->prepare("SELECT current_balance FROM client WHERE user_id = ?");
$stmt_balance->bind_param('i', $user_id);
    $stmt_balance->execute();
    $stmt_balance->store_result();
if($stmt_balance < $pr_amount){
    // If it's not, something really odd has happened
    $error_msg_payout .= '<p class="error">Payment request amount is greater than the available balance.</p>';
}
 $stmt_balance->close();

//-------For checking pr comment validity
     if (strlen($pr_comment) > 150) {
    // If it's not, something really odd has happened
    $error_msg_payout .= '<p class="error">Payment instruction should be within 150 charecters</p>';
}
if (!ctype_alpha(str_replace(' ', '',$pr_comment))) {
$error_msg_payout .= '<p class="error">Payment Instruction Include disallowed charecters</p>';
}

if (empty($error_msg_payout)) {

    // Insert the new account into the database 
    if ($insert_stmt_payout = $mysqli->prepare("INSERT INTO payment (user_id,pr_amount,pr_comment,pr_processor) 
SELECT ?, ?, ?, pr_processor FROM paymentlist WHERE pr_processor = ?")) {
        $insert_stmt_payout->bind_param('idss', $user_id,$pr_amount,$pr_comment,$pr_processor);
        // Execute the prepared query.
        if (! $insert_stmt_payout->execute()) {
            header('Location: ../error.php?err=AddPayment failure: INSERT');
            exit();
        }
    }
    //---deducting balance after succesful request       
    $stmt_deduct = $mysqli->prepare("UPDATE client SET current_balance = (current_balance-?) WHERE user_id = ?");
    $stmt_deduct->bind_param('di', $pr_amount,$user_id);
    $stmt_deduct->execute();
    if (! $stmt_deduct->execute()) {
            header('Location: ../error.php?err=AddPayment failure: INSERT AMOUNT');
            exit();
        }
        $stmt_deduct->close();          
    header('Location: ./payment.php');
    exit();
}

}

HTML PART: payment.php

<form method="post" name="payment_request" action="<?php echo esc_url($_SERVER['PHP_SELF']); ?>">
        Add Request:
        <?php
         $stmt = $mysqli->prepare('SELECT pr_processor FROM paymentlist '); 
         $stmt->execute();    // Execute the prepared query.
         $stmt->bind_result($pr_processor);
         $stmt->store_result();
         echo "<select name='pr_processor'>";
         while($stmt->fetch()) {
         echo "<option value='" . $pr_processor . "'>" . $pr_processor . "</option>";
          }
         $stmt->close();
         echo "</select>";
         ?> <br>
         Amount: <input type='number' min="1" max="500" name='pr_amount' id='pr_amount' step='0.01' value='0.00' placeholder='0.00' /><br>
          Payment Instruction: <input type='text' name='pr_comment' id='pr_comment' /><br>
          <input type="submit" value="Add Payout Request" name="addpayment" />
    </form>

注意:如果我不使用step,那么只需输入整数和输出即可。但是我要求输入带有小数点的货币值。

2 个答案:

答案 0 :(得分:2)

我在https://www.w3schools.com/html/tryit.asp?filename=tryhtml_input_number上运行了您的html代码,并在提交数据后显示正确的数字值。

您是否在将$ pr_amount添加到数据库之前处理它。请发布您的php文件的完整内容。

答案 1 :(得分:1)

试试这个

<input type='number' min="1" max="500" name='pr_amount' id='pr_amount' step='0.01' value='0.00' placeholder='0.00' />