Tuesday, 15 October 2019

razorpay payment gateway integration in asp.net c#

step 1 : login with razorpay account and get api key and secret.

it has given in setting menu .

step 2 :  download that code from given link

 https://github.com/razorpay/razorpay-dotnet-testapp


step 3: u can add dll from NuGet packages

step 4 : modify that code

on payment.aspx



           <form action="paymentresponse.aspx" method="post">
<script
    src="https://checkout.razorpay.com/v1/checkout.js"
    data-key="rzp_live_7LdgbZgdiDb1yh"
    data-amount="<%=amt%>"
    data-name="Razorpay"
    data-description="Fund"
    data-order_id="<%=orderId%>"
    data-image="https://razorpay.com/favicon.png"
    data-prefill.name="<%=name%>"
    data-prefill.email="<%=email%>"
    data-prefill.contact="<%=mobileno%>"
    data-theme.color="#F37254"
></script>
<input type="hidden" value="Hidden Element" name="hidden">

  <asp:Label ID="lbl1" runat="server"></asp:Label>

 </form>


on payment.aspx.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Razorpay.Api;
using System.Net;

public partial class payment : System.Web.UI.Page
{
    public string orderId;
    public string amt;
    public string name;
    public string email;
    public string mobileno;
    protected void Page_Load(object sender, EventArgs e)
    {
   
        ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;


        string key = "rzp_live_xxxxxxxxxxx";
        string secret = "6f84xxxxxxxxxxx";

        amt = "5000";  // its 500 bec it multiple by 100 by default so to make rs 500 u have to write 5000
        name = "text";
        email = "text@gmail.com";
        mobileno = "912345678";

        Dictionary<string, object> input = new Dictionary<string, object>();
        input.Add("amount", amt); // this amount should be same as transaction amount
        input.Add("currency", "INR");
        input.Add("receipt", "12121");
        input.Add("payment_capture", 1);

        RazorpayClient client = new RazorpayClient(key, secret);
     
        Razorpay.Api.Order order = client.Order.Create(input);
        string orderId = order["id"].ToString();

        lbl1.Text = orderId;
     
    }
}



step 5 : 

nothing will come on design page on charge.aspx 

on Charge.aspx.cs


using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Razorpay.Api;
using System.Net;

public partial class paymentresponse : System.Web.UI.Page
{
    MyDataClassesDataContext db = new MyDataClassesDataContext();

    protected void Page_Load(object sender, EventArgs e)
    {

        ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;

        string paymentId = Request.Form["razorpay_payment_id"];

        string key = "rzp_live_xxxxxxxxxxx";
        string secret = "6f84xxxxxxxxxxxxxxxxxxxxxxx";

   
         RazorpayClient client2 = new RazorpayClient(key, secret);
   
        Payment payment2 = client2.Payment.Fetch(paymentId);

        Dictionary<string, object> options = new Dictionary<string, object>();
        options.Add("amount", "100");

        Payment paymentCaptured = payment2.Capture(options);

        string amt = paymentCaptured.Attributes["amount"];

   
       // now u have amt


     
 

    }

}


 


Tuesday, 28 March 2017

QR Code in asp.net C# with google api

 try
        {
     

            var url = string.Format("https://chart.googleapis.com/chart?chs=250x250&cht=qr&chl=bi‌​tcoin:{0}amount={1}", mybitcoinaddress,myamount);
            WebResponse response = default(WebResponse);
            Stream remoteStream = default(Stream);
            StreamReader readStream = default(StreamReader);
            WebRequest request = WebRequest.Create(url);
            response = request.GetResponse();
            remoteStream = response.GetResponseStream();
            readStream = new StreamReader(remoteStream);

            System.Drawing.Image img = System.Drawing.Image.FromStream(remoteStream);
             System.Web.UI.WebControls.Image imgBarCode = new System.Web.UI.WebControls.Image();
             using (MemoryStream ms = new MemoryStream())
             {
                 img.Save(ms, System.Drawing.Imaging.ImageFormat.Png);
                 byte[] byteImage = ms.ToArray();
                 imgBarCode.ImageUrl = "data:image/png;base64," + Convert.ToBase64String(byteImage);
             }
             plBarCode.Controls.Add(imgBarCode);
             
            response.Close();
            remoteStream.Close();
            readStream.Close();
           
           
        }
        catch (Exception ex)
        {
        }

Friday, 10 March 2017

Thursday, 22 December 2016

Integrate Perfect Money in asp.net. , perfect money api integration in asp.net

download class file from give link
http://traininginjaipur.com/perfectmoneyclass.zip



  PerfectMoney obj = new PerfectMoney();

int paymentid= any random unique no ;


   Dictionary<string, string> results = obj.Transfer(PerfectMoneyAc, PerfectMoneyPwd, PerfectMoneyPayeerID,ReciverPayeerID, current_amt_in_doller, 1, paymentid);
                        if (results.Count > 0)
                        {
                            foreach (var i in results)
                            {
                                if (i.Key == "ERROR")
                                {
                                    f = 1;
                                    ScriptManager.RegisterStartupScript(this.Page, this.GetType(), "msg", "alert('" + i.Key + "," + i.Value + "');window.location='Account.aspx';", true);
                                }

                            }

                            if (f == 0)
                            {

                           
                                ScriptManager.RegisterStartupScript(this.Page, this.GetType(), "msg", "alert('Withdrawal successfull');window.location='ReturnfromPerfectMoney_Withdrawal_Yes.aspx?a=" + key + "';", true);
                            }
                        }

Integrate BitCoin in asp.net, BitCoin API in ASP.NET, bitcoin wallet integration in asp.net

download .dll files from given link
http://traininginjaipur.com/bitcoindll.zip


u have to specify  ont bitcoin wallet username and pwd , and then u have to provide receiver bitcoin account,

that code will transfer given bitcoin to one wallet to another wallet

using Info.Blockchain.API;
using Info.Blockchain.API.Receive;
using Info.Blockchain.API.Wallet;

  Wallet w = new Wallet("SenderBitCoinAc", "SenderBitCoinAcPwd");

  string reciverbitcoinadd = ".PayeerID";

  decimal amt = (decimal)(YourAmount);

  // this is to convert amt to bitcoin amt formate                
 decimal finalamt = amt * 100000000;

 PaymentResponse pr = w.Send(reciverbitcoinadd , Convert.ToInt64(finalamt));


Saturday, 17 December 2016

html code for full screen web page, show web page in full screen

<!DOCTYPE html>
<html>
<head>
</head>
<body>
    <div class="container">
        <section class="main-content">
             <button id="view-fullscreen">Practice</button>
            <script  >

                (function () {
                    var viewFullScreen = document.getElementById("view-fullscreen");
                    if (viewFullScreen) {
                        viewFullScreen.addEventListener("click", function () {
                            var docElm = document.documentElement;
                            if (docElm.requestFullscreen) {
                                docElm.requestFullscreen();
                            }
                            else if (docElm.mozRequestFullScreen) {
                                docElm.mozRequestFullScreen();
                            }
                            else if (docElm.webkitRequestFullScreen) {
                                docElm.webkitRequestFullScreen();
                            }
                        }, false);
                    }
                })();
            </script>
        </section>
    </div>
</body>
</html>

Monday, 28 November 2016

Integrate PayUMoney in ASP.Net,add PayUMoney in asp.net with c# ,PayUMoney asp.net C#

http://www.c-sharpcorner.com/uploadfile/c42694/integrate-payumoney-in-asp-net/



Or

Directly get values from db and send it to payumoney

**************************
 In Webconfig
*******************************

 <appSettings>
   
    <add key="MERCHANT_KEY" value="gtKFFx"/>
    <add key="SALT" value="eCwWELxi"/>
    <add key="PAYU_BASE_URL" value="https://test.payu.in"/>
    <add key="action" value=""/>
    <add key="hashSequence" value="key|txnid|amount|productinfo|firstname|email|udf1|udf2|udf3|udf4|udf5|udf6|udf7|udf8|udf9|udf10"/>
  </appSettings>

**************************
in C# Page
**************************

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Security.Cryptography;
using System.Configuration;
using System.Text;
using System.Data;
using DataLogicLayer;

public partial class paymentprocess : System.Web.UI.Page
{
    cls_connection con = new cls_connection();

    public string action1 = string.Empty;
    public string hash1 = string.Empty;
    public string txnid1 = string.Empty;

    protected void Page_Load(object sender, EventArgs e)
    {
        try
        {


            //set merchant key from web.config or AppSettings
            key.Value = ConfigurationManager.AppSettings["MERCHANT_KEY"];

       
            processnow();
        }
        catch (Exception ex)
        {
            Response.Write("<span style='color:red'>" + ex.Message + "</span>");

        }
    }



    /// <summary>
    /// Generate HASH for encrypt all parameter passing while transaction
    /// </summary>
    /// <param name="text"></param>
    /// <returns></returns>
    public string Generatehash512(string text)
    {

        byte[] message = Encoding.UTF8.GetBytes(text);

        UnicodeEncoding UE = new UnicodeEncoding();
        byte[] hashValue;
        SHA512Managed hashString = new SHA512Managed();
        string hex = "";
        hashValue = hashString.ComputeHash(message);
        foreach (byte x in hashValue)
        {
            hex += String.Format("{0:x2}", x);
        }
        return hex;

    }




    private  void processnow()
    {
        try
        {
            string qry;

            if (Request.QueryString["chkid"] != null)
            {
                qry = "select     a.NetAmount,b.Name,b.Email,b.MobileNo  from dbo.Checkout as a inner join dbo.RegistrationCustomer as b on a.CustomerId=b.CustomerId where a.checkoutid=" + Request.QueryString["chkid"].ToString() + " and a.CustomerId=" + Session["OwnerId"].ToString() + " ";
                DataSet ds = new DataSet();
                ds = con.select_data_ds(qry);

                string amountval = ds.Tables[0].Rows[0][0].ToString();
                string nameval = "israr";// ds.Tables[0].Rows[0][1].ToString();
                string emailval = ds.Tables[0].Rows[0][2].ToString();
                string mobileNoval = ds.Tables[0].Rows[0][3].ToString();

                string productinfo = "YourProductName";

                string successurl = "http://localhost:62991/payumoneysuccess.aspx";
                string failureurl = "http://localhost:62991/payumoneyfail.aspx";
                string cancelurl = "http://localhost:62991/payumoneycancel.aspx";

                string[] hashVarsSeq;
                string hash_string = string.Empty;


                if (string.IsNullOrEmpty(Request.Form["txnid"])) // generating txnid
                {
                    Random rnd = new Random();
                    string strHash = Generatehash512(rnd.ToString() + DateTime.Now);
                    txnid1 = strHash.ToString().Substring(0, 20);

                }
                else
                {
                    txnid1 = Request.Form["txnid"];
                }
                if (string.IsNullOrEmpty(Request.Form["hash"])) // generating hash value
                {
                    if (
                        string.IsNullOrEmpty(ConfigurationManager.AppSettings["MERCHANT_KEY"]) ||
                        string.IsNullOrEmpty(txnid1) ||
                        string.IsNullOrEmpty(amountval) ||
                        string.IsNullOrEmpty(nameval) ||
                        string.IsNullOrEmpty(emailval ) ||
                        string.IsNullOrEmpty(mobileNoval) ||
                        string.IsNullOrEmpty(productinfo) ||
                        string.IsNullOrEmpty(successurl) ||
                        string.IsNullOrEmpty(failureurl)
                        )
                    {
                        //error

                        frmError.Visible = true;
                        return;
                    }

                    else
                    {
                        frmError.Visible = false;
                        hashVarsSeq = ConfigurationManager.AppSettings["hashSequence"].Split('|'); // spliting hash sequence from config
                        hash_string = "";
                        foreach (string hash_var in hashVarsSeq)
                        {
                            if (hash_var == "key")
                            {
                                hash_string = hash_string + ConfigurationManager.AppSettings["MERCHANT_KEY"];
                                hash_string = hash_string + '|';
                            }
                            else if (hash_var == "txnid")
                            {
                                hash_string = hash_string + txnid1;
                                hash_string = hash_string + '|';
                            }
                            else if (hash_var == "amount")
                            {
                                hash_string = hash_string + Convert.ToDecimal(amountval).ToString("g29");
                                hash_string = hash_string + '|';
                            }
                            else if (hash_var == "productinfo")
                            {
                                hash_string = hash_string + productinfo;
                                hash_string = hash_string + '|';
                            }
                            else if (hash_var == "firstname")
                            {
                                hash_string = hash_string + nameval;
                                hash_string = hash_string + '|';
                            }
                            else if (hash_var == "email")
                            {
                                hash_string = hash_string + emailval;
                                hash_string = hash_string + '|';
                            }
                            else
                            {

                                hash_string = hash_string + (Request.Form[hash_var] != null ? Request.Form[hash_var] : "");// isset if else
                                hash_string = hash_string + '|';
                            }
                        }

                        hash_string += ConfigurationManager.AppSettings["SALT"];// appending SALT

                        hash1 = Generatehash512(hash_string).ToLower();         //generating hash
                        action1 = ConfigurationManager.AppSettings["PAYU_BASE_URL"] + "/_payment";// setting URL

                    }


                }

                else if (!string.IsNullOrEmpty(Request.Form["hash"]))
                {
                    hash1 = Request.Form["hash"];
                    action1 = ConfigurationManager.AppSettings["PAYU_BASE_URL"] + "/_payment";

                }




                if (!string.IsNullOrEmpty(hash1))
                {
                    hash.Value = hash1;
                    txnid.Value = txnid1;

                    System.Collections.Hashtable data = new System.Collections.Hashtable(); // adding values in gash table for data post
                    data.Add("hash", hash.Value);
                    data.Add("txnid", txnid.Value);
                    data.Add("key", key.Value);
                    string AmountForm = Convert.ToDecimal(amountval).ToString("g29");// eliminating trailing zeros
                    amount.Text = AmountForm;
                    data.Add("amount", AmountForm);
                    data.Add("firstname", nameval );
                    data.Add("email", emailval);
                    data.Add("phone",mobileNoval);
                    data.Add("productinfo", productinfo );
                    data.Add("surl", successurl );
                    data.Add("furl", failureurl);
                    data.Add("lastname", "");
                    data.Add("curl", cancelurl);
                    data.Add("address1", "");
                    data.Add("address2", "");
                    data.Add("city", "");
                    data.Add("state", "");
                    data.Add("country","");
                    data.Add("zipcode", "");
                    data.Add("udf1", "");
                    data.Add("udf2", "");
                    data.Add("udf3", "");
                    data.Add("udf4", "");
                    data.Add("udf5", "");
                    data.Add("pg", pg.Text.Trim());


                    string strForm = PreparePOSTForm(action1, data);
                    Page.Controls.Add(new LiteralControl(strForm));

                }

                else
                {
                    //no hash

                }
            }
        }

        catch (Exception ex)
        {
            Response.Write("<span style='color:red'>" + ex.Message + "</span>");

        }



    }
    private string PreparePOSTForm(string url, System.Collections.Hashtable data)      // post form
    {
        //Set a name for the form
        string formID = "PostForm";
        //Build the form using the specified data to be posted.
        StringBuilder strForm = new StringBuilder();
        strForm.Append("<form id=\"" + formID + "\" name=\"" +
                       formID + "\" action=\"" + url +
                       "\" method=\"POST\">");

        foreach (System.Collections.DictionaryEntry key in data)
        {

            strForm.Append("<input type=\"hidden\" name=\"" + key.Key +
                           "\" value=\"" + key.Value + "\">");
        }


        strForm.Append("</form>");
        //Build the JavaScript which will do the Posting operation.
        StringBuilder strScript = new StringBuilder();
        strScript.Append("<script language='javascript'>");
        strScript.Append("var v" + formID + " = document." +
                         formID + ";");
        strScript.Append("v" + formID + ".submit();");
        strScript.Append("</script>");
        //Return the form and the script concatenated.
        //(The order is important, Form then JavaScript)
        return strForm.ToString() + strScript.ToString();
    }

}



*******************************
On Sucess page
******************************

using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Security.Cryptography;
using System.Text;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace PayUDemo
{
    public partial class payumoneysuccess: System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            try
            {

                string[] merc_hash_vars_seq;
                string merc_hash_string = string.Empty;
                string merc_hash = string.Empty;
                string order_id = string.Empty;
                string hash_seq = "key|txnid|amount|productinfo|firstname|email|udf1|udf2|udf3|udf4|udf5|udf6|udf7|udf8|udf9|udf10";

                if (Request.Form["status"] == "success")
                {

                    merc_hash_vars_seq = hash_seq.Split('|');
                    Array.Reverse(merc_hash_vars_seq);
                    merc_hash_string = ConfigurationManager.AppSettings["SALT"] + "|" + Request.Form["status"];


                    foreach (string merc_hash_var in merc_hash_vars_seq)
                    {
                        merc_hash_string += "|";
                        merc_hash_string = merc_hash_string + (Request.Form[merc_hash_var] != null ? Request.Form[merc_hash_var] : "");

                    }
                    merc_hash = Generatehash512(merc_hash_string).ToLower();



                    if (merc_hash != Request.Form["hash"])
                    {
                        //Value didn't match that means some paramter value change between transaction
                        Response.Write("Hash value did not matched");

                    }
                    else
                    {
                        //if hash value match for before transaction data and after transaction data
                        //that means success full transaction  , see more in response
                        order_id = Request.Form["txnid"];

                        Response.Write("value matched");

                        //Hash value did not matched
                    }

                }

                else
                {

                    Response.Write("Hash value did not matched");
                    // osc_redirect(osc_href_link(FILENAME_CHECKOUT, 'payment' , 'SSL', null, null,true));

                }
            }

            catch (Exception ex)
            {
                Response.Write("<span style='color:red'>" + ex.Message + "</span>");

            }
        }
        /// <summary>
        /// Generate HASH for encrypt all parameter passing while transaction
        /// </summary>
        /// <param name="text"></param>
        /// <returns></returns>
        public string Generatehash512(string text)
        {

            byte[] message = Encoding.UTF8.GetBytes(text);

            UnicodeEncoding UE = new UnicodeEncoding();
            byte[] hashValue;
            SHA512Managed hashString = new SHA512Managed();
            string hex = "";
            hashValue = hashString.ComputeHash(message);
            foreach (byte x in hashValue)
            {
                hex += String.Format("{0:x2}", x);
            }
            return hex;

        }




    }

}