Chat Application With ASP.NET MVC Using RabbitMQ
In this article, you will learn how to develop a chat application in ASP.NET MVC using RabbitMQ. First, you need to download RabbitMQ and OTP.
Step 1: RabbitMQ
https://www.rabbitmq.com/download.html
data:image/s3,"s3://crabby-images/b2cd1/b2cd136870ae601a1e1b8cc942f2999c056dba6f" alt=""
Step 2: OTP
http://www.erlang.org/downloads
data:image/s3,"s3://crabby-images/12af8/12af8a4dfa739763b34bfee2c21d04c3b2585364" alt=""
Create a new MVC project.
Step 3: Open Visual Studio
data:image/s3,"s3://crabby-images/95a57/95a57d2c319723a2b63134689d4174d4bb535d8c" alt=""
Go to File menu and select New Project->Web application->MVC.
data:image/s3,"s3://crabby-images/dc512/dc512305e68e1ac9a42d8cd4976b8286e14ccdd6" alt=""
From New Project, select ASP.NET Web Application and click OK.
data:image/s3,"s3://crabby-images/45633/45633608faa6f58d399beda3d0458fd4850ce6b5" alt=""
Select MVC and click OK.
data:image/s3,"s3://crabby-images/31b45/31b458d55636ed602031033ad392889abac3a054" alt=""
In Visual Studio, the folder structure is shown as below in the Solution Explorer for the chat application.
data:image/s3,"s3://crabby-images/3ba15/3ba15abc4b018e31749cc191141b3893828f91ee" alt=""
Right-click on Project and select “Manage NuGet Packages..”.
data:image/s3,"s3://crabby-images/02658/0265839a0e1305ffe73cc9e292cc2ed3dffb8aa2" alt=""
Search Rabbitmq and install the rabbitmq.client package.
data:image/s3,"s3://crabby-images/59aa8/59aa8e13215407f08cecaf574e4cf03752813277" alt=""
Adding new HomeController
Right-click on Controllers folder, click Add >> Controller.
data:image/s3,"s3://crabby-images/0af75/0af750caaaf0ed1c9dfba4bf4c2c5da2924eed90" alt=""
Once the user selects the controller, the “Add Scaffold” dialog gets opened. Select MVC 5 Controller – Empty and click “Add” button.
data:image/s3,"s3://crabby-images/dfcc7/dfcc785171ec39cec730d5a417720c474cdfa33d" alt=""
Give Controller a name (HomeController) and click “Add”.
data:image/s3,"s3://crabby-images/57c6d/57c6d99ee4bfd93f6fec50ee21b9ab0d101fcf0c" alt=""
Once the user clicks on Add button, the Workspace will be opened to write the code.
data:image/s3,"s3://crabby-images/ef37a/ef37ae492efaaa7f1759a295a78254118dff035b" alt=""
Paste the below code in HomeController.
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using RabbitMQ.Client;
- using RabbitMQ.Util;
- using System.Web.Mvc;
- using ChatApplication.Models.HelperBll;
- using System.Web.UI.WebControls;
- namespace ChatApplication.Controllers
- {
- public class HomeController : Controller
- {
- DataLayer dl = new DataLayer();
- // GET: Home
- public ActionResult Index()
- {
- if (Session[“userid”]==null)
- {
- return RedirectToAction(“login”);
- }
- else
- {
- return View();
- }
- }
- [HttpPost]
- public JsonResult sendmsg(string message,string friend)
- {
- RabbitMQBll obj = new RabbitMQBll();
- IConnection con = obj.GetConnection();
- bool flag = obj.send(con, message,friend);
- return Json(null);
- }
- [HttpPost]
- public JsonResult receive()
- {
- try
- {
- RabbitMQBll obj = new RabbitMQBll();
- IConnection con = obj.GetConnection();
- string userqueue = Session[“username”].ToString();
- string message = obj.receive(con, userqueue);
- return Json(message);
- }
- catch (Exception)
- {
- return null;
- }
- }
- public ActionResult login()
- {
- return View();
- }
- [HttpPost]
- public ActionResult login(FormCollection fc)
- {
- string email = fc[“txtemail”].ToString();
- string password = fc[“txtpassword”].ToString();
- UserModel user = dl.login(email, password);
- if (user.userid > 0)
- {
- ViewData[“status”] = 1;
- ViewData[“msg”] = “login Successful…”;
- Session[“username”] = user.email;
- Session[“userid”] = user.userid.ToString();
- return RedirectToAction(“Index”);
- }
- else
- {
- ViewData[“status”] = 2;
- ViewData[“msg”] = “invalid Email or Password…”;
- return View();
- }
- }
- [HttpPost]
- public JsonResult friendlist()
- {
- int id = Convert.ToInt32(Session[“userid”].ToString());
- List<UserModel> users = dl.getusers(id);
- List<ListItem> userlist = new List<ListItem>();
- foreach (var item in users)
- {
- userlist.Add(new ListItem
- {
- Value = item.email.ToString(),
- Text = item.email.ToString()
- });
- }
- return Json(userlist);
- }
- }
- }
Create a table in the database (PostgreSQL).
Below is the query to create a table.
- CREATE TABLE public.tbluser(userid integer NOT NULL DEFAULT nextval(‘tbluser_userid_seq’::regclass), email text COLLATE pg_catalog.
- “default”
- NOT NULL, mobile text COLLATE pg_catalog.
- “default”
- NOT NULL, password text COLLATE pg_catalog.
- “default”
- NOT NULL, dob date NOT NULL, CONSTRAINT tbluser_pkey PRIMARY KEY(userid))
data:image/s3,"s3://crabby-images/2ea11/2ea11bd39270cb291fd206750e0d46091f380ea0" alt=""
Insert the connection string in web.config file in ASP.NET.
data:image/s3,"s3://crabby-images/3a2e9/3a2e9db6ff6be62940682aee99440be3748683fd" alt=""
Create a User Model in the Models folder. Right-click on Models folder -> click Add -> select Class.
data:image/s3,"s3://crabby-images/8ddf7/8ddf7cd4fda75dcb0941a96a4cc080181f31db66" alt=""
data:image/s3,"s3://crabby-images/fbab1/fbab1179dc59a1062be30d2bc745955032857176" alt=""
data:image/s3,"s3://crabby-images/1a35d/1a35d8986f38e97afa53ef6b735918108a7cf123" alt=""
Paste the below code in UserModel.
- public class UserModel
- {
- public int userid { get; set; }
- [Required(ErrorMessage =”Email id Is required”)]
- public string email { get; set; }
- [Required(ErrorMessage = “Mobile Number Is required”)]
- public string mobile { get; set; }
- [Required(ErrorMessage = “Password Is required”)]
- public string password { get; set; }
- [Required(ErrorMessage = “Confirm Password Is required”)]
- [Compare(“password”, ErrorMessage = “Password and Confirmation Password must match.”)]
- public string confirmpassword { get; set; }
- [Required(ErrorMessage = “Date Of Birth Is required”)]
- public string dob { get; set; }
- }
Create a class Datalayer.cs and paste it.
Right-click on Models folder ->click Add-> select Class.
data:image/s3,"s3://crabby-images/e15be/e15be691d54fc842d71a2feb76200ab6e152a861" alt=""
Paste the below code in DataLayer.cs.
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using RabbitMQ.Client;
- using RabbitMQ.Util;
- using System.Web.Mvc;
- using ChatApplication.Models.HelperBll;
- using System.Web.UI.WebControls;
- namespace ChatApplication.Controllers
- {
- public class HomeController : Controller
- {
- DataLayer dl = new DataLayer();
- // GET: Home
- public ActionResult Index()
- {
- if (Session[“userid”]==null)
- {
- return RedirectToAction(“login”);
- }
- else
- {
- return View();
- }
- }
- [HttpPost]
- public JsonResult sendmsg(string message,string friend)
- {
- RabbitMQBll obj = new RabbitMQBll();
- IConnection con = obj.GetConnection();
- bool flag = obj.send(con, message,friend);
- return Json(null);
- }
- [HttpPost]
- public JsonResult receive()
- {
- try
- {
- RabbitMQBll obj = new RabbitMQBll();
- IConnection con = obj.GetConnection();
- string userqueue = Session[“username”].ToString();
- string message = obj.receive(con, userqueue);
- return Json(message);
- }
- catch (Exception)
- {
- return null;
- }
- }
- public ActionResult login()
- {
- return View();
- }
- [HttpPost]
- public ActionResult login(FormCollection fc)
- {
- string email = fc[“txtemail”].ToString();
- string password = fc[“txtpassword”].ToString();
- UserModel user = dl.login(email, password);
- if (user.userid > 0)
- {
- ViewData[“status”] = 1;
- ViewData[“msg”] = “login Successful…”;
- Session[“username”] = user.email;
- Session[“userid”] = user.userid.ToString();
- return RedirectToAction(“Index”);
- }
- else
- {
- ViewData[“status”] = 2;
- ViewData[“msg”] = “invalid Email or Password…”;
- return View();
- }
- }
- [HttpPost]
- public JsonResult friendlist()
- {
- int id = Convert.ToInt32(Session[“userid”].ToString());
- List<UserModel> users = dl.getusers(id);
- List<ListItem> userlist = new List<ListItem>();
- foreach (var item in users)
- {
- userlist.Add(new ListItem
- {
- Value = item.email.ToString(),
- Text = item.email.ToString()
- });
- }
- return Json(userlist);
- }
- }
- }
Create a class RabbitMQBll.cs to handle the Rabbitmq operations (connection, send and receive). Right-click on Models folder -> click Add -> select Class.
data:image/s3,"s3://crabby-images/dd2f6/dd2f6ab821126ec1e0f37ef45bc2bcd02dbbfaa2" alt=""
Paste the below code in RabbitMQBll.cs.
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using RabbitMQ.Client;
- using RabbitMQ.Util;
- using RabbitMQ.Client.Events;
- using System.Text;
- namespace ChatApplication.Models.HelperBll
- {
- public class RabbitMQBll
- {
- public IConnection GetConnection()
- {
- ConnectionFactory factory = new ConnectionFactory();
- factory.UserName = “”;
- factory.Password = “”;
- factory.Port = 5672;
- factory.HostName = “localhost”;
- factory.VirtualHost = “/”;
- return factory.CreateConnection();
- }
- public bool send(IConnection con,string message,string friendqueue)
- {
- try
- {
- IModel channel = con.CreateModel();
- channel.ExchangeDeclare(“messageexchange”, ExchangeType.Direct);
- channel.QueueDeclare(friendqueue, true, false, false, null);
- channel.QueueBind(friendqueue, “messageexchange”, friendqueue, null);
- var msg = Encoding.UTF8.GetBytes(message);
- channel.BasicPublish(“messageexchange”, friendqueue, null, msg);
- }
- catch (Exception)
- {
- }
- return true;
- }
- public string receive(IConnection con,string myqueue)
- {
- try
- {
- string queue = myqueue;
- IModel channel = con.CreateModel();
- channel.QueueDeclare(queue: queue, durable: true, exclusive: false, autoDelete: false, arguments: null);
- var consumer = new EventingBasicConsumer(channel);
- BasicGetResult result = channel.BasicGet(queue: queue, autoAck: true);
- if (result != null)
- return Encoding.UTF8.GetString(result.Body);
- else
- return null;
- }
- catch (Exception)
- {
- return null;
- }
- }
- }
- }
Add the below code in Views -> Index.cshtml.
Right-click on Index method in HomeController ->Add View.
data:image/s3,"s3://crabby-images/745dd/745dd3c05d8c281b4d25246d26e0e87d01536bb9" alt=""
Give the Index name.
data:image/s3,"s3://crabby-images/f95c9/f95c92bacd0bd92132a0cd8d0f74b646075d1252" alt=""
Paste the below code in View.
- @using System.Web.Optimization
- @{
- Layout = null;
- }
- <!DOCTYPE html>
- <html>
- <head>
- <meta name=”viewport” content=”width=device-width” />
- <title>Index</title>
- @Styles.Render(“~/Content/css”)
- @Scripts.Render(“~/bundles/jquery”)
- @Scripts.Render(“~/bundles/bootstrap”)
- <script type=”text/javascript”>
- $(document).ready(function () {
- $(“#btnsend”).click(function () {
- send();
- });
- getmyfriends();
- function getmyfriends()
- {
- $.ajax({
- type: “POST”,
- url: “@Url.Action(“friendlist”)”,
- contentType: “application/json; charset=utf-8”,
- data: ‘{}’,
- dataType: “json”,
- success: function (r) {
- var ddlfrined = $(“[id*=ddlfriend]”);
- // ddlfrined.empty().append(‘<option selected=”selected” value=”0″>select</option>’);
- for (var i = 0; i <r.length; i++) {
- ddlfrined.append($(“<option></option>”).val(r[i].Value).html(r[i].Text));
- }
- },
- error: function (r) {
- alert(“error”);
- }
- });
- }
- setInterval(function () {
- $.ajax({
- type: “POST”,
- contentType: “application/json; charset=utf-8”,
- data: ‘{}’,
- url: “@Url.Action(“receive”)”,
- dataType: “json”,
- success: function (response) {
- var data = $(“#divmsg”).html();
- $(“#divmsg”).html(data + “<br>Friend:” + response);
- },
- error: function (response) {
- }
- });
- }, 5000);
- function send() {
- var message = $(“#txtmsg”).val();
- var friend = $(“#ddlfriend”).val();
- var data = $(“#divmsg”).html();
- $(“#divmsg”).html(data + “<br>Me:” + message);
- $(“#txtmsg”).val(“”);
- debugger;
- $.ajax({
- type: “POST”,
- contentType: “application/json; charset=utf-8”,
- data: ‘{“message”:”‘ + message + ‘”,”friend”:”‘+friend+'”}’,
- url: “@Url.Action(“sendmsg”)”,
- dataType: “json”,
- success: function (response) {
- var data = $(“#divmsg”).html();
- $(“#divmsg”).html(data + “<br>Me :” + message);
- },
- error: function (response) {
- }
- });
- }
- });
- </script>
- </head>
- <body>
- <nav class=”nav navbar-default”>
- <div class=”navbar-brand”>
- <span style=”float:right;”>@Session[“username”].ToString()</span>
- </div>
- </nav>
- <br />
- <div class=”clearfix”></div>
- @using (Html.BeginForm())
- {
- <div class=”container”>
- <div class=”row”>
- </div>
- <div class=”row”>
- <div class=”col-md-4″>
- <div class=”form-group”>
- <select id=”ddlfriend” name=”ddlfriend” class=”form-control”>
- </select>
- </div>
- <div class=”form-group”>
- <input type=”text” name=”txtmsg” id=”txtmsg” class=”form-control” />
- </div>
- <div class=”form-group”>
- <input type=”button” value=”send” class=”btn btn-success” name=”btnsend” id=”btnsend” />
- </div>
- </div>
- <div class=”col-md-6″>
- <div class=”panel panel-success”>
- <div class=”panel-heading”>
- <div class=”panel-title”>
- Messages
- </div>
- <div class=”panel-footer” style=”min-height:400px;”>
- <div id=”divmsg”>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- }
- <div>
- </div>
- </body>
- </html>
Press F5 to Build and Run the project.
data:image/s3,"s3://crabby-images/6c2fb/6c2fb7de43deee3fc5aaf2635196a9c3405cfab1" alt=""
I hope you liked the article. If you have any query, please feel free to post in the comments section.
data:image/s3,"s3://crabby-images/226da/226daead849a7b2c721393573ca6c68dc052af0c" alt=""
Magnificent beat ! I would like to apprentice even as you amend your web site, how could i subscribe for a blog web site? The account aided me a acceptable deal. I had been tiny bit familiar of this your broadcast offered vibrant transparent idea