HttpRequest.UrlReferrer in C#
Gets information about the URL of the client's previous request that linked to the current URL.
public Uri UrlReferrer { get; }
Uri MyUrl = Request.UrlReferrer;
Response.Write("Referrer URL Port: " + Server.HtmlEncode(MyUrl.Port.ToString()) + "< br >");
Response.Write("Referrer URL Protocol: " + Server.HtmlEncode(MyUrl.Scheme) + "< br >");
Dotnet, DotnetCore, Azure, C#,VB.net, Sql Server, WCF, MVC ,Linq, Javascript and Jquery
29 December 2013
25 December 2013
Marshalling
Marshalling
Marshalling (sometimes spelled marshaling) is the process of transforming the memory representation of an object to a data format suitable for storage or transmission, and it is typically used when data must be moved between different parts of a computer program or from one program to another.
Marshalling is similar to serialization and is used to communicate to remote objects with an object.
It simplifies complex communication, using custom/complex objects to communicate instead of primitives.
The opposite, or reverse, of marshalling is called unmarshalling.
Marshalling (sometimes spelled marshaling) is the process of transforming the memory representation of an object to a data format suitable for storage or transmission, and it is typically used when data must be moved between different parts of a computer program or from one program to another.
Marshalling is similar to serialization and is used to communicate to remote objects with an object.
It simplifies complex communication, using custom/complex objects to communicate instead of primitives.
The opposite, or reverse, of marshalling is called unmarshalling.
XML VS JSON
XML VS JSON
XML - Extensible Markup Language
JSON - Javascript Object Notation
JSON
JSON uses JavaScript syntax for describing data objects, but JSON is still language and platform independent.
JSON is more lighter and efficient than XML
JSON does not provide any display capabilities because it is not a document markup language.
XML
XML’s strength is extensibility and the avoidance of namespace clashes. It holds any data type and can be used to transport full documents with formatting information included. XML is best used when transporting something like a patient chart or text document with markup included.
XML provide display capabilities.
XML structures are based on elements (which can be nested), attributes (which cannot), raw content text, entities, DTDs, and other meta structures.
Finally,
JSON is a better data exchange format. XML is a better document exchange format. Use the right one for the right job.
XML - Extensible Markup Language
JSON - Javascript Object Notation
JSON
JSON uses JavaScript syntax for describing data objects, but JSON is still language and platform independent.
JSON is more lighter and efficient than XML
JSON does not provide any display capabilities because it is not a document markup language.
XML
XML’s strength is extensibility and the avoidance of namespace clashes. It holds any data type and can be used to transport full documents with formatting information included. XML is best used when transporting something like a patient chart or text document with markup included.
XML provide display capabilities.
XML structures are based on elements (which can be nested), attributes (which cannot), raw content text, entities, DTDs, and other meta structures.
Finally,
JSON is a better data exchange format. XML is a better document exchange format. Use the right one for the right job.
SOAP VS REST
SOAP VS REST
SOAP - "Simple Object Access Protocol"
REST - "Representational state transfer"
REST
Standard and Unified methods like POST, GET, PUT and DELETE. Its work like how an website makes a request using HTTP protocol.
Easy to use URI (Uniform resource identifier) format to locate any web resource.
REST is light weighted compared to SOAP
SOAP
SOAP is a lightweight protocol intended for exchanging structured information in a decentralized, distributed environment. SOAP uses XML technologies to define an extensible messaging framework, which provides a message construct that can be exchanged over a variety of underlying protocols. The framework has been designed to be independent of any particular programming model and other implementation specific semantics.
WCF SOAP
The WCF SOAP service can be categorized as operations-based, which means that a SOAP client calls a method that is available as a web service operation on a remote server, and receives a SOAP response.
WCF REST
A WCF REST service can be categorized as resource-based, which means that a REST client sends an HTTP request to programmatically accomplish a business objective. These requests largely employ a GET that is sent to a URI. In return, the client receives the corresponding resource.
SOAP - "Simple Object Access Protocol"
REST - "Representational state transfer"
REST
Standard and Unified methods like POST, GET, PUT and DELETE. Its work like how an website makes a request using HTTP protocol.
Easy to use URI (Uniform resource identifier) format to locate any web resource.
REST is light weighted compared to SOAP
SOAP
SOAP is a lightweight protocol intended for exchanging structured information in a decentralized, distributed environment. SOAP uses XML technologies to define an extensible messaging framework, which provides a message construct that can be exchanged over a variety of underlying protocols. The framework has been designed to be independent of any particular programming model and other implementation specific semantics.
WCF SOAP
The WCF SOAP service can be categorized as operations-based, which means that a SOAP client calls a method that is available as a web service operation on a remote server, and receives a SOAP response.
WCF REST
A WCF REST service can be categorized as resource-based, which means that a REST client sends an HTTP request to programmatically accomplish a business objective. These requests largely employ a GET that is sent to a URI. In return, the client receives the corresponding resource.
1 December 2013
Difference Between Razor View Engine and ASPX View Engine in MVC
Difference Between Razor View Engine and ASPX View Engine in MVC
ASPX View Engine is the default view engine for the Asp.net MVC that is included with Asp.net MVC from the beginning.
Razor Engine is an advanced view engine that was introduced with MVC3. This is not a new language but it is a new markup syntax.
ASPX View Engine doesn't support TDD (Test Driven Development)
Razor Engine supports TDD (Test Driven Development)
ASPX View Engine support design mode in visual studio means you can see your page look and feel without running the application.
Razor Engine, doesn't support design mode in visual studio means you cann't see your design page look and feel.
ASPX View Engine is faster than Razor Engine.
Razor Engine is little bit slow as compared to Webform Engine.
Syntax
Webform uses <% and %>
for example
< %: Html.ActionLink("SignUp", "SignUp") % >
Razor uses @ symbol
for example
@Html.ActionLink("SignUp", "SignUp")
ASPX View Engine does not prevent XSS attacks means any script saved in the database will be fired while rendering the page.
Razor Engine prevents XSS attacks(Cross-Site Scripting Attacks) means it encodes the script or html tags like <,> before rendering to view.
ASPX View Engine is the default view engine for the Asp.net MVC that is included with Asp.net MVC from the beginning.
Razor Engine is an advanced view engine that was introduced with MVC3. This is not a new language but it is a new markup syntax.
ASPX View Engine doesn't support TDD (Test Driven Development)
Razor Engine supports TDD (Test Driven Development)
ASPX View Engine support design mode in visual studio means you can see your page look and feel without running the application.
Razor Engine, doesn't support design mode in visual studio means you cann't see your design page look and feel.
ASPX View Engine is faster than Razor Engine.
Razor Engine is little bit slow as compared to Webform Engine.
Syntax
Webform uses <% and %>
for example
< %: Html.ActionLink("SignUp", "SignUp") % >
Razor uses @ symbol
for example
@Html.ActionLink("SignUp", "SignUp")
ASPX View Engine does not prevent XSS attacks means any script saved in the database will be fired while rendering the page.
Razor Engine prevents XSS attacks(Cross-Site Scripting Attacks) means it encodes the script or html tags like <,> before rendering to view.
17 November 2013
If variable is Empty or NULL in WHERE clause in SQL Server
If variable is Empty or NULL in WHERE clause in SQL Server
If @SearchType is Null or Empty how to return all values from the database.
Sample Query:
SELECT
P.[ProductId],
P.[ProductName],
P.[ProductPrice],
P.[Type]
FROM [Product] P
-- if @Searchtype is not null then use the where clause
WHERE p.[Type] = @SearchType
Just use
If @searchType is null means 'return the whole table' then use
WHERE p.[Type] = @SearchType OR @SearchType is NULL
If @searchType is an empty string means 'return the whole table' then use
WHERE p.[Type] = @SearchType OR @SearchType = ''
If @searchType is null or an empty string means 'return the whole table' then use
WHERE p.[Type] = @SearchType OR Coalesce(@SearchType,'') = ''
If the @SearchType is Null or Empty, it returns all the value from the database.
If the @SearchType contains any value, it returns only the condition satisfied data.
If @SearchType is Null or Empty how to return all values from the database.
Sample Query:
SELECT
P.[ProductId],
P.[ProductName],
P.[ProductPrice],
P.[Type]
FROM [Product] P
-- if @Searchtype is not null then use the where clause
WHERE p.[Type] = @SearchType
Just use
If @searchType is null means 'return the whole table' then use
WHERE p.[Type] = @SearchType OR @SearchType is NULL
If @searchType is an empty string means 'return the whole table' then use
WHERE p.[Type] = @SearchType OR @SearchType = ''
If @searchType is null or an empty string means 'return the whole table' then use
WHERE p.[Type] = @SearchType OR Coalesce(@SearchType,'') = ''
If the @SearchType is Null or Empty, it returns all the value from the database.
If the @SearchType contains any value, it returns only the condition satisfied data.
15 October 2013
Difference between CTE and Temp Table and Table Variable in SQL Server
Difference between CTE and Temp Table and Table Variable in SQL Server
1. Temp Tables are physically created in the Tempdb database. These tables act as the normal table and also can have constraints, index like normal tables.
It is divided into two Local temp tables and Global Temp Table,
Local Temp table are only available to the SQL Server session or connection (means single user) that created the tables.
Global temp tables are available to all SQL Server sessions or connections (means all the user).
These can be created by any SQL Server connection user and these are automatically deleted when all the SQL Server connections have been closed.
cases where you need transaction rollback support.
cases where you need transaction rollback support.
2. CTE - Common table Expression is a named temporary result set which is used to manipulate the complex sub-queries data. This exists for the scope of statement. This is created in memory rather than Tempdb database. You cannot create any index on CTE.
3. Table Variable acts like a variable and exists for a particular batch of query execution. It gets dropped automatically once it comes out of batch. This is also created in the Tempdb database but not the memory.You cannot create a non-clustered index on a table variable, unless the index is a side effect of a PRIMARY KEY or UNIQUE constraint on the table.
If the resultset is small, the table variable is always the optimum choice.
If the resultset is small, the table variable is always the optimum choice.
9 October 2013
Remove duplicates in SQL Server when tables have no primary key
Remove duplicates in SQL Server when tables have no primary key
I have table called CricketerDetails, and the table has no primary or unique key.
Below i have mentioned how to remove duplicate items with query.
1. Procedure to remove the Duplicate rows with query is
Query
WITH tempTable as
(
SELECT ROW_NUMBER() Over(PARTITION BY FirstName,LastName,HighestScore ORDER BY FirstName) As RowNumber,* FROM CricketerDetails
)
DELETE FROM tempTable where RowNumber >1
SELECT * FROM CricketerDetails order by FirstName asc
I have table called CricketerDetails, and the table has no primary or unique key.
Below i have mentioned how to remove duplicate items with query.
1. Procedure to remove the Duplicate rows with query is
Query
WITH tempTable as
(
SELECT ROW_NUMBER() Over(PARTITION BY FirstName,LastName,HighestScore ORDER BY FirstName) As RowNumber,* FROM CricketerDetails
)
DELETE FROM tempTable where RowNumber >1
SELECT * FROM CricketerDetails order by FirstName asc
12 September 2013
5 September 2013
Access Modifiers in c#
The type or member can be accessed by any other code in the same assembly or another assembly that references it.
The type or member can be accessed only by code in the same class or struct.
The type or member can be accessed only by code in the same class or struct, or in a class that is derived from that class.
The type or member can be accessed by any code in the same assembly, but not from another assembly.
The type or member can be accessed by any code in the assembly in which it is declared, or from within a derived class in another assembly. Access from another assembly must take place within a class declaration that derives from the class in which the protected internal element is declared, and it must take place through an instance of the derived class type.
Extension Methods in C#
Extension Methods in C#
Extension methods enable you to "add" methods to existing types without creating a new derived type, recompiling, or otherwise modifying the original type. Extension methods are a special kind of static method, but they are called as if they were instance methods on the extended type.
Remove $ from the string using Extension Methods in C#
using System;
using System.Windows.Forms;
namespace ExtensionMethodsExample
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
ExtensionMethodExample();
}
private void ExtensionMethodExample()
{
string dollarval = "2000$";
dollarval = dollarval.RemoveDollarSign();
}
}
public static class RemoveDollar
{
public static String RemoveDollarSign(this string dollarval)
{
string val = dollarval.Replace("$", "");
return val;
}
}
}
Extension methods enable you to "add" methods to existing types without creating a new derived type, recompiling, or otherwise modifying the original type. Extension methods are a special kind of static method, but they are called as if they were instance methods on the extended type.
Remove $ from the string using Extension Methods in C#
using System;
using System.Windows.Forms;
namespace ExtensionMethodsExample
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
ExtensionMethodExample();
}
private void ExtensionMethodExample()
{
string dollarval = "2000$";
dollarval = dollarval.RemoveDollarSign();
}
}
public static class RemoveDollar
{
public static String RemoveDollarSign(this string dollarval)
{
string val = dollarval.Replace("$", "");
return val;
}
}
}
29 August 2013
HTTP Modules vs Global.asax Files
HTTP Modules vs Global.asax Files
You can implement much of the functionality of a Http modules in the application's Global.asax file, which enables you to respond to application events. However, modules have an advantage over the Global.asax file because they are encapsulated and can be created one time and used in many different applications. By adding them to the global assembly cache and registering them in the Machine.config file, you can reuse them across applications.
You can implement much of the functionality of a Http modules in the application's Global.asax file, which enables you to respond to application events. However, modules have an advantage over the Global.asax file because they are encapsulated and can be created one time and used in many different applications. By adding them to the global assembly cache and registering them in the Machine.config file, you can reuse them across applications.
The advantage of using the Global.asax file is that you can handle other registered events such as Session_Start and Session_End. In addition, the Global.asax file enables you to instantiate global objects that are available throughout the application.
You should use a module whenever you must create code that depends on application events, and when the following conditions are true:
- You want to re-use the module in other applications.
- You want to avoid putting complex code in the Global.asax file.
- The module applies to all requests in the pipeline (IIS 7.0 Integrated mode only).
18 August 2013
GAC - Global Assembly cache
GAC - Global Assembly cache
The global assembly cache stores assemblies specifically designated to be shared by several applications on the computer.
The global assembly cache stores assemblies specifically designated to be shared by several applications on the computer.
Worker Process and Application Pool in asp.net
Worker Process and Application Pool in asp.net
Worker Process:
Worker Process (w3wp.exe) runs the ASP.Net application in IIS. This process is responsible to manage all the request and response that are coming from client system. All the ASP.Net functionality runs under the scope of worker process. When a request comes to the server from a client worker process is responsible to generate the request and response. In a single word we can say worker process is the heart of ASP.NET Web Application which runs on IIS.
Application Pool:
Application pool is the container of worker process. Application pools is used to separate sets of IIS worker processes that share the same configuration. Application pools enables a better security, reliability, and availability for any web application. The worker process serves as the process boundary that separates each application pool so that when one worker process or application is having an issue or recycles, other applications or worker processes are not affected. This makes sure that a particular web application doesn't not impact other web application as they they are configured into different application pools.
Worker Process:
Worker Process (w3wp.exe) runs the ASP.Net application in IIS. This process is responsible to manage all the request and response that are coming from client system. All the ASP.Net functionality runs under the scope of worker process. When a request comes to the server from a client worker process is responsible to generate the request and response. In a single word we can say worker process is the heart of ASP.NET Web Application which runs on IIS.
Application Pool:
Application pool is the container of worker process. Application pools is used to separate sets of IIS worker processes that share the same configuration. Application pools enables a better security, reliability, and availability for any web application. The worker process serves as the process boundary that separates each application pool so that when one worker process or application is having an issue or recycles, other applications or worker processes are not affected. This makes sure that a particular web application doesn't not impact other web application as they they are configured into different application pools.
15 August 2013
Serialization and DeSerialization in C#
Serialization and DeSerialization in C#
Serialization is the process of converting an object into a stream of bytes in order to persist it to memory, a database, or a file. Its main purpose is to save the state of an object in order to be able to recreate it when needed. The reverse process is called deserialization.
The object is serialized to a stream, which carries not just the data, but information about the object's type, such as its version, culture, and assembly name. From that stream, it can be stored in a database, a file, or memory.
Serialization allows the developer to save the state of an object and recreate it as needed, providing storage of objects as well as data exchange. Through serialization, a developer can perform actions like sending the object to a remote application by means of a Web Service, passing an object from one domain to another, passing an object through a firewall as an XML string, or maintaining security or user-specific information across applications.
Serialization is the process of converting an object into a stream of bytes in order to persist it to memory, a database, or a file. Its main purpose is to save the state of an object in order to be able to recreate it when needed. The reverse process is called deserialization.
The object is serialized to a stream, which carries not just the data, but information about the object's type, such as its version, culture, and assembly name. From that stream, it can be stored in a database, a file, or memory.
Serialization allows the developer to save the state of an object and recreate it as needed, providing storage of objects as well as data exchange. Through serialization, a developer can perform actions like sending the object to a remote application by means of a Web Service, passing an object from one domain to another, passing an object through a firewall as an XML string, or maintaining security or user-specific information across applications.
Binary Serialization
Binary serialization uses binary encoding to produce compact serialization for uses such as storage or socket-based network streams.
XML Serialization
XML serialization serializes the public fields and properties of an object, or the parameters and return values of methods, into an XML stream that conforms to a specific XML Schema definition language (XSD) document. XML serialization results in strongly typed classes with public properties and fields that are converted to XML.System.Xml.Serialization contains the classes necessary for serializing and deserializing XML.
SOAP Serialization
XML serialization can also be used to serialize objects into XML streams that conform to the SOAP specification. SOAP is a protocol based on XML, designed specifically to transport procedure calls using XML. As with regular XML serialization, attributes can be used to control the literal-style SOAP messages generated by an XML Web service.
Basic Serialization
The only requirement in basic serialization is that the object has the SerializableAttribute attribute applied. The NonSerializedAttribute can be used to keep specific fields from being serialized.
When you use basic serialization, the versioning of objects may create problems, in which case custom serialization may be preferable. Basic serialization is the easiest way to perform serialization, but it does not provide much control over the process.
Custom Serialization
In custom serialization, you can specify exactly which objects will be serialized and how it will be done. The class must be marked SerializableAttribute and implement theISerializable interface.
12 August 2013
Html.TextBox vs Html.TextBoxFor in MVC
Html.TextBox vs Html.TextBoxFor in MVC
Html.TextBox and Html.DropDownList are not strongly typed and hence they doen't require a
strongly typed view. This means that we can hardcore whatever name we want.
On the other hand, Html.TextFor and Html.DropDownListFor are strongly typed and requires
a strongly typed view, and the name is inferred from the Lambda expression.
Whether we use Html.TextBox and Html.DropDownlist or Html.TextBoxFor and Html.DropDownListFor,
the end result is the same. they produce the same Html.
Html.TextBox and Html.DropDownList are not strongly typed and hence they doen't require a
strongly typed view. This means that we can hardcore whatever name we want.
On the other hand, Html.TextFor and Html.DropDownListFor are strongly typed and requires
a strongly typed view, and the name is inferred from the Lambda expression.
Whether we use Html.TextBox and Html.DropDownlist or Html.TextBoxFor and Html.DropDownListFor,
the end result is the same. they produce the same Html.
Nested List in C#
Nested List in C#
Consider there are two Class
public class Person
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public List< Addresses > { get; set; }
}
public class Address
{
public string Line1 { get; set; }
public string Line2 { get; set; }
public string ZipCode { get; set; }
public string City { get; set; }
public string State { get; set; }
public string Country { get; set; }
}
Procedure used to add multiple class in the List
var personDetails = new List< Person >
{
new Person
{
Id = 1, FirstName = "Arun",
LastName = "Prakash",
Addresses = new List< Address >
{
new Address{Line1 = "Hope College",Line2 = "Coimbatore"}
}
},
new Person{
Id = 2, FirstName = "Sanjay",
LastName = "Ramasamy",
Addresses = new List< Address >
{
new Address{Line1 = "Anna Salai",Line2= "Chennai"}
}
}
};
Consider there are two Class
public class Person
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public List< Addresses > { get; set; }
}
public class Address
{
public string Line1 { get; set; }
public string Line2 { get; set; }
public string ZipCode { get; set; }
public string City { get; set; }
public string State { get; set; }
public string Country { get; set; }
}
Procedure used to add multiple class in the List
var personDetails = new List< Person >
{
new Person
{
Id = 1, FirstName = "Arun",
LastName = "Prakash",
Addresses = new List< Address >
{
new Address{Line1 = "Hope College",Line2 = "Coimbatore"}
}
},
new Person{
Id = 2, FirstName = "Sanjay",
LastName = "Ramasamy",
Addresses = new List< Address >
{
new Address{Line1 = "Anna Salai",Line2= "Chennai"}
}
}
};
5 August 2013
Html.RenderPartial vs Html.Partial, Html.RenderAction vs Html.Action
Html.RenderPartial vs Html.Partial, Html.RenderAction vs Html.Action
@Html.Partial("Details")
@Html.Action("Index", "Home")
and
@{ Html.RenderPartial("Details"); }
@{ Html.RenderAction("Index", "Home"); }
Html.Partial returns a string, Html.RenderPartial calls Write internally, and returns void.
You can store the output of Html.Partial in a variable, or return it from a function. You cannot do this with Html.RenderPartial.
Html.RenderPartial -The result will be written to the Response stream during the execution.
The same is true for Html.Action and Html.RenderAction.
@Html.Partial("Details")
@Html.Action("Index", "Home")
and
@{ Html.RenderPartial("Details"); }
@{ Html.RenderAction("Index", "Home"); }
Html.Partial returns a string, Html.RenderPartial calls Write internally, and returns void.
You can store the output of Html.Partial in a variable, or return it from a function. You cannot do this with Html.RenderPartial.
Html.RenderPartial -The result will be written to the Response stream during the execution.
The same is true for Html.Action and Html.RenderAction.
MVC 3 Ajax Json Sample
MVC 3 Ajax Json Sample
Create model name PersonDetails.cs
using System.Collections.Generic;
namespace MVCJsonAjax.Models
{
public class Person
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public List< Address > Addresses { get; set; }
}
public class Address
{
public string Line1 { get; set; }
public string Line2 { get; set; }
public string ZipCode { get; set; }
public string City { get; set; }
public string State { get; set; }
public string Country { get; set; }
}
}
Create Controller - SaveController.cs
using System.Web.Mvc;
using MVCJsonAjax.Models;
namespace MVCJsonAjax.Controllers
{
public class SaveController : Controller
{
//
// GET: /Save/
[ActionName("SaveData"),HttpGet]
public ActionResult SaveData()
{
return View();
}
[ActionName("SaveData"), HttpPost]
public JsonResult SaveData(Person objPerson,Address objAddress)
{
JsonResult result = new JsonResult();
// Save logic - save person and address details
result.Data = "Saved Successfully";
return result;
}
}
}
Create View for ActionResult SaveData()
@using MVCJsonAjax.Models
@{
ViewBag.Title = "SaveData";
}
< h2 >
Save Data< /h2 >
< div>
< div id="message" >
< /div>
< /div >
< script type =" text/javascript ">
$(document).ready(function () {
$('#btnSubmit').click(function () {
var Person =
{
FirstName: $('#Item1_FirstName').val(),
LastName: $('#Item1_LastName').val()
};
var Address =
{
Line1: $('#Item2_Line1').val(),
Line2: $('#Item2_Line2').val(),
ZipCode: $('#Item2_ZipCode').val(),
City: $('#Item2_City').val(),
State: $('#Item2_State').val(),
Country: $('#Item2_Country').val()
};
var obj = { "Per": Person, "Add": Address};
$.ajax({
url: '/Save/SaveData',
type: "POST",
data:JSON.stringify({objPerson: Person ,objAddress: Address }),
cache: false,
dataType: "json",
contentType: "application/json;charset=utf-8",
success: function (result) {
$('#message').html(result).fadeIn();
}
});
return false;
});
});
@model Tuple< Person, Address >
@using ( Html.BeginForm() )
{
< table >
< tr >
< td >
@Html.LabelFor(m => m.Item1.FirstName)
@Html.TextBoxFor(m => m.Item1.FirstName)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item1.LastName)
@Html.TextBoxFor(m => m.Item1.LastName)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.Line1)
@Html.TextBoxFor(m => m.Item2.Line1)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.Line2)
@Html.TextBoxFor(m => m.Item2.Line2)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.ZipCode)
@Html.TextBoxFor(m => m.Item2.ZipCode)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.City)
@Html.TextBoxFor(m => m.Item2.City)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.State)
@Html.TextBoxFor(m => m.Item2.State)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.Country)
@Html.TextBoxFor(m => m.Item2.Country)
< /td >
< /tr >
< tr >
< td >
< input type="submit" value="Submit" id="btnSubmit" / >
< /td >
< /tr >
< /table >
}
Create model name PersonDetails.cs
using System.Collections.Generic;
namespace MVCJsonAjax.Models
{
public class Person
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public List< Address > Addresses { get; set; }
}
public class Address
{
public string Line1 { get; set; }
public string Line2 { get; set; }
public string ZipCode { get; set; }
public string City { get; set; }
public string State { get; set; }
public string Country { get; set; }
}
}
Create Controller - SaveController.cs
using System.Web.Mvc;
using MVCJsonAjax.Models;
namespace MVCJsonAjax.Controllers
{
public class SaveController : Controller
{
//
// GET: /Save/
[ActionName("SaveData"),HttpGet]
public ActionResult SaveData()
{
return View();
}
[ActionName("SaveData"), HttpPost]
public JsonResult SaveData(Person objPerson,Address objAddress)
{
JsonResult result = new JsonResult();
// Save logic - save person and address details
result.Data = "Saved Successfully";
return result;
}
}
}
Create View for ActionResult SaveData()
@using MVCJsonAjax.Models
@{
ViewBag.Title = "SaveData";
}
< h2 >
Save Data< /h2 >
< div>
< div id="message" >
< /div>
< /div >
< script type =" text/javascript ">
$(document).ready(function () {
$('#btnSubmit').click(function () {
var Person =
{
FirstName: $('#Item1_FirstName').val(),
LastName: $('#Item1_LastName').val()
};
var Address =
{
Line1: $('#Item2_Line1').val(),
Line2: $('#Item2_Line2').val(),
ZipCode: $('#Item2_ZipCode').val(),
City: $('#Item2_City').val(),
State: $('#Item2_State').val(),
Country: $('#Item2_Country').val()
};
var obj = { "Per": Person, "Add": Address};
$.ajax({
url: '/Save/SaveData',
type: "POST",
data:JSON.stringify({objPerson: Person ,objAddress: Address }),
cache: false,
dataType: "json",
contentType: "application/json;charset=utf-8",
success: function (result) {
$('#message').html(result).fadeIn();
}
});
return false;
});
});
@model Tuple< Person, Address >
@using ( Html.BeginForm() )
{
< table >
< tr >
< td >
@Html.LabelFor(m => m.Item1.FirstName)
@Html.TextBoxFor(m => m.Item1.FirstName)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item1.LastName)
@Html.TextBoxFor(m => m.Item1.LastName)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.Line1)
@Html.TextBoxFor(m => m.Item2.Line1)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.Line2)
@Html.TextBoxFor(m => m.Item2.Line2)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.ZipCode)
@Html.TextBoxFor(m => m.Item2.ZipCode)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.City)
@Html.TextBoxFor(m => m.Item2.City)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.State)
@Html.TextBoxFor(m => m.Item2.State)
< /td >
< /tr >
< tr >
< td >
@Html.LabelFor(m => m.Item2.Country)
@Html.TextBoxFor(m => m.Item2.Country)
< /td >
< /tr >
< tr >
< td >
< input type="submit" value="Submit" id="btnSubmit" / >
< /td >
< /tr >
< /table >
}
4 August 2013
Dynamic v. Strongly Typed Views in MVC C# Razor Engine
Dynamic vs. Strongly Typed Views
Dynamic
Because we’re using a dynamic and not a strongly typed view, intellisense doesn’t help us. The completed code is shown below:
@model dynamic
@ {
ViewBag.Title = "IndexNotStonglyTyped";
}
< p >
< ul >
@foreach (var blog in Model) {
< li >
< a href="@blog.URL">@blog.Name< /a >
< /li >
}
< /ul >
< /p >
Strongly Typed Views
When it is strongly typed view.
Inside the new view template we get intellisense support.
Dynamic
Because we’re using a dynamic and not a strongly typed view, intellisense doesn’t help us. The completed code is shown below:
@model dynamic
@ {
ViewBag.Title = "IndexNotStonglyTyped";
}
Index Not Stongly Typed< /h2 >
< p >
< ul >
@foreach (var blog in Model) {
< li >
< a href="@blog.URL">@blog.Name< /a >
< /li >
}
< /ul >
< /p >
Strongly Typed Views
When it is strongly typed view.
Inside the new view template we get intellisense support.
Handle Multiple Submit button in MVC C#
Handle Multiple Submit button in MVC C#
View
<% Html.BeginForm("MyAction", "MyController", FormMethod.Post); %>
< input type="submit" name="submitButton" value="Send" / >
< input type="submit" name="submitButton" value="Cancel" / >
<% Html.EndForm(); %>
Controller
public class MyController : Controller {
public ActionResult MyAction(string submitButton) {
switch(submitButton) {
case "Send":
// delegate sending to another controller action
return(Send());
case "Cancel":
// call another action to perform the cancellation
return(Cancel());
default:
// If they've submitted the form without a submitButton,
// just return the view again.
return(View());
}
}
private ActionResult Cancel() {
// process the cancellation request here.
return(View("Cancelled"));
}
private ActionResult Send() {
// perform the actual send operation here.
return(View("SendConfirmed"));
}
}
View
<% Html.BeginForm("MyAction", "MyController", FormMethod.Post); %>
< input type="submit" name="submitButton" value="Send" / >
< input type="submit" name="submitButton" value="Cancel" / >
<% Html.EndForm(); %>
Controller
public class MyController : Controller {
public ActionResult MyAction(string submitButton) {
switch(submitButton) {
case "Send":
// delegate sending to another controller action
return(Send());
case "Cancel":
// call another action to perform the cancellation
return(Cancel());
default:
// If they've submitted the form without a submitButton,
// just return the view again.
return(View());
}
}
private ActionResult Cancel() {
// process the cancellation request here.
return(View("Cancelled"));
}
private ActionResult Send() {
// perform the actual send operation here.
return(View("SendConfirmed"));
}
}
Delegates Example in C#
//Delegates Example in C#
using System;
using System.Windows.Forms;
namespace DelegatesTesting
{
public partial class DelegatesTest : Form
{
public DelegatesTest()
{
InitializeComponent();
}
//Delegate Declaration
public delegate int PointtoAddFunction(int i, int j);
private void btnSubmit_Click(object sender, EventArgs e)
{
//Point the Delegate object with Method
PointtoAddFunction handler = AddFunction;
//Invoke the Method
MessageBox.Show(handler(10, 12).ToString());
}
//Method
public int AddFunction(int i, int j)
{
return i + j;
}
}
}
using System;
using System.Windows.Forms;
namespace DelegatesTesting
{
public partial class DelegatesTest : Form
{
public DelegatesTest()
{
InitializeComponent();
}
//Delegate Declaration
public delegate int PointtoAddFunction(int i, int j);
private void btnSubmit_Click(object sender, EventArgs e)
{
//Point the Delegate object with Method
PointtoAddFunction handler = AddFunction;
//Invoke the Method
MessageBox.Show(handler(10, 12).ToString());
}
//Method
public int AddFunction(int i, int j)
{
return i + j;
}
}
}
Datatable to List in C# using Linq
Datatable to List in C# using Linq
//StudentDetails Class with Entity Details
public class StudentDetails
{
public int StudentID { get; set; }
public string StudentName { get; set; }
public string ClassName { get; set; }
public string Section { get; set; }
}
{
public int StudentID { get; set; }
public string StudentName { get; set; }
public string ClassName { get; set; }
public string Section { get; set; }
}
//Dataaccess part, Microsoft Sqlhelper class used
public List GetStudentDetails(int studentID)
{
DataSet ds = new DataSet();
SqlParameter[] SqlParam = null;
SqlParam = new SqlParameter[1];
SqlCommand SqlCmd = new SqlCommand();
List objStud =
new List();
try
{
SqlParam[0] = new SqlParameter("@StudentID", SqlDbType.Int);
SqlParam[0].Value = studentID;
SqlHelper.FillDataset(DBconnection(), CommandType.StoredProcedure, "usp_Get_StudentDetails", ds, new string[] { "Display" }, SqlParam);
objStud =
ds.Tables[0].AsEnumerable().Select(data => new StudentDetails() { StudentID
= (int)data["StudentID"], StudentName =
(string)data["StudentName"], ClassName =
(string)data["ClassName"], Section =
(string)data["Section"] }).ToList();
return objStud;
}
catch (Exception ex)
{
throw ex;
}
finally
{
if (ds != null)
{
ds.Dispose();
}
objStud = null;
}
}
{
DataSet ds = new DataSet();
SqlParameter[] SqlParam = null;
SqlParam = new SqlParameter[1];
SqlCommand SqlCmd = new SqlCommand();
List
try
{
SqlParam[0] = new SqlParameter("@StudentID", SqlDbType.Int);
SqlParam[0].Value = studentID;
SqlHelper.FillDataset(DBconnection(), CommandType.StoredProcedure, "usp_Get_StudentDetails", ds, new string[] { "Display" }, SqlParam);
return objStud;
}
catch (Exception ex)
{
throw ex;
}
finally
{
if (ds != null)
{
ds.Dispose();
}
objStud = null;
}
}
MVC Menu
MVC Menu
1. MVC Programming Model in Asp.net
2. Setting the Default Page or Route in MVC application
3. Difference between Asp.Net MVC and Web Forms
4.ViewBag, ViewData, TempData and View State in MVC
5.Alternative to View State in MVC in Asp.net
6.Handle Multiple Submit button in MVC C#
7.Html.TextBox vs Html.TextBoxFor in MVC
8.Html.RenderPartial vs Html.Partial, Html.RenderAction vs Html.Action
1. MVC Programming Model in Asp.net
2. Setting the Default Page or Route in MVC application
3. Difference between Asp.Net MVC and Web Forms
4.ViewBag, ViewData, TempData and View State in MVC
5.Alternative to View State in MVC in Asp.net
6.Handle Multiple Submit button in MVC C#
7.Html.TextBox vs Html.TextBoxFor in MVC
8.Html.RenderPartial vs Html.Partial, Html.RenderAction vs Html.Action
3 August 2013
ASP.Net Page Life Cycle Events
ASP.Net Page Life Cycle Events:
At each stage of the page life cycle, the page raises some
events, which could be coded. An event handler is basically a function or
subroutine, bound to the event, using declarative attributes like Onclick or
handle.
Following are the page life cycle events:
PreInit PreInit is the first event in page life cycle. It checks the IsPostBack
property and determines whether the page is a postback. It sets the themes and
master pages, creates dynamic controls and gets and sets profile property
values. This event can be handled by overloading the OnPreInit method or
creating a Page_PreInit handler.
Init Init
event initializes the control property and the control tree is built. This
event can be handled by overloading the OnInit method or creating a Page_Init
handler.
InitComplete InitComplete event allows
tracking of view state. All the controls turn on view-state tracking.
LoadViewState LoadViewState event allows loading view state
information into the controls.
LoadPostData during this phase, the contents of all the input fields defined with the
PreLoad PreLoad occurs before the post back data is loaded in the controls. This event
can be handled by overloading the OnPreLoad method or creating a Page_PreLoad
handler.
Load the
Load event is raised for the page first and then recursively for all child
controls. The controls in the control tree are created. This event can be
handled by overloading the OnLoad method or creating a Page_Load handler.
LoadComplete the loading process is completed, control event handlers are run and page
validation takes place. This event can be handled by overloading the
OnLoadComplete method or creating a Page_LoadComplete handler.
PreRender the PreRender event occurs just before the output is rendered. By handling this
event, pages and controls can perform any updates before the output is
rendered.
PreRenderComplete as the PreRender event is recursively fired for all child
controls, this event ensures the completion of the pre-rendering phase.
SaveStateComplete state of control on the page is saved.
Personalization, control state and view state information is saved. The HTML
markup is generated. This stage can be handled by overriding the Render method
or creating a Page_Render handler.
UnLoad the
UnLoad phase is the last phase of the page life cycle. It raises the UnLoad
event for all controls recursively and lastly for the page itself. Final
cleanup is done and all resources and references, such as database connections,
are freed. This event can be handled by modifying the OnUnLoad method or
creating a Page_UnLoad handler.
Alternative to View State in MVC in Asp.net
Alternative to View State in MVC in Asp.net
1. For retaining the values during postback in the MVC page values you can use Ajax, so that values in the control won't clear.
2. For temporarily storing the value in current and the subsequent requests use TempData. TempData preserves value for current and next request.
TempData - http://royalarun.blogspot.in/2013/08/viewbag-viewdata-tempdata-and-view.html
TempData - http://royalarun.blogspot.in/2013/08/viewbag-viewdata-tempdata-and-view.html
ViewBag, ViewData, TempData and View State in MVC
ViewBag, ViewData, TempData and View State in MVC
ASP.NET MVC offers us three options ViewData, ViewBag and TempData for passing data from controller to view and in next request. ViewData and ViewBag are almost similar and TempData performs additional responsibility.
ASP.NET MVC offers us three options ViewData, ViewBag and TempData for passing data from controller to view and in next request. ViewData and ViewBag are almost similar and TempData performs additional responsibility.
Similarities between ViewBag & ViewData :
- Helps to maintain data when you move from controller to view.
- Used to pass data from controller to corresponding view.
- Short life means value becomes null when redirection occurs. This is because their goal is to provide a way to communicate between controllers and views. It’s a communication mechanism within the server call.
Difference between ViewBag & ViewData:
- ViewData is a dictionary of objects that is derived from ViewDataDictionary class and accessible using strings as keys.
- ViewBag is a dynamic property that takes advantage of the new dynamic features in C# 4.0.
- ViewData requires typecasting for complex data type and check for null values to avoid error.
- ViewBag doesn’t require typecasting for complex data type.
ViewBag & ViewData Example:
public ActionResult Index()
{
ViewBag.Name = "Arun Prakash";
return View();
}
public ActionResult Index()
{
ViewData["Name"] = "Arun Prakash";
return View();
}
View
@ViewBag.Name
@ViewData["Name"]
TempData:
Helps to maintain data when you move from one controller to other controller or from one action to other action. In other words when you redirect, “Tempdata” helps to maintain data between those redirects. It internally uses session variables. TempData is meant to be a very short-lived instance, and you should only use it during the current and the subsequent requests only
The only scenario where using TempData will reliably work is when you are redirecting. This is because a redirect kills the current request (and sends HTTP status code 302 Object Moved to the client), then creates a new request on the server to serve the redirected view.
It requires typecasting for complex data type and check for null values to avoid error.
public ActionResult Index()
{
var model = new Review()
{
Body = "Start",
Rating=5
};
TempData["ModelName"] = model;
return RedirectToAction("About");
}
public ActionResult About()
{
var model= TempData["ModelName"];
return View(model);
}
View State in MVC
ASP.NET MVC does not have ViewState (that of storing the values of controls in the web page).
So ASP.NET MVC pages are incredibly lightweight and your request and response times are much faster.
Alternative to View State in MVC
1. For retaining the values during postback in the MVC page values you can use Ajax, so that values in the control won't clear.
2. For temporarily storing the value in current and the subsequent requests use TempData.
Handle Null Values in Linq Query (C#)
Handle Null Values in Linq Query (C#)
Avoid a null reference exception as shown in the following example:
var query1 = from c in categories where c != null join p in products on c.ID equals (p == null ? null : p.CategoryID) select new { Category = c.Name, Name = p.Name };
The where clause filters out all null elements in the categories sequence. This technique is independent of the null check in the join clause. The conditional expression with null in this example works because Products.CategoryID is of type int? which is shorthand for Nullable
In a join clause, if only one of the comparison keys is a nullable value type, you can cast the other to a nullable type in the query expression. In the following example, assume that EmployeeID is a column that contains values of type int?:
void TestMethod(Northwind db) { var query = from o in db.Orders join e in db.Employees on o.EmployeeID equals (int?)e.EmployeeID select new { o.OrderID, e.FirstName }; }Use of ternary operator as in the below example and the MobileNo = "N/A" for thenull
values:Solution 1
var user = from u in Users join uc in UserClients on u.Id equals uc.UserId into myuserwithclient from m in myuserwithclient.DefaultIfEmpty() select new { u.Id, FirstName = u.FirstName, LastName = u.LastName, UserId = m.UserId, MobileNo = (m.MobileNo == null) ? "N/A" : m.MobileNo };
Solution 2var user = from u in Users join uc in UserClients on u.Id equals uc.UserId into myuserwithclient from m in myuserwithclient.DefaultIfEmpty() select new { u.Id, FirstName = u.FirstName, LastName = u.LastName, UserId = m.UserId, MobileNo = m.MobileNo ?? "N/A" };
Reference: http://msdn.microsoft.com/en-us/library/bb882535.aspx
31 July 2013
Covariance .Net Framework 4.0
Covariance .Net Framework 4.0
Covariance preserve assignment compatibility between Parent and Child relationship during dynamic polymorphism
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Covariance
{
class Program
{
static void Main(string[] args)
{
List objAthelete = new List();
objAthelete.Add(new Athelete
{
SportName = "100 meter",
SportsType = "Running"
});
IEnumerable Persons = objAthelete;
Athelete objAth = new Athelete();
//objAth.PrintAll(Persons);
}
}
public class Person
{
public string Name { get; set; }
public string City { get; set; }
}
public class Athelete : Person
{
public string SportName { get;set; }
public string SportsType { get;set; }
public void PrintAll(IEnumerable
{
foreach (Athelete o in objects)
{
Console.WriteLine("Sports Name:" + o.SportName + "Sports Type:" + o.SportsType);
}
}
}
}
The following error is thrown when the application is run in .Net framework 3.5, but it support in 4.0 framework.
Covariance preserve assignment compatibility between Parent and Child relationship during dynamic polymorphism
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Covariance
{
class Program
{
static void Main(string[] args)
{
List
objAthelete.Add(new Athelete
{
SportName = "100 meter",
SportsType = "Running"
});
IEnumerable
Athelete objAth = new Athelete();
//objAth.PrintAll(Persons);
}
}
public class Person
{
public string Name { get; set; }
public string City { get; set; }
}
public class Athelete : Person
{
public string SportName { get;set; }
public string SportsType { get;set; }
public void PrintAll(IEnumerable
{
foreach (Athelete o in objects)
{
Console.WriteLine("Sports Name:" + o.SportName + "Sports Type:" + o.SportsType);
}
}
}
}
The following error is thrown when the application is run in .Net framework 3.5, but it support in 4.0 framework.
27 July 2013
Add multiple model in View MVC 3 and MVC 4
Add multiple model in View MVC 3 and MVC 4
Using Tuple it is possible, Add below code in the view.
@model Tuple< Model1,Model2 >
Example : http://pastebin.com/VBPhBBUw
Using Tuple it is possible, Add below code in the view.
@model Tuple< Model1,Model2 >
Example : http://pastebin.com/VBPhBBUw
29 June 2013
Set Property Value on Master Page from Content Page ASP.NET
Set Property Value on Master Page from Content Page
Create a property in your master page and you access it from content page:
Master page:
public partial class BasePage : System.Web.UI.MasterPage
{
private string[] _RequiredRoles = null;
public string[] RequiredRoles
{
get { return _RequiredRoles; }
set { _RequiredRoles = value; }
}
}
Content Page:
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load()
{
Master.RequiredRoles = new string[] { //set appropriate roles };
}
}
Subscribe to:
Posts (Atom)
Implementing OAuth validation in a Web API
I mplementing OAuth validation in a Web API Implementing OAuth validation in a Web API using C# typically involves several key steps to sec...
-
ViewBag, ViewData, TempData and View State in MVC ASP.NET MVC offers us three options ViewData, ViewBag and TempData for passing data from...
-
// Export Datatable to Excel in C# Windows application using System; using System.Data; using System.IO; using System.Windows.Forms; ...