Substring
SELECT
(SELECT substring(DomainName,1,(charindex(',',DomainName)-1)))
FROM Settings.Settings
Replace
(SELECT REPLACE(p.FirstPart,'<p>','<p style="text-align:center;"')) AS 'FirstPart',
Here you will find about .net technology. also can get example about MVC.net and jquery.
Sunday, June 30, 2013
Wednesday, June 26, 2013
JQuery Popup on page load asp.net
JS/CSS
<link rel="stylesheet" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.5/themes/base/jquery-ui.css"
type="text/css" media="all" />
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js" type="text/javascript"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.5/jquery-ui.min.js"
type="text/javascript"></script>.
Java Script Function
<script>
function ShowPopup(message) {
$(function () {
// $("#dialog").html(message);
var bbw = '<%=Session["bbw"]%>';
if (bbw=='') {
$("#dialog").dialog({
title: '<%=Session["CompanyName"]%>',
// buttons: {
// Close: function () {
// //$(this).dialog('close');
// }
// },
<%Session["bbw"] = "Welcome";%>
modal: true
});
}
});
};
</script>
Popup Div
<div id="dialog" title="Basic dialog" style="display:none;">
<p>
This is the default dialog which is useful for displaying information. The dialog
window can be moved, resized and closed with the 'x' icon.</p>
</div>
<link rel="stylesheet" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.5/themes/base/jquery-ui.css"
type="text/css" media="all" />
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js" type="text/javascript"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.5/jquery-ui.min.js"
type="text/javascript"></script>.
Java Script Function
<script>
function ShowPopup(message) {
$(function () {
// $("#dialog").html(message);
var bbw = '<%=Session["bbw"]%>';
if (bbw=='') {
$("#dialog").dialog({
title: '<%=Session["CompanyName"]%>',
// buttons: {
// Close: function () {
// //$(this).dialog('close');
// }
// },
<%Session["bbw"] = "Welcome";%>
modal: true
});
}
});
};
</script>
Popup Div
<div id="dialog" title="Basic dialog" style="display:none;">
<p>
This is the default dialog which is useful for displaying information. The dialog
window can be moved, resized and closed with the 'x' icon.</p>
</div>
Saturday, June 22, 2013
JqGrid in MVC3
Add all this CSS & JS
@{
ViewBag.Title = "Home Page";
}
@{
ViewBag.Title = "Home Page";
}
<link href="../../css/jquery-ui-1.8.12.custom.css" rel="stylesheet" type="text/css" />
<link href="../../css/ui.jqgrid.css" rel="stylesheet" type="text/css" />
<script src="../../js/jquery-1.5.2.min.js" type="text/javascript"></script>
<script src="../../js/i18n/grid.locale-en.js" type="text/javascript"></script>
<script src="../../js/jquery.jqGrid.min.js" type="text/javascript"></script>
<script src="../../Scripts/json2-min.js" type="text/javascript"></script>
<script src="../../js/jquery.jqGrid.src.js" type="text/javascript"></script>
Java Script Function
<script type="text/javascript">
$(document).ready(function () {
jQuery("#list1").jqGrid({
datatype: "local",
colNames: ['Inv No', 'Date', 'Client', 'Amount', 'Tax', 'Total', 'Notes'],
colModel: [
{ name: 'id', index: 'id', width: 60, sorttype: "int" },
{ name: 'invdate', index: 'invdate', width: 90, sorttype: "date" },
{ name: 'name', index: 'name', width: 100 },
{ name: 'amount', index: 'amount', width: 80, align: "right", sorttype: "float" },
{ name: 'tax', index: 'tax', width: 80, align: "right", sorttype: "float" },
{ name: 'total', index: 'total', width: 80, align: "right", sorttype: "float" },
{ name: 'note', index: 'note', width: 150, sortable: false }
],
multiselect: true,
rowNum: 10,
rowList: [5, 10, 20, 50, 100],
pager: jQuery('#pager1'),
sortorder: "desc",
viewrecords: true,
subGrid: true,
subGridUrl: 'Default.aspx',
subGridModel: [{ name: ['No', 'Item', 'Qty', 'Unit', 'Line Total'],
width: [55, 200, 80, 80, 80]
}
],
caption: "Manipulating Array Data"
});
jQuery("#list1").jqGrid('navGrid', '#pager1', { del: false, add: false, edit: false }, {}, {}, {}, { multipleSearch: true });
var mydata = [
{ id: "1", invdate: "2007-10-01", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "2", invdate: "2007-10-02", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "3", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "4", invdate: "2007-10-04", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "5", invdate: "2007-10-05", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "6", invdate: "2007-09-06", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "7", invdate: "2007-10-04", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "8", invdate: "2007-10-03", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "9", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" }
];
for (var i = 0; i <= mydata.length; i++)
jQuery("#list1").jqGrid('addRowData', i + 1, mydata[i]);
});
</script>
<link href="../../css/ui.jqgrid.css" rel="stylesheet" type="text/css" />
<script src="../../js/jquery-1.5.2.min.js" type="text/javascript"></script>
<script src="../../js/i18n/grid.locale-en.js" type="text/javascript"></script>
<script src="../../js/jquery.jqGrid.min.js" type="text/javascript"></script>
<script src="../../Scripts/json2-min.js" type="text/javascript"></script>
<script src="../../js/jquery.jqGrid.src.js" type="text/javascript"></script>
Java Script Function
<script type="text/javascript">
$(document).ready(function () {
jQuery("#list1").jqGrid({
datatype: "local",
colNames: ['Inv No', 'Date', 'Client', 'Amount', 'Tax', 'Total', 'Notes'],
colModel: [
{ name: 'id', index: 'id', width: 60, sorttype: "int" },
{ name: 'invdate', index: 'invdate', width: 90, sorttype: "date" },
{ name: 'name', index: 'name', width: 100 },
{ name: 'amount', index: 'amount', width: 80, align: "right", sorttype: "float" },
{ name: 'tax', index: 'tax', width: 80, align: "right", sorttype: "float" },
{ name: 'total', index: 'total', width: 80, align: "right", sorttype: "float" },
{ name: 'note', index: 'note', width: 150, sortable: false }
],
multiselect: true,
rowNum: 10,
rowList: [5, 10, 20, 50, 100],
pager: jQuery('#pager1'),
sortorder: "desc",
viewrecords: true,
subGrid: true,
subGridUrl: 'Default.aspx',
subGridModel: [{ name: ['No', 'Item', 'Qty', 'Unit', 'Line Total'],
width: [55, 200, 80, 80, 80]
}
],
caption: "Manipulating Array Data"
});
jQuery("#list1").jqGrid('navGrid', '#pager1', { del: false, add: false, edit: false }, {}, {}, {}, { multipleSearch: true });
var mydata = [
{ id: "1", invdate: "2007-10-01", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "2", invdate: "2007-10-02", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "3", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "4", invdate: "2007-10-04", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "5", invdate: "2007-10-05", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "6", invdate: "2007-09-06", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" },
{ id: "7", invdate: "2007-10-04", name: "test", note: "note", amount: "200.00", tax: "10.00", total: "210.00" },
{ id: "8", invdate: "2007-10-03", name: "test2", note: "note2", amount: "300.00", tax: "20.00", total: "320.00" },
{ id: "9", invdate: "2007-09-01", name: "test3", note: "note3", amount: "400.00", tax: "30.00", total: "430.00" }
];
for (var i = 0; i <= mydata.length; i++)
jQuery("#list1").jqGrid('addRowData', i + 1, mydata[i]);
});
</script>
Textbox in MVC3
Readonly
@Html.TextAreaFor(m => m.Password, new { @readonly = "readonly" })
Adding Css
@Html.TextAreaFor(m => m.Password, new { style = "width:100px;height:25px;background-color:#000" })
Enable-disabled
@Html.TextBoxFor(m => m.Password, new { disabled="disabled" })
Password
@Html.PasswordFor(m => m.Password, new { id = "txtPassWord"})
Default Value
@Html.TextBoxFor(m => m.UserName, new { @name="Name", @Value = "test" })
@Html.TextAreaFor(m => m.Password, new { @readonly = "readonly" })
Adding Css
@Html.TextAreaFor(m => m.Password, new { style = "width:100px;height:25px;background-color:#000" })
Enable-disabled
@Html.TextBoxFor(m => m.Password, new { disabled="disabled" })
Password
@Html.PasswordFor(m => m.Password, new { id = "txtPassWord"})
Default Value
@Html.TextBoxFor(m => m.UserName, new { @name="Name", @Value = "test" })
Tuesday, June 18, 2013
Great .NET Framework 4.5 Features
Introduction
It has been almost a year since .NET 4.5 got released. But the problems with most of the recent Microsoft releases have been communication with .NET developers. Only one or two features are known to developers and other features just stay on MSDN and end up becoming simple documents.For example, the time you ask a .NET developer what is new in the core framework .NET 4.5 most of them will just say
async
and awaitt
(at least with people whom I have interacted have just talked about those features).Again it’s very difficult to run through all the new features. Because the features may not sound interesting depending on what you are working currently on..
So in this article I have picked my five favorite features introduced in .NET 4.5 core. Again it’s possible my favorites cannot be your favorites. But what I have done is while choosing these features I kept in mind the larger .NET community and I hope I have met that expectation.
Feature 1: async and await (code markers)
This feature has been oversold and every .NET evangelist has talked about it. But this is still my favorite and you will come to know why in a few lines from here.async
and await
are markers which mark code positions from where control should resume after a task (thread) completes.Let us try to make sense of the above statement by understanding the below code. If you see the flow of the below code:
Method()
gets called from theStatic void main()
entry point.Method()
spawns aTask
(thread)LongTask
which waits for 10 seconds.- At the same time the control comes back to
Method()
to execute the remaining code after the task was called. In other words as the invocation is multi-threaded (Task.Run
…),LongTask
is also running i.e., waiting for 10 seconds and the remaining code of yourMethod()
is also executed.
LongTask()
finishes execution, the control should go back to Method
to execute the remaining code. The async
and await
keywords help to achieve the above behavior.async
and await
keywords:async
andawait
are pair keywords. You cannot use them in a standalone manner.async
is marked on a method. This keyword is just an indicator saying that this method will have theawait
keyword.- The
await
keyword marks the position from where the task should resume. So you will always find this keyword in conjunction withTask
.
async
and await
.
All the other steps remain the same but “Step 3” is executed after
“Step 2” completes. In simple words the control comes back to Method()
after the task has finished operation.Task.Wait
or Task.ContinueWith
, so how do they differ? I am leaving this question as a home work for you.Feature 2: Zip facility (Zip compression)
Zip is one of the most accepted archive file formats. Zip format is supported in almost all operating systems with some built-in name.
- In Windows operating system it’s implemented by the name “Compressed folders”.
- In MAC OS it’s implemented by the name “Archive utility”.
System.IO.Compression
.The first step is you need to reference two namespaces:
System.IO.Compression.FileSystem
System.IO.Compression
using System.IO.Compression;
If you want to Zip files from a folder you can use the CreateFromDirectory
function as shown below.ZipFile.CreateFromDirectory(@"D:\data",@"D:\data.zip");
If you wish to unzip, you can use the ExtractToDirectory
function as shown in the below code.ZipFile.ExtractToDirectory(@"D:\data.zip", @"D:\data\unzip");
Feature 3: Regex timeout (TimeOut)
“Regex” has been the most preferred way of doing validations. In case you are new to Regex, please see the Regex video where I have explained how regex is implemented. But because of the typical parsing logic of regex it is exposed to DOS attacks. Let us try to understand in detail what I mean by that.
For instance consider this regular expression - “^(\d+)$”. This regex expression says that it can have only numbers. You can also see the regex symbolic diagram which shows how the regex will be evaluated .Now let’s say if we want to validate “123456X”. It will have six paths as shown in the below figure.
The proper solution for this would be to have a timeout on the regex operation. Good news, in .NET 4.5 you can now define a timeout property as shown in the below code. So if you get any kind of malicious string, the application will not go in a loop forever.
try { var regEx = new Regex(@”^(\d+)+$”, RegexOptions.Singleline, TimeSpan.FromSeconds(2)); var match = regEx.Match(“123453109839109283090492309480329489812093809x”); } catch (RegexMatchTimeoutException ex) { Console.WriteLine(“Regex Timeout”); }
Feature 4: Profile optimization (Improved startup performance)
We all know .NET code is in a half compiled format. During runtime, the JIT (Just-in-Time) compiler runs and translates this half compiled IL code to native machine code. One of the big complaints about JIT is that when a .NET applications runs the first time, it runs slow as JIT is busy translating IL code to machine code.
In order to bring down this startup time, in .NET 4.5, we have something called “profile optimization”. Profile is nothing but a simple file which has a list of methods which the application will need during startup. So when the application starts, a background JIT runs and starts translating IL code for those methods into machine / native code.
This background JIT compilation of startup methods happens across multiple processors thus minimizing the start up time further. Also note you need to have a multicore box to implement profile optimization. In case you do not have a multicore box then this setting is ignored.
System.Runtime
namespace. You can then call the SetProfileRoot
and StartProfile
methods of the static class ProfileOptimization
.
Now when the application starts the background JIT it will read from
the profile file and compile your start up methods in the background
thus reducing your startup time.using System.Runtime; // Call the Setprofilerroot and Startprofile method ProfileOptimization.SetProfileRoot(@"D:\ProfileFile"); ProfileOptimization.StartProfile("ProfileFile"); One important note:
Profileoptimization
is enabled by
default for ASP.NET 4.5 and Silverlight 5 applications. So the above
code need not be written for these technologies.
Feature 5: Garbage collector (GC background cleanup)
Garbage collector is one real heavy task in a .NET application. And it becomes heavier when it is an ASP.NET application. ASP.NET applications run on the server and a lot of clients send requests to the server thus creating loads of objects, making the GC really work hard for cleaning up unwanted objects.
At some point of time the background GC runs and starts clean up. When these background GCs start cleanup, they suspend all the application threads. This makes the server/application less responsive for that moment.
gcServer
XML tag and enable it to true
.<configuration>
<runtime>
<gcServer enabled="true"/>
</runtime>
</configuration>
Three more features worth exploring
Set default culture to App Domain
In the previous versions of .NET if I needed to set culture I needed to do it in every thread. Below is a sample code which demonstrates the pain of setting culture at thread levels. That was a real pain when we had heavily multi-threaded applications.CultureInfo cul = new CultureInfo(strCulture); Thread.CurrentThread.CurrentCulture = cul; Thread.CurrentThread.CurrentUICulture = cul; In 4.5 we can set culture at the app domain level and all the threads inside that appdomain will inherit that culture. Below is a sample code of how to implement
DefaultThreadCurrentCulture
.CultureInfo culture = CultureInfo.CreateSpecificCulture("fr-FR"); CultureInfo.DefaultThreadCurrentCulture = culture;
Array support more than two gigabyte size
I am not sure in what kind of a scenario we would need a 2 GB collection. So I personally do not see where we would need this feature. If I ever need such a big collection I would break it into parts. But I am sure there should be a good reason for this feature to be enabled in the framework.Unicode support for console
I left this feature out from the discussion as very less people work with console applications. I have seen people using consoles for academic purposes. All said and done we now have Unicode support for console apps also.References
-
.NET for Windows Store Apps
-
Portable Class Libraries
-
Core New Features and Improvements
-
Tools
-
Parallel Computing
-
Web
-
Networking
-
Windows Presentation Foundation (WPF)
-
Windows Communication Foundation (WCF)
-
Windows Workflow Foundation (WF)
Saturday, June 1, 2013
Delete File Form FTP Server ASP.NET
string fullpath = "ftp server path" + lblName.Text;
FtpWebRequest request = (FtpWebRequest)WebRequest.Create(new Uri(fullpath));
request.Method = WebRequestMethods.Ftp.DeleteFile;
request.Credentials = new NetworkCredential("user","password ");
request.UsePassive = true;
request.UseBinary = true;
request.KeepAlive = true;
request.Timeout = 100000;
FtpWebResponse response = (FtpWebResponse)request.GetResponse();
response.Close();
FtpWebRequest request = (FtpWebRequest)WebRequest.Create(new Uri(fullpath));
request.Method = WebRequestMethods.Ftp.DeleteFile;
request.Credentials = new NetworkCredential("user","password ");
request.UsePassive = true;
request.UseBinary = true;
request.KeepAlive = true;
request.Timeout = 100000;
FtpWebResponse response = (FtpWebResponse)request.GetResponse();
response.Close();
Getting file List From FTP Server ASP.NET
public void directoryListSimple()
{
DataTable dt = new DataTable();
dt.Columns.Add("Name");
StringBuilder result = new StringBuilder();
FtpWebRequest request = (FtpWebRequest)WebRequest.Create(new Uri("FTP path"));
request.UseBinary = true;
request.Method = WebRequestMethods.Ftp.ListDirectory;
request.Credentials = new NetworkCredential("user name", "password");
request.UsePassive = true;
request.UseBinary = true;
request.KeepAlive = true;
request.Timeout = 100000;
FtpWebResponse response = (FtpWebResponse)request.GetResponse();
Stream responseStream = response.GetResponseStream();
StreamReader reader = new StreamReader(responseStream);
string line = reader.ReadLine();
while (line!=null)
{
DataRow dr = dt.NewRow();
result.Append(line);
result.Append("\n");
line = reader.ReadLine();
if (line != null)
{
dt.Rows.Add(line.ToString());
}
}
Sftpfile.DataSource = dt;
Sftpfile.DataBind();
result.Remove(result.ToString().LastIndexOf('\n'), 1);
//responseDir.Close();
result.ToString().Split('\n');
reader.Close();
response.Close();
}
{
DataTable dt = new DataTable();
dt.Columns.Add("Name");
StringBuilder result = new StringBuilder();
FtpWebRequest request = (FtpWebRequest)WebRequest.Create(new Uri("FTP path"));
request.UseBinary = true;
request.Method = WebRequestMethods.Ftp.ListDirectory;
request.Credentials = new NetworkCredential("user name", "password");
request.UsePassive = true;
request.UseBinary = true;
request.KeepAlive = true;
request.Timeout = 100000;
FtpWebResponse response = (FtpWebResponse)request.GetResponse();
Stream responseStream = response.GetResponseStream();
StreamReader reader = new StreamReader(responseStream);
string line = reader.ReadLine();
while (line!=null)
{
DataRow dr = dt.NewRow();
result.Append(line);
result.Append("\n");
line = reader.ReadLine();
if (line != null)
{
dt.Rows.Add(line.ToString());
}
}
Sftpfile.DataSource = dt;
Sftpfile.DataBind();
result.Remove(result.ToString().LastIndexOf('\n'), 1);
//responseDir.Close();
result.ToString().Split('\n');
reader.Close();
response.Close();
}
Get List of all files From Folder C#
string fullpath="Full path";
DirectoryInfo dirInfo = new DirectoryInfo(fullpath);
FileInfo[] fileInfo = dirInfo.GetFiles("*.*", SearchOption.AllDirectories);
DirectoryInfo dirInfo = new DirectoryInfo(fullpath);
FileInfo[] fileInfo = dirInfo.GetFiles("*.*", SearchOption.AllDirectories);
Upload file by FTP ASP.NET
string uri="www.abc.com";
string file = "ful path of local file";
string usename="usename";
string password="password";
string DName="Server Directory Name";
public void UploadFile(string uri, string file, string usename, string password, string DName)
{
string fullpath = "ftp://ftp." + uri + "/" + uri + "/wwwroot/" + DName + "/";
FtpWebRequest request = (FtpWebRequest)FtpWebRequest.Create(new Uri(fullpath + fileToUpload.FileName));
request.Method = WebRequestMethods.Ftp.MakeDirectory;
request.Method = WebRequestMethods.Ftp.UploadFile;
request.Credentials = new NetworkCredential(usename, password);
request.UsePassive = true;
request.UseBinary = true;
request.KeepAlive = false;
request.Timeout = 100000;
//Load the file
FileStream stream = File.OpenRead(file);
byte[] buffer = new byte[stream.Length];
stream.Read(buffer, 0, buffer.Length);
stream.Close();
//Upload file
Stream reqStream = request.GetRequestStream();
reqStream.Write(buffer, 0, buffer.Length);
reqStream.Close();
lblmsg.Visible = true;
lblmsg.Text = "File upload successfully";
}
string file = "ful path of local file";
string usename="usename";
string password="password";
string DName="Server Directory Name";
public void UploadFile(string uri, string file, string usename, string password, string DName)
{
string fullpath = "ftp://ftp." + uri + "/" + uri + "/wwwroot/" + DName + "/";
FtpWebRequest request = (FtpWebRequest)FtpWebRequest.Create(new Uri(fullpath + fileToUpload.FileName));
request.Method = WebRequestMethods.Ftp.MakeDirectory;
request.Method = WebRequestMethods.Ftp.UploadFile;
request.Credentials = new NetworkCredential(usename, password);
request.UsePassive = true;
request.UseBinary = true;
request.KeepAlive = false;
request.Timeout = 100000;
//Load the file
FileStream stream = File.OpenRead(file);
byte[] buffer = new byte[stream.Length];
stream.Read(buffer, 0, buffer.Length);
stream.Close();
//Upload file
Stream reqStream = request.GetRequestStream();
reqStream.Write(buffer, 0, buffer.Length);
reqStream.Close();
lblmsg.Visible = true;
lblmsg.Text = "File upload successfully";
}
Subscribe to:
Posts (Atom)
Opps Part 1 : Abstraction
Abstraction in C# is a fundamental concept of object-oriented programming (OOP) that allows developers t...
-
<html> <body> <table> <tr><td>Text to Save:</td></tr> <tr> <td colspan="3...
-
SQL Server has several fixed database roles such as db_datareader and db_datawriter , which grants the user read and write access res...
-
Get Yahoo Contact for C# Create new Website Create AppCode Folder Create OAuthBase.cs in AppCode Folder like us...