'The id provided does not exist razorpay in nodejs

i'm implementing razorpay payment gateway in my React.js app with backend nodejs.

here frontend.jsx

razorpayHandler = () =>{
        const payment_amount  = this.props.TotalPrice;
        const backend_url = 'https://25234399bb.ngrok.io';
        const self = this;
        const options = {
        key: config.RAZOR_PAY_KEY,
        amount: payment_amount * 100,
        name: 'StanPlus',
        description: 'pay your ambulance fare',
        handler(response) {
            const paymentId = response.razorpay_payment_id;
            const url =  backend_url+'/razorpay/'+paymentId+'/'+payment_amount+'/'+self.id;
            console.log(paymentId)
            // Using my server endpoints to capture the payment
            fetch(url, {
            method: 'get',
            headers: {
                "Content-type": "application/x-www-form-urlencoded; charset=UTF-8"
            }
            })
            .then(resp =>  resp.json())
            .then(function (data) {
                    console.log(data)
            })
            .catch(function (error) {
                console.log('Request failed', error);
            });
        },
        theme: {
            color: '#40A9FF',
        },
        };
        const rzp1 = new window.Razorpay(options);

        rzp1.open();
    }

backend.js(nodejs)

var express = require('express');
var router = express.Router();
var config = require('../config');

const Razorpay = require('razorpay');
const instance = new Razorpay({
  key_id: config.razorpay_live_key,
  key_secret: config.razorpay_live_secret,
});

router.get('/:payment_id/:amount/:BID',function(req,res,next){
    const {payment_id } = req.params;
    const {BID} = req.params;
    const amount = Number(req.params.amount*100);
    instance.payments.capture(payment_id, amount).then((data) => {
        data.Bid = BID;
        res.json(data);
    }).catch((error) => {
        res.json(error);
    });
})
module.exports = router;

it showing me error

"statusCode":400,"error":{"code":"BAD_REQUEST_ERROR","description":"The id provided does not exist"

but if the same code if do process using test key its getting successfully completed but it is not working with live api.
here i'm passing an extra parameter to the backend which required for us but if removed that parameter then also it is not working.but with parameter it is working with test api.
when we send request to backend it is generating id and sending to backend also but still it showing The id provided does not exist.



Solution 1:[1]

if you are using test mode then just remove order_id parameter from json object.

Solution 2:[2]

I also faced this error a week ago. This error arrived when we changed the test keys to the production keys for final payment to work.

So I faced this issue The id provided does not exist because of the mismatch of Razorpay Keys on the frontend and backend side(node.js side.)

So make sure you have the same client key and secret of the production environment on both backend and frontend side.

Let me know in comments if it still is not resolved.

Solution 3:[3]

  1. For Test Remove the OrderId from your options json data.
  2. For Live mode Pass the autogenerated Orderid From the user Control.

Solution 4:[4]

Removing order_id is not good practice we should follow documentation. To get order_id in React you have to first create a order in your backend eg(node.js). follow this steps to get order_id from Razorpay.

Step - 1

var instance = new Razorpay({  key_id: 'YOUR_KEY_ID',  key_secret: 'YOUR_KEY_SECRET'})

this will initiate new Razorpay object.

Step - 2

MyOrder = instance.orders.create({amount, currency, receipt, notes})

this will create an order for you and than you have access to order_id check your console for more options to get and finally you have to pass your order_id in your case you have to pass order_id in options.

Note : You can access order id like this MyOrder.id

for more information check official doc. https://razorpay.com/docs/payment-gateway/server-integration/nodejs/

you can find Razorpay SDKs for various Platform here https://razorpay.com/integrations/

Solution 5:[5]

If you are using for payments, than remove order_id from options JSON value.

 var options = {
        "key": "xxxxxxxxxxxxxxx", // Enter the Key ID generated from the Dashboard
        "amount": "50000", // Amount is in currency subunits. Default currency is INR. Hence, 50000 refers to 50000 paise
        "currency": "INR",
        "name": "Acme Corp",
        "description": "Test Transaction",
        "image": "https://example.com/your_logo",
        // "order_id": "order_9A33XWu170gUtm", //This is a sample Order ID. Pass the `id` obtained in the response of Step 1
        "handler": function (response){
            alert(response.razorpay_payment_id);
            alert(response.razorpay_order_id);
            alert(response.razorpay_signature)
        },
        "prefill": {
            "name": "Gaurav Kumar",
            "email": "[email protected]",
            "contact": "9999999999"
        },
        "notes": {
            "address": "Razorpay Corporate Office"
        },
        "theme": {
            "color": "#3399cc"
        }
    };

Solution 6:[6]

This error happens when you pass an incorrect order_id to trigger the payment modal. Basically an order_id that does not belong to your razorpay account, or an invalid one.

Example: if you generated an order_id with one set of credentials and use another set of credentials afterwards, this issue can happen.

Solution 7:[7]

I too faced the same problem while integrating Razorpay for subscription payments Initially, I passed order_id in the options param, which yielded the error -

{
  "code": "BAD_REQUEST_ERROR",
  "description": "The id provided does not exist",
  "source": "business",
  "step": "payment_initiation",
  "reason": "input_validation_failed",
  "metadata": {}
}

Hence replaced order_id with subscription_id.
Works now!

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 saigopi.me
Solution 2 hmharshit
Solution 3 Neetan Sharma
Solution 4
Solution 5 GRV PHP DEVLOPER
Solution 6 Expenzor
Solution 7 Ankit Kumar Mishra