Show Line Numbers in Visual Studio
It is always better to have Line numbers displayed in Visual Studio when you debug your VB or C# Project. It is not turned on by default. you can turn it on as shown below
Software development blog to share from latest technology to classic solutions of famous and common issues of software development.
Sunday, July 17, 2011
Login and Registration Tips and Tricks
Although this is not specific to porting, this link provides tips and best practices for creating
user management pages for your sites. Since this blog is about asp.net I thought you might find it useful.
Free .Net ebooks Download
This post aims to give you free asp.net, vb.net, c#.net ebooks and tutorials. This free ebooks teaches you visual studio.Net, visual basic.Net, ActiveX, Vbscript, ASP.NET, VB.NET, C#.NET, J#, Crystal Report.NET, ADO.NET, Visual Basic, Visual C++, Visual J++, microsoft .net platforms, c net, asp net 2.0, microsoft visual interdev, visual basic 2005 and vb.net database, etc.
This site free .Net ebooks guides to learn .Net tips, programming introductions, scripting, asp.net with vb.net and c#.net, secure asp.net web applications, visual studio, etc.
The following are the free Dot NET and visual studio ebooks and tutorials provided by this site.
This site free .Net ebooks guides to learn .Net tips, programming introductions, scripting, asp.net with vb.net and c#.net, secure asp.net web applications, visual studio, etc.
The following are the free Dot NET and visual studio ebooks and tutorials provided by this site.
- 65 Tips for Migrating to Visual Studio .NET
- A Programmer's Introduction to Visual Basic.NET By Craig Utley and Jonathan Morrison
- ActiveX and VBScript
- ActiveX Programming Unleashed by Weiying Chen
- An Introduction to ASP .NET using Visual Basic .NET By Peter McMahon
- An Introduction to ASP.NET
- ASP.NET AJAX Roadmap
- ASP.NET Web Developer's Guide By Mesbah Ahmed, Chris Garrett, Jeremy Faircloth, and Chris Payne
- ASP.Net with C# - The Basis By Vijay Mukhi
- Beginning VB.NET, 2nd edition
- Building Secure ASP.NET Applications: Authentication, Authorization, and Secure Communication By J.D. Meier, Alex Mackman, Michael Dunner, and Srinath Vasireddy
- CodeNotes for .NET Edited by Gregory Brill
- CodeNotes for J# Edited By Gregory Brill
- COM and .NET Interoperability By Andrew Troelsen
- Dan Appleman's Developing ActiveX Components with Visual Basic 5.0
- Database Developer's Guide with Visual Basic 4, Second Edition By Roger Jennings
- Database Developer's Guide with Visual C++ 4, Second Edition By Roger Jennings & Peter Hipson
- Improving .NET Application Performance and Scalability By J.D. Meier, Srinath Vasireddy, Ashish Babbar, and Alex Mackman
- Inside ASP.NET Web Matrix By Alex Homer and Dave Sussman
- Introducing Microsoft Visual Basic 2005 for Developers
- Late Night ActiveX By Eric Tall and Mark Ginsburg
- Learning Crystal Reports for DotNet By Brian Bischof
- Mastering™ Visual Basic® .NET By Evangelos Petroutsos
- MetaData Tables by Vijay Mukhi , Akash Saraf and Sonal Mukhi
- Moving to ASP.NET: Web Development with VB .NET By Steve Harris and Rob Macdonald
- Programming the .NET Compact Framework in Visual Basic .NET by Paul Yao & David Durant
- Programming VB.NET - A Guide For Experienced Programmers By Gary Cornell
- Proxy in VB
- Sams Teach Yourself Visual Basic 6 in 24 Hours By Greg M. Perry
- Special Edition Using Microsoft Visual InterDev
- Special Edition Using Microsoft® Visual Studio for Enterprise Development
- Teach Yourself ActiveX in 21 Days By Sanders Kaufman, Jeff Perkins and Dina Fleet
- Teach Yourself VBScript in 21 Days by Keith Brophy, Timothy Koets
- Teach Yourself Visual J++ in 21 Days by Laura Lemay, David Olhasso, Charles Perkins, and Patrick Winters
- Upgrading Microsoft Visual Basic 6.0 to Microsoft Visual Basic .NET
- VBScript UNLEASHED By Petroutsos, Schongar, et al.
- Visual Basic .NET For Object-Oriented Programmers
- Visual Basic 6 Black Book By Steven Holzner
- WebSphere and .Net Interoperability Using Web Services
- WebSphere MQ Solutions in a Microsoft .NET Environment
- XML Web Services and Soap By Vijay Mukhi, Vikram Ramchand and Sonal Mukhi
Session keeps timing out when debugging iis7
I found out why this is happening. In IIS7 on the Application Pool, there are ping settings that will kill a session if it gets not response. This is great for production as it keeps iis running slim but when debugging in Visual Studio and stopping on a breakpoint that is nasty.
I found an article that explains how to disable the ping or extend the timeout period.
Application Pool Ping setting in IIS
http://technet.microsoft.com/en-us/library/cc725836.aspx
If you come across any tips, tricks or resource you think the group will find helpful please email them to Muhammad Nadir at nadir.fsd@gmail.com we will post them here.
I found an article that explains how to disable the ping or extend the timeout period.
Application Pool Ping setting in IIS
http://technet.microsoft.com/en-us/library/cc725836.aspx
If you come across any tips, tricks or resource you think the group will find helpful please email them to Muhammad Nadir at nadir.fsd@gmail.com we will post them here.
Required permissions cannot be acquired
If you get the following error message then this link provides you with the step by step to resolve it
http://marcoscavaleiro.blogspot.com/2006/11/failed-to-grant-minimum-permission.html
If you have any tips, tricks or resources that you think would assist the group please email them to Muhammad Nadir at nadir.fsd@gmail.com
and we will post them here.
http://marcoscavaleiro.blogspot.com/2006/11/failed-to-grant-minimum-permission.html
An unhandled exception occurred during the execution of the current
web request. Please review the stack trace for more information about the error
and where it originated in the code. Exception Details:
System.Security.Policy.PolicyException: Required permissions
cannot be acquired. Source Error: An unhandled exception was generated during
the execution of the current web request. Information regarding the origin and
location of the exception can be identified using the exception stack trace
below. Stack Trace: [PolicyException: Required permissions cannot be
acquired.]
System.Security.SecurityManager.ResolvePolicy(Evidence evidence,
PermissionSet
reqdPset, PermissionSet optPset, PermissionSet denyPset,
PermissionSet&
denied, Boolean checkExecutionPermission) +2770052
System.Security.SecurityManager.ResolvePolicy(Evidence evidence,
PermissionSet
reqdPset, PermissionSet optPset, PermissionSet denyPset,
PermissionSet&
denied, Int32& securitySpecialFlags, Boolean
checkExecutionPermission) +57
[FileLoadException: Could not load file or
assembly
'Microsoft.Practices.EnterpriseLibrary.Data.Configuration.Design,
Version=3.1.0.0, Culture=neutral, PublicKeyToken=null' or one of its
dependencies. Failed to grant minimum permission requests. (Exception from
HRESULT: 0x80131417)] System.Reflection.Assembly._nLoad(AssemblyName
fileName,
String codeBase, Evidence assemblySecurity, Assembly locationHint,
StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean
forIntrospection) +0
If you have any tips, tricks or resources that you think would assist the group please email them to Muhammad Nadir at nadir.fsd@gmail.com
and we will post them here.
Do NOT use Response.Close unless you really need to
I found out the hard way with a bug I was getting. A JSON call was truncating on me and it turns out a Response.Close was intermittantly removing the last character.
Here is the article: http://forums.iis.net/t/1152058.aspx
If you have any tips, tricks or resources that you think would assist the group please email them to Muhammad Nadir at nadir.fsd@gmail.com
and we will post them here.
Here is the article: http://forums.iis.net/t/1152058.aspx
If you have any tips, tricks or resources that you think would assist the group please email them to Muhammad Nadir at nadir.fsd@gmail.com
and we will post them here.
30 Simple Steps to Creating Sandbox Test Accounts.
I struggled all day trying to use the sandbox for PayPal then I found this forum article.
I found it so helpful that I have posted it here so others could benefit from it. If you come across articles, tips, tricks let me know and I will post them as well. You can email them to me at nadir.fsd@gmail.com
-----------------------------------------------------------------------------------------------
http://www.paypaldeveloper.com/pdn/board/message?board.id=sandbox&message.id=6035#M6035
After 6 hours of pain with PayPal support (or lack thereof) I present the following 30 step process to creating, confirming, and verifying test accounts through the broken Developer Central Sandbox.
I hope this helps other people, and that the years of life I've lost over the last several hours is worth it.
To Setup Sandbox and Get Test API Credentials:
Prerequisites:
* Create a user account to access the Developer Central Sandbox.
* Log in to the Sandbox account
* Create a Test Account of type 'seller'.
- This will throw an error message on saving, but it will still create the account. Click the Test Accounts tab to see the account it created.
Create Confirm the email address:
1. Create business test account (done in prerequisite above)
2. Log into PayPal Sandbox with test business account details created earlier.
3. Go to Profile Tab
4. Go to Email
5. Choose the email address and click 'Confirm'
6. Go back to the Sandbox Test Environment and click the Test Email tab
7. Open the email with subject line 'Activate Your PayPal Account'
8. From the email body, select the confirmation URL and paste into new browser window - it will load the PayPal site (in sandbox mode).
9. Log in with business account.
10. From the landing page, click the 'confirm email' link in the 'To Do List' box.
11. Click the 'click here if a link doesn't appear in the email' link.
12. Paste in the confirmation number from the email in step 8, and click confirm. A confirmation of success should be displayed.
13. Click Continue.
Create Bank Accounts For Test Business Account:
14. Click the Profile tab
15. Click Bank Accounts link
16. Create a fake bank account. Test Bank. Use BSB 242-200 for Australia. Any random integer for account number, so long as it's not already being used by another PayPal account. I ended up having to mash the keypad until I found an unused number.
17. Confirm the bank account by clicking the 'confirm' link after the step above.
18. Step 17 loads another page where you need to click 'Submit'.
19. Step 18 loads another page where you need to click 'I Agree'.
20. The account should now be verified.
21. Click the Profile Tab again.
22. Click API Setup
23. Click Request API Credentials
24. Select API Signature
25. Click I Agree, Click Submit.
26. Copy the details to a safe place for later reference.
Developer Central Sandbox
27. Go back to the Developer central sandbox and login with your account details created in the prerequisite section of this document (i.e., not your test business account, but your actual Developer Central Sandbox account).
28. The Test business account should now be verfied.
29. Click API Credentials tab.
30. The API credentials obtained in step 26 should appear.
I found it so helpful that I have posted it here so others could benefit from it. If you come across articles, tips, tricks let me know and I will post them as well. You can email them to me at nadir.fsd@gmail.com
-----------------------------------------------------------------------------------------------
http://www.paypaldeveloper.com/pdn/board/message?board.id=sandbox&message.id=6035#M6035
After 6 hours of pain with PayPal support (or lack thereof) I present the following 30 step process to creating, confirming, and verifying test accounts through the broken Developer Central Sandbox.
I hope this helps other people, and that the years of life I've lost over the last several hours is worth it.
To Setup Sandbox and Get Test API Credentials:
Prerequisites:
* Create a user account to access the Developer Central Sandbox.
* Log in to the Sandbox account
* Create a Test Account of type 'seller'.
- This will throw an error message on saving, but it will still create the account. Click the Test Accounts tab to see the account it created.
Create Confirm the email address:
1. Create business test account (done in prerequisite above)
2. Log into PayPal Sandbox with test business account details created earlier.
3. Go to Profile Tab
4. Go to Email
5. Choose the email address and click 'Confirm'
6. Go back to the Sandbox Test Environment and click the Test Email tab
7. Open the email with subject line 'Activate Your PayPal Account'
8. From the email body, select the confirmation URL and paste into new browser window - it will load the PayPal site (in sandbox mode).
9. Log in with business account.
10. From the landing page, click the 'confirm email' link in the 'To Do List' box.
11. Click the 'click here if a link doesn't appear in the email' link.
12. Paste in the confirmation number from the email in step 8, and click confirm. A confirmation of success should be displayed.
13. Click Continue.
Create Bank Accounts For Test Business Account:
14. Click the Profile tab
15. Click Bank Accounts link
16. Create a fake bank account. Test Bank. Use BSB 242-200 for Australia. Any random integer for account number, so long as it's not already being used by another PayPal account. I ended up having to mash the keypad until I found an unused number.
17. Confirm the bank account by clicking the 'confirm' link after the step above.
18. Step 17 loads another page where you need to click 'Submit'.
19. Step 18 loads another page where you need to click 'I Agree'.
20. The account should now be verified.
21. Click the Profile Tab again.
22. Click API Setup
23. Click Request API Credentials
24. Select API Signature
25. Click I Agree, Click Submit.
26. Copy the details to a safe place for later reference.
Developer Central Sandbox
27. Go back to the Developer central sandbox and login with your account details created in the prerequisite section of this document (i.e., not your test business account, but your actual Developer Central Sandbox account).
28. The Test business account should now be verfied.
29. Click API Credentials tab.
30. The API credentials obtained in step 26 should appear.
Debugging Windows Services
In the current project, I have to develop some windows services to sending out notification mails. The first challenge I faced is I can't directly run and debug the Windows service. For that I need to install the service (using installutil –I ServiceName) and attach the process to Visual studio, and then only I can debug it. It works fine for me. Then the next challenge was, debugging the code in the onStart event. Because once the service started, then only we can able to attach it to Visual Studio. So I put some code to write to text file, and/or event log. But I feel like it's not a good method. After searching in the net I got a nice workaround.
protected override void OnStart(string[] args)
{
System.Diagnostics.Debugger.Launch();
//Rest of the code
}
While starting the Service, it will display a dialog like this
After selecting Yes, Visual Studio will open up and you can start debugging. You can get more information from these links
protected override void OnStart(string[] args)
{
System.Diagnostics.Debugger.Launch();
//Rest of the code
}
While starting the Service, it will display a dialog like this
After selecting Yes, Visual Studio will open up and you can start debugging. You can get more information from these links
WPF Menu - How to implement Shortcut Keys
WPF Menu - How to implement Shortcut Heys
There are many ways to add shortcut keys in WPF
# Using Underscore - In the Header Property, put the "_" before the Text, and you can use "ALT+<Key>". This is not Shortcut key, it is normally called "HotKey"
# Using InputGestureText - This is the way Visual Studio gives directly. - You can set a Key combination directly over here.
But it will invoke the click event, even if we use the Key combination. This is for display purpose only.
#Using CommandBindings - - I found this way is better and easier one
Happy WPF Programming :)
There are many ways to add shortcut keys in WPF
# Using Underscore - In the Header Property, put the "_" before the Text, and you can use "ALT+<Key>". This is not Shortcut key, it is normally called "HotKey"
1: <MenuItem Header="_Open" />
1: <MenuItem Header="_Open" InputGestureText="Ctrl + O" />
#Using CommandBindings - - I found this way is better and easier one
- In the markup create the command Bindings using Command Collections.
<CommandBinding Command="ApplicationCommands.Open" CanExecute="CommandCanExecute" Executed="CommandExecuted" />
<CommandBinding Command="ApplicationCommands.Close" CanExecute="CommandCanExecute" Executed="CommandExecuted" />
- In the code implement the event Handlers.
1: Sub CommandExecuted(ByVal sender As Object, ByVal e As ExecutedRoutedEventArgs)
2: 'Add the commands to be executed.
3: If e.Command.Equals(ApplicationCommands.Open) Then
4: MessageBox.Show("Open Menu item clicked")
5: ElseIf e.Command.Equals(ApplicationCommands.Close) Then
6: MessageBox.Show("Close menu item clicked")
7: End If
8: End Sub
9: Sub CommandCanExecute(ByVal sender As Object, ByVal e As CanExecuteRoutedEventArgs)
10: e.CanExecute = True 'I am always returning true, based on this the menu item will enabled / disabled
11: End Sub
- Assign the Commands to the Command property of our menu items.
<MenuItem Command="ApplicationCommands.Open" > <Separator />
<MenuItem Command="ApplicationCommands.Close" />
Compile it run it. You will see "Ctrl + O" added to the right side Open menu item.
You can see Ctrl + O added into the Open Menu item(Screenshot)
Happy WPF Programming :)
A Simple Splash screen in C#
I started my .net career in VB.Net. While developing a windows application in VB.Net it is pretty easy to put a Splash screen. There is Project property called Splash screen and you can put any form there, after that the specified form will act as a Splash screen. But when I started an windows application in C#, there is no project property called Splash screen. While doing some searching, I found lot of ways, like Putting a timer and closing the splash etc. But I feel like it is not the right way of doing a splash screen, then I started my own implementation and found one. I am not sure it is good one or not, but it is working for me.
Here is the steps:
1) Added one Form with an Image, as Splashscreen.cs, and my main UI is Welcome.cs
2) In the Program.cs I modified the code like the following
[STAThread]
static void Main()
{
Application.ApplicationExit += new EventHandler(Application_ApplicationExit);
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
SplashScreen s = new SplashScreen();
s.Show();
Welcome welcome = new Welcome(s);
Application.Run(welcome);
}
3) And in the Welcome.cs, added one parameterized constructor, with SplashScreen as the Parameter
SplashScreen _s = null;
public Welcome(SplashScreen s)
{
InitializeComponent();
this._s = s;
}
4) And in the Form_Load() event I added code to close the splash screen if exists.
if (this._s != null) { this._s.Close(); }
5) Run the application, see the splash is coming and after that Main UI is coming
Here is the steps:
1) Added one Form with an Image, as Splashscreen.cs, and my main UI is Welcome.cs
2) In the Program.cs I modified the code like the following
[STAThread]
static void Main()
{
Application.ApplicationExit += new EventHandler(Application_ApplicationExit);
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
SplashScreen s = new SplashScreen();
s.Show();
Welcome welcome = new Welcome(s);
Application.Run(welcome);
}
3) And in the Welcome.cs, added one parameterized constructor, with SplashScreen as the Parameter
SplashScreen _s = null;
public Welcome(SplashScreen s)
{
InitializeComponent();
this._s = s;
}
4) And in the Form_Load() event I added code to close the splash screen if exists.
if (this._s != null) { this._s.Close(); }
5) Run the application, see the splash is coming and after that Main UI is coming
ASP.NET 2.0 Chat that uses Membership functionality
AspxChat - generic MsAjax-based chatting control for ASP.Net 2
- Uses standard ASP.Net 2.0 Membership functionality to manage users, which allows a seamless integration into existing applications that use Membership without a single line of code
- Utilizes Microsoft AJAX Extensions to present a user interface in asynchronous fashion, that is: without continuous page refreshes
- Provide a simple administrative interface for users in Administrator role
- Provide a generic voting functionality with a Yes/Now poll
- Uses implicit localization feature of ASP.Net 2.0 to present a user interface in different languages (English, Ukrainian and Russian localization included)
- Uses ASP.Net 2.0 Themes feature to fine tune user interface
- Provide a default page with a standard ASP.Net 2.0 Login control to enable using AspxChat as a stand-alone application
- AspxChat is configurable with a standard web.config file (presently only 2 parameters can be customized: history depth and default name for non-authenticated users)
Freehand drawing with .Net Windows forms
Few days back, I got a requirement to implement Free Hand drawing in .Net. I searched a lot but I didn't get any good solution, the one I found from code project was Invalidating the picture box every time. So today I got a solution, it not seems to be a perfect solution because Paint events occurs, we need to re-paint the whole lines again.
I am attaching the code here. I will update the post once I get some perfect solution for this.
Private m_Drawing As Boolean = False
Private m_List As List(Of Point) = Nothing
Private Sub MyPic_MouseDown(ByVal sender As System.Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyPic.MouseDown
If e.Button = Windows.Forms.MouseButtons.Left Then
m_Drawing = True
End If
End Sub
Private Sub MyPic_MouseUp(ByVal sender As System.Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyPic.MouseUp
If m_Drawing AndAlso m_List IsNot Nothing Then
If m_List.Count >= 2 Then
MyPic.CreateGraphics.DrawLines(New Pen(Color.Blue, 1), m_List.ToArray())
End If
m_Drawing = False
m_List.Clear()
End If
End Sub
Private Sub MyPic_MouseMove(ByVal sender As System.Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyPic.MouseMove
If m_List IsNot Nothing AndAlso m_Drawing Then
m_List.Add(e.Location)
End If
End Sub
Private Sub frmMain_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
m_List = New List(Of Point)
End Sub
I am attaching the code here. I will update the post once I get some perfect solution for this.
Private m_Drawing As Boolean = False
Private m_List As List(Of Point) = Nothing
Private Sub MyPic_MouseDown(ByVal sender As System.Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyPic.MouseDown
If e.Button = Windows.Forms.MouseButtons.Left Then
m_Drawing = True
End If
End Sub
Private Sub MyPic_MouseUp(ByVal sender As System.Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyPic.MouseUp
If m_Drawing AndAlso m_List IsNot Nothing Then
If m_List.Count >= 2 Then
MyPic.CreateGraphics.DrawLines(New Pen(Color.Blue, 1), m_List.ToArray())
End If
m_Drawing = False
m_List.Clear()
End If
End Sub
Private Sub MyPic_MouseMove(ByVal sender As System.Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyPic.MouseMove
If m_List IsNot Nothing AndAlso m_Drawing Then
m_List.Add(e.Location)
End If
End Sub
Private Sub frmMain_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
m_List = New List(Of Point)
End Sub
ASP.NET, ASP.NET MVC, .NET and NuGet
Here is the latest in my link-listing series. Also check out my Best of 2010 Summary for links to 100+ other posts I've done in the last year.
[I am also now using Twitter for quick updates and to share links. Follow me at: twitter.com/scottgu]
Scott
[I am also now using Twitter for quick updates and to share links. Follow me at: twitter.com/scottgu]
ASP.NET
- Introducing new ASP.NET Universal Providers: Great post from Scott Hanselman on the new System.Web.Providers we are working on. This release delivers new ASP.NET Membership, Role Management, Session, Profile providers that work with SQL Server, SQL CE and SQL Azure.
- CSS Sprites and the ASP.NET Sprite and Image Optimization Library: Great post from Scott Mitchell that talks about a free library for ASP.NET that you can use to optimize your CSS and images to reduce HTTP requests and speed up your site.
- Better HTML5 Support for the VS 2010 Editor: Another great post from Scott Hanselman on an update several people on my team did that enables richer HTML5 editing support within Visual Studio 2010.
- Install the Ajax Control Toolkit from NuGet: Nice post by Stephen Walther on how you can now use NuGet to install the Ajax Control Toolkit within your applications. This makes it much easier to reference and use.
- May 2011 Release of the Ajax Control Toolkit: Another great post from Stephen Walther that talks about the May release of the Ajax Control Toolkit. It includes a bunch of nice enhancements and fixes.
- SassAndCoffee 0.9 Released: Paul Betts blogs about the latest release of his SassAndCoffee extension (available via NuGet). It enables you to easily use Sass and Coffeescript within your ASP.NET applications (both MVC and Webforms).
ASP.NET MVC
- ASP.NET MVC Mini-Profiler: The folks at StackOverflow.com (a great site built with ASP.NET MVC) have released a nice (free) profiler they've built that enables you to easily profile your ASP.NET MVC 3 sites and tune them for performance.
- Globalization, Internationalization and Localization in ASP.NET MVC 3: Great post from Scott Hanselman on how to enable internationalization, globalization and localization support within your ASP.NET MVC 3 and jQuery solutions.
- Precompile your MVC Razor Views: Great post from David Ebbo that discusses a new Razor Generator tool that enables you to pre-compile your razor view templates as assemblies – which enables a bunch of cool scenarios.
- Unit Testing Razor Views: Nice post from David Ebbo that shows how to use his new Razor Generator to enable unit testing of razor view templates with ASP.NET MVC.
- Bin Deploying ASP.NET MVC 3: Nice post by Phil Haack that covers a cool feature added to VS 2010 SP1 that makes it really easy to \bin deploy ASP.NET MVC and Razor within your application. This enables you to easily deploy the app to servers that don't have ASP.NET MVC 3 installed.
.NET
- Table Splitting with EF 4.1 Code First: Great post from Morteza Manavi that discusses how to split up a single database table across multiple EF entity classes. This shows off some of the power behind EF 4.1 and is very useful when working with legacy database schemas.
- Choosing the Right Collection Class: Nice post from James Michael Hare that talks about the different collection class options available within .NET. A nice overview for people who haven't looked at all of the support now built into the framework.
- Little Wonders: Empty(), DefaultIfEmpty() and Count() helper methods: Another in James Michael Hare's excellent series on .NET/C# "Little Wonders". This post covers some of the great helper methods now built-into .NET that make coding even easier.
NuGet
- NuGet 1.4 Released: Learn all about the latest release of NuGet – which includes a bunch of cool new capabilities. It takes only seconds to update to it – go for it!
- NuGet in Depth: Nice presentation from Scott Hanselman all about NuGet and some of the investments we are making to enable a better open source ecosystem within .NET.
- NuGet for the Enterprise – NuGet in a Continuous Integration Automated Build System: Great post from Scott Hanselman on how to integrate NuGet within enterprise build environments and enable it with CI solutions.
Scott
Great Free Video Training on ASP.NET Web Forms and ASP.NET MVC
We've recently published some great end-to-end ASP.NET video training courses on the http://asp.net web-site.
Created by Pluralsight (a great .NET training company), these video courses are available free of charge and provide a great way to learn (or brush-up your knowledge of) ASP.NET Web Forms 4 and ASP.NET MVC 3. Each course is taught by a single trainer, and provides a nice end-to-end curriculum (from basic concepts to working with the new Entity Framework "code first" model to security, deployment, and testing).
Below are some details on the two free training courses we published this weekend (and links for how to watch them):
Below is a breakdown of the 10 video modules in the ASP.NET MVC 3 series:
You can watch the series for free on the http://asp.net/web-forms page (it is on the left-hand side within the "Essential Videos" section):
Below is a breakdown of the 9 video modules in the ASP.NET Web Forms series:
Hope this helps,
Scott
P.S. In addition to blogging, I am also now using Twitter for quick updates and to share links. Follow me at: twitter.com/scottgu
Created by Pluralsight (a great .NET training company), these video courses are available free of charge and provide a great way to learn (or brush-up your knowledge of) ASP.NET Web Forms 4 and ASP.NET MVC 3. Each course is taught by a single trainer, and provides a nice end-to-end curriculum (from basic concepts to working with the new Entity Framework "code first" model to security, deployment, and testing).
Below are some details on the two free training courses we published this weekend (and links for how to watch them):
ASP.NET MVC 3 Training
This weekend we posted the final videos in a brand new 10 part ASP.NET MVC 3 training course taught by K Scott Allen. You can now watch the entire series for free on the http://asp.net/mvc page (it is on the left-hand side within the "Essential Videos" section):Below is a breakdown of the 10 video modules in the ASP.NET MVC 3 series:
- Introduction (35 minutes)
- Controllers (35 minutes)
- Razor Views (45 minutes)
- Working with Data: Entity Framework Code First (39 minutes)
- Working with Data: Validation and Mapping (33 minutes)
- Javascript, jQuery and Ajax (47 minutes)
- Security (43 minutes)
- Caching, Localization, Resources and Diagnostics (34 minutes)
- Unit Testing (37 minutes)
- Deployment and Configuration (37 minutes)
ASP.NET Web Forms 4 Training
Dan Wahlin is developing a great course on ASP.NET Web Forms 4.You can watch the series for free on the http://asp.net/web-forms page (it is on the left-hand side within the "Essential Videos" section):
Below is a breakdown of the 9 video modules in the ASP.NET Web Forms series:
- Introduction to ASP.NET (64 minutes)
- ASP.NET Web Forms Features (111 minutes)
- Working with Data (75 minutes)
- Entity Framework (47 minutes)
- Master Pages (24 minutes)
- JavaScript and Ajax (62 minutes)
- Security (coming soon)
- Using ASP.NET Dynamic Data (coming soon)
- Web Deployment (coming soon)
Even More Content Coming
Keep an eye on the http://asp.net/web-forms and http://asp.net/mvc learning centers in the months ahead as we post even more textual and video training content. Each of the two learning centers now has a nice structured outline of content that you can use to quickly look things up as well as learn how ASP.NET works. We'll be refining and extending the content even more in the weeks and months ahead.Hope this helps,
Scott
P.S. In addition to blogging, I am also now using Twitter for quick updates and to share links. Follow me at: twitter.com/scottgu
ASP.NET MVC 3 and the @helper syntax within Razor
ASP.NET MVC 3 supports a new view-engine option called "Razor" (in addition to continuing to support/enhance the existing .aspx view engine). Razor minimizes the number of characters and keystrokes required when writing a view template, and enables a fast, fluid coding workflow.
Unlike most template syntaxes, with Razor you do not need to interrupt your coding to explicitly denote the start and end of server blocks within your HTML. The Razor parser is smart enough to infer this from your code. This enables a compact and expressive syntax which is clean, fast and fun to type.
You can learn more about Razor from some of the blog posts I've done about it over the last last 9 months:
Code before we define a @helper method
Let's look at a simple product listing scenario where we list product details, and output either the price of the product – or the word "FREE!" if the item doesn't cost anything:
The above code is fairly straight-forward, and Razor's syntax makes it easy to integrate server-side C# code within the HTML.
One place that is a little messy, though, is the if/else logic for the price. We will likely output prices elsewhere within the site (or within the same page), and duplicating the above logic everywhere would be error-prone and hard to maintain. Scenarios like this are prime candidates to extract and refactor into helper methods using the @helper syntax.
Refactoring the above sample using the @helper syntax
Let's extract the price output logic, and encapsulate it within a helper method that we'll name "DisplayPrice". We can do this by re-writing the sample to the code below:
We've used the @helper syntax above to define a reusable helper method named "DisplayPrice". Just like a standard C#/VB method, it can contain any number of arguments (you can also define the arguments to be either nullable or optional). Unlike standard C#/VB methods, though, @helper methods can contain both content and code, and support the full Razor syntax within them – which makes it really easy to define and encapsulate rendering/formatting helper methods:
You can invoke @helper methods just like you would a standard C# or VB method:
Visual Studio will provide code intellisense when invoking the method:
We can accomplish this by saving our @helper methods within .cshtml/.vbhtml files that are placed within a \App_Code directory that you create at the root of a project. For example, below I created a "ScottGu.cshtml" file within the \App_Code folder, and defined two separate helper methods within the file (you can have any number of helper methods within each file):
Once our helpers are defined at the app level, we can use them within any view template of our application.
The ScottGu.cshtml template in the \App_Code folder above will logically compile down to a class called "ScottGu" with static members of "DisplayPrice" and "AnotherHelper" within it. We can re-write our previous sample to call it using the code below:
Visual Studio will provide code intellisense when calling app-level helpers like this:
May 15th Update: One issue that a few people have pointed out is that when a @helper is saved within the \app_code directory, you don't by default get access to the ASP.NET MVC Html helper methods within it (e.g. Html.ActionLink(), Html.TextBox(), etc). You do get access to the built-in HTML helper methods when they are defined in the same file as your views. This is not supported out of the box, though, when the helpers are within the \app_code directory - we'll add this in the next release. Paul Stovall has a nice helper class that you can use in the meantime to access and use the built-in Html helper methods within @helper methods you define in the \app_code directory. You can learn how to use it here.
You can use this functionality to write code that is even cleaner and more maintainable.
Hope this helps,
Scott
P.S. In addition to blogging, I am also now using Twitter for quick updates and to share links. Follow me at: twitter.com/scottgu
Unlike most template syntaxes, with Razor you do not need to interrupt your coding to explicitly denote the start and end of server blocks within your HTML. The Razor parser is smart enough to infer this from your code. This enables a compact and expressive syntax which is clean, fast and fun to type.
You can learn more about Razor from some of the blog posts I've done about it over the last last 9 months:
- Introducing Razor
- New @model keyword in Razor
- Layouts with Razor
- Server-Side Comments with Razor
- Razor's @: and <text> syntax
- Implicit and Explicit code nuggets with Razor
- Layouts and Sections with Razor
Simple @helper method scenario
The @helper syntax within Razor enables you to easily create re-usable helper methods that can encapsulate output functionality within your view templates. They enable better code reuse, and can also facilitate more readable code. Let's look at a super-simple scenario of how the @helper syntax can be used.Code before we define a @helper method
Let's look at a simple product listing scenario where we list product details, and output either the price of the product – or the word "FREE!" if the item doesn't cost anything:
The above code is fairly straight-forward, and Razor's syntax makes it easy to integrate server-side C# code within the HTML.
One place that is a little messy, though, is the if/else logic for the price. We will likely output prices elsewhere within the site (or within the same page), and duplicating the above logic everywhere would be error-prone and hard to maintain. Scenarios like this are prime candidates to extract and refactor into helper methods using the @helper syntax.
Refactoring the above sample using the @helper syntax
Let's extract the price output logic, and encapsulate it within a helper method that we'll name "DisplayPrice". We can do this by re-writing the sample to the code below:
We've used the @helper syntax above to define a reusable helper method named "DisplayPrice". Just like a standard C#/VB method, it can contain any number of arguments (you can also define the arguments to be either nullable or optional). Unlike standard C#/VB methods, though, @helper methods can contain both content and code, and support the full Razor syntax within them – which makes it really easy to define and encapsulate rendering/formatting helper methods:
You can invoke @helper methods just like you would a standard C# or VB method:
Visual Studio will provide code intellisense when invoking the method:
Reusing @helpers across multiple views
In the example above, we defined our @helper method within the same view template as the code that called it. Alternatively, we can define the @helper method outside of our view template, and enable it to be re-used across all of the view templates in our project.We can accomplish this by saving our @helper methods within .cshtml/.vbhtml files that are placed within a \App_Code directory that you create at the root of a project. For example, below I created a "ScottGu.cshtml" file within the \App_Code folder, and defined two separate helper methods within the file (you can have any number of helper methods within each file):
Once our helpers are defined at the app level, we can use them within any view template of our application.
The ScottGu.cshtml template in the \App_Code folder above will logically compile down to a class called "ScottGu" with static members of "DisplayPrice" and "AnotherHelper" within it. We can re-write our previous sample to call it using the code below:
Visual Studio will provide code intellisense when calling app-level helpers like this:
May 15th Update: One issue that a few people have pointed out is that when a @helper is saved within the \app_code directory, you don't by default get access to the ASP.NET MVC Html helper methods within it (e.g. Html.ActionLink(), Html.TextBox(), etc). You do get access to the built-in HTML helper methods when they are defined in the same file as your views. This is not supported out of the box, though, when the helpers are within the \app_code directory - we'll add this in the next release. Paul Stovall has a nice helper class that you can use in the meantime to access and use the built-in Html helper methods within @helper methods you define in the \app_code directory. You can learn how to use it here.
Summary
Razor's @helper syntax provides a convenient way to encapsulate rendering functionality into helper methods that you can re-use within individual view templates, or across all view templates within a project.You can use this functionality to write code that is even cleaner and more maintainable.
Hope this helps,
Scott
P.S. In addition to blogging, I am also now using Twitter for quick updates and to share links. Follow me at: twitter.com/scottgu
HTML5 Improvements with the ASP.NET MVC 3 Tools Update
Last week I blogged about the new ASP.NET MVC 3 Tools Update, and then followed it up with a detailed post that covered using the EF Code First and the new Data Scaffolding features in it.
Today's blog post is a continuation of this series and covers some of the new HTML5 improvements with the ASP.NET MVC 3 Tools Update release.
Project Template Support for HTML5 Semantic Markup
The ASP.NET MVC 3 Tools Update adds support for you to optionally use HTML5 semantic markup when creating new ASP.NET MVC 3 projects. You can specify this by checking the "Use HTML5 semantic markup" checkbox when creating new projects:Selecting this checkbox option does two things:
1) It causes VS 2010 to use HTML5 semantic markup elements like <header>, <footer>, <section> and <nav> within the default layout.cshtml file that is generated. This is instead of just using <div> elements for header/footer/navigation elements – which is the default behavior if the HTML5 semantic checkbox isn't selected (and the same behavior that we have shipped earlier).
2) It causes VS 2010 to reference the modernizr.js JavaScript library by default within the layout.cshtml – which among other things will allow you to use CSS to style HTML5 semantic markup elements even with older browsers like IE6 (ensuring your site still works for older browsers).
Understanding Semantic HTML5 Markup
HTML5 introduces a number of new elements and APIs that introduce new behavioral capability (features like <video>, <canvas>, <svg>, etc).HTML5 also introduces new elements (like <section>, <article>, <aside>, <header>, and <nav>) that enable you to enrich the semantic meaning and structure of your content and pages. These features allow you to write your pages so that you don't have to use opaque <div> elements to structure everything, and instead they allow you to better express the semantic meaning of your content. This makes your code a little cleaner to read, and long-term will hopefully enable browsers and search engines to better understand your markup and provide even richer experiences.
When you create a new ASP.NET MVC 3 Project with the "Use HTML5 semantic markup" checkbox selected, Visual Studio will use semantic HTML instead of <div> elements (where appropriate) within the layout.cshtml file that is generated for the new project. This means that the top of the site is wrapped in a <header> element, navigation links are surrounded by a <nav> element, and the footer is encapsulated within a <footer> element.
Learn more about Semantic HTML5 Markup
Bruce Lawson and Remy Sharp have a great Introducing HTML5 book that covers (among other new HTML5 features) how you can take advantage of semantic HTML5 markup:
You can also read Emily Lewis' Using HTML5's New Semantic Tags Today article on MSDN's ScriptJunkie site to learn more about the role of HTML5 semantic markup and see a practical example of it in action.
HTML5 Intellisense within VS 2010 SP1
With VS 2010 SP1, you can now change the "Target Schema for Validation" drop-down within the Text Editor toolbar to target HTML5 with intellisense:When you select HTML5 as your validation target, the HTML intellisense engine within Visual Studio will provide appropriate intellisense for the new HTML5 elements and attributes. This is true for both behavioral elements like <canvas> and <video> as well as semantic elements like <article> and <nav>:
Note: the next release of VS will default to honoring the <!DOCTYPE> at the top of the page when driving intellisense, and then allow you to specify a default standard to use when it isn't present (or when you are editing within user controls, or partial/editor templates). With VS 2010 and earlier versions of Visual Studio you have to explicitly set which HTML version you want to target.
Modernizr.js Library
Semantic HTML5 markup is now supported by all modern browser vendors, and you can use standard CSS techniques to stylize and customize pages built with it.One challenge, though, is that there are still a lot of older browsers out there – and browsers like IE6 by default don't allow you to stylize semantic HTML5 elements using CSS. The semantic HTML5 site that looks beautiful in a modern browser might end up looking broken unless you use a library that enables you to work around this limitation.
Modernizr.js
Modernizr is a small and elegant open-source JavaScript library that helps you take advantage of emerging web technologies (HTML5, CSS3) while still maintaining a level of compatibility with older browsers that may not yet support these new capabilities. You can learn more about Modernizr from the http://modernizr.com/ website.
Starting with the ASP.NET MVC 3 Tools Update, we are now shipping Modernizr with ASP.NET MVC 3, and adding it by default to all new ASP.NET MVC 3 projects. If you select the "Use HTML5 semantic markup" checkbox when creating new ASP.NET MVC 3 projects, Visual Studio will also add a reference to the Modernizr.js library by default within your layout.cshtml template:
Modernizr.js and using CSS with Semantic HTML5 on older Browsers
Including the above Modernizr.js script reference will enable you to use CSS to stylize semantic HTML5 elements – and have it work both in modern browsers (where it is natively supported), as well as older ones (including IE6). Among other things, Modernizr is smart enough to run a little script that will cause older browsers to honor CSS rules with unknown elements they encounter.
You can see the benefit Modernizr brings with this by running the default ASP.NET MVC 3 project that is created using IE9. If you use the default IE9 rendering mode (which supports Semantic HTML5 elements) the site will look like below, and use the browser's built-in CSS support for semantic HTML5:
If you enable "Compatibility View" within the browser (the second icon at the top of IE's navigation bar) – you'll see a "downlevel" rendering of the page (just like what IE6/7/8 users would see). Modernizr allows our CSS rules to work in this downlevel mode – despite the older IE rendering engine not natively supporting elements like <header>, <footer>, <nav>, <section>, etc:
If we had not included Modernizr.js on the page, visitors to the site using older browsers would have instead seen something broken like this:
As you can see – Modernizr provides a big improvement over what users with older browser would have otherwise seen! Best of all, we didn't have to write any code or author an alternative CSS style-sheet to get this to work. And we are using HTML5 Semantic Markup throughout the site.
Using Modernizr to Detect Browser Capabilities
The above Semantic HTML5 markup example is just one of the nice benefits that Modernizr brings.
Modernizr also makes it easy to check for browser capabilities (without you having to hard-code browser versions into code), and enables you to easily detect and light-up if a specific feature is supported. You can learn more about how this works on the http://modernizr.com web-site.
Justin Schwartzenberger has a nice blog post that shows this in action, and highlights How to use Modernizr with ASP.NET MVC 3 to store user data via HTML5 localstorage. His tutorial shows an end-to-end ASP.NET MVC 3 sample where he uses HTML5's localstorage feature if it is available, and falls back to just using cookies on older browsers.
Summary
The new ASP.NET MVC 3 Tooling Update is full of goodness. If you haven't already downloaded and installed it I highly recommend you do so. You can run the ASP.NET MVC 3 installer on the http://asp.net/mvc site to make sure you have the latest version.The HTML5 Semantic Markup improvements in ASP.NET MVC 3 enable you to start designing sites that take better advantage of HTML5 and modern browsers. Using Modernizr.js you can also have these sites continue to work with older browsers, and optionally light-up only when new features are enabled.
Hope this helps,
Scott
P.S. I am also now using Twitter for quick updates and to share links. Follow me at: twitter.com/scottgu
EF Code First and Data Scaffolding with the ASP.NET MVC 3 Tools Update
Earlier this week I blogged about the new ASP.NET MVC 3 Tools Update that we shipped last month.
In today's blog post I'm going to go into more detail about two of the cool new features it brings:
- Built-in support for EF 4.1 (which includes the new EF "code-first" support)
- Built-in data scaffolding support within Visual Studio (which enables you to rapidly create data-driven sites)
Scenario We'll Build
To help illustrate how to use the above features, we'll walkthrough building a simple data-drive site. It will support listing products:As well as creating/editing new products (and categories):
We can now build this entire application (and create the database that backs it) with ASP.NET MVC 3 in only a minute or two.
Step 1: Create New Project
We'll begin by creating a new ASP.NET MVC 3 project (using the File->New Project menu command). We'll use the "Internet Project" template – which will provide us with a default starter template for our application.When you look at the newly created project within the Solution Explorer, you'll see that the ASP.NET MVC 3 Tools update adds a new assembly – EntityFramework – to our ASP.NET MVC 3 projects:
The EntityFramework assembly implements Entity Framework 4.1 – which we also released last month. EF 4.1 brings with it a bunch of great data API improvements to .NET – including the new "code first" option. EF Code First provides a really elegant and clean way to work with data, and enables you to do so without requiring a designer or XML mapping file. You can now easily take advantage of this by default with all new ASP.NET MVC 3 projects.
We'll be using the EF Code First approach to implement our data access for this application.
Step 2: Implement Model Classes
Our first step will be to create two classes – Product and Category – that we'll use to define the "model" of our application. We'll implement these as standard "plain old C# objects" within the \Models folder of our project using the code below:Notice how the above classes are just standard classes with .NET data-types. They do not need to derive from any base class, nor implement any interfaces.
In addition to standard scalar properties, each class has an "association" property. For example, the "Product" class has a "Category" property that enables a developer to get access to the Category it belongs to. Likewise the "Category" class has a "Products" property that enables a developer to retrieve the Products that are within that particular Category. EF Code First can handle automatically managing these associations (using the Primary Key/Foreign Key values), and can lazy load the appropriate data on-demand.
Step 3: Implement a StoreContext Class using EF Code First
Now that we've defined our two model classes, our next step will be to implement a "DbContext" class using EF code First that will map the model classes to tables in a database. We'll implement this using the code below:The "StoreContext" class above is the DbContext class we are using to map our Product and Category classes to/from a database. It derives from the DbContext base class provided by EF Code First, and exposes two properties that correspond to tables within our database. For this sample we are using the default "convention over configuration" based mapping rules to define how the classes should map to/from the database. This means that the Products property will map to a Products table, and the Categories property will map to a Categories table. In later blog posts I'll talk about how you can optionally override this and perform custom mappings.
You can add the above class anywhere within your solution. For example, you could add it within the \Models folder of your project – or within a separate class library project if you prefer to keep your data code separate. You'll want to add a "using" statement to the System.Data.Entity namespace at the top of the class file (in order to reference the DbContext and DbSet<T> classes).
After you've saved the above class files, compile the project – you'll want to have built it before the next step.
Step 4: Scaffold a Categories Controller
We have everything we need to model our data and save/retrieve it from a database. Now let's create an ASP.NET MVC Controller class that will implement the support necessary to display our Category data and enable creating/editing/deleting Category objects. Prior to last month's ASP.NET MVC 3 Tools Update, you would have had to manually write a Controller class to do this (and implement all of the EF data access code yourself). The ASP.NET MVC 3 Tools Update now includes built-in "scaffolding" support that can help do this for you automatically.To scaffold a new Categories controller class, we'll right-click on the "/Controllers" folder of our project and choose the Add->Controller context menu:
Selecting Add->Controller will bring up the "Add Controller" dialog. We'll name the controller class we want to create "CategoriesController". Starting with last month's ASP.NET MVC 3 Tools Update, the "Add Controller" dialog also now supports a new "Scaffolding options" section – which enables you to choose to "scaffold" the new controller using a variety of built-in templates:
We'll choose the "Controller with read/write actions and views, using Entity Framework" template – which will create a Controller class that has all of the EF code necessary to create, update, list and delete model objects.
After selecting this template, we can choose the model class we want our Controller to implement CRUD support for – in this case the "Category" class. We can also select the EF DbContext/ObjectContext class that we want to use to access the database – in this case the "StoreContext" class we defined earlier:
When we click the "Add" button, Visual Studio will automatically create a CategoriesController class for us – with appropriate Create, Edit, Details, Delete and Index action methods inside it – as well associated view templates for each of the actions:
If you open the CategoriesController.cs class you'll find that the action methods within it implement the EF data access code necessary for CRUD support:
And now we have all of the code we need to implement data listing/editing for Categories within our database
Step 5: Configuring our Database Location
The last step we'll do before running our application is to point our application at the database we want to use. EF code first allows you to use an existing database you already have defined, or alternatively you can point it at a database that doesn't yet exist – in which case it will automatically create it for you using the model classes you've defined.No Connection-String
By default, you actually don't need to configure a connection-string to point at a database. If you don't specify one, EF Code-First will by default create a new SQL Express database whose name matches your DbContext class name (for example: above it would create a ScaffoldingDemo.Models.StoreContext database within your local .\SQLExpress database instance).
Explicitly Specifying a Connection-String
You can alternatively explicitly specify where you want your database to live by adding a connection-string to your application's web.config file. You'll want the name of the connection-string to match the DbContext class name. For example – in our application above our DbContext class was named "StoreContext", and so by default EF will look for a connection-string with the same name to determine the database location.
Below is the entry we'd add to our web.config file if we wanted to use an embedded SQL CE database named "Store.sdf" within our application's \App_data folder:
<configuration>
<connectionStrings>
<add name="StoreContext"
connectionString="Data Source=|DataDirectory|\Store.sdf"
providerName="System.Data.SqlServerCe.4.0" />
</connectionStrings>
</configuration>
You can learn more about SQL CE – and the new VS 2010 SP1 tooling support for it – from my previous blog post about it.
Step 6: Run the Application
Ok – let's now run the application and navigate to the /Categories URL. This will execute our CategoriesController's Index() method – which will list all categories in our database. Currently we don't have any:Let's click the "Create New" link to create a new category – this will navigate to the /Categories/Create URL, which provides us with a form to create a new category:
Clicking the "Create" button will post the form to our CategoriesController and add a new Category to our database. We can repeat this a few times to add several different categories:
The cool thing is that we didn't have to write any Controller or View code to enable this – the scaffolding support automatically generated the code we needed to enable this. This provides a really easy way to get started. We can then go in and tweak it as necessary to customize the functionality further.
Step 7: Looking at the database
We configured our application to use a connection-string that pointed to a SQL CE database that (at the time) didn't exist. When we ran our application, EF 4.1 detected that the database didn't exist and automatically created it for us – based on the Product and Category classes we defined earlier.To see the database, click the "Show All Files" icon at the top of Visual Studio's "Solution Explorer" and add the "Store.sdf" database that was automatically created by EF to your project:
You can then double-click the database to open it up in the Server Explorer – and expand the tables within it to see the schema that was created:
Notice above how EF Code First automatically created the appropriate database schema based on the Category and Product classes we created earlier. It also automatically setup Primary Key/Foreign-Key relationships between the two tables based on the association properties specified in the classes.
Step 8: Scaffolding a Products Controller
We've created a CategoriesController class to manage listing and editing Categories. Let's now create a ProductsController class to manage listing and editing Products.Just like before, we'll right-click on the \Controllers folder in our project and choose the Add->Controller context menu. We'll name the Controller class we want to create "ProductsController" and indicate that we want to scaffold using the EF template with a Product model class:
Clicking the "Add" button will scaffold a ProductsController class for us, with appropriate action methods for CRUD scenarios, and create the associated view templates that go with them:
We can then run our project again and navigate to the /Products URL within it:
Let's click the "Create New" link to create a new Product:
One cool thing to notice is that the "Category" is a drop-down of valid Categories (and not just a textbox with a foreign-key integer value):
The scaffolding support within Visual Studio was smart enough to detect that Category was an association, and scaffold EF code that populates the drop-down with valid Categories.
After entering several products our /Products URL will display the data like below:
Notice again how Category is displayed using the friendly name – and not just the foreign-key value.
Learning More
The above walkthrough provided a quick look at the new EF code-first and data scaffolding support built-into the ASP.NET MVC 3 Tools Update, and how you can use them to easily and quickly jumpstart application development. EF Code First enables you to write incredibly clean data access code. The data scaffolding support enables you to rapidly create data UI – and then allows you to go in and easily tweak/customize it further.In addition to working with EF Code-First, you can also use the data scaffolding support against standard EF ObjectContext objects (built using either the database-first or model-first approach and the EF WYSIWYG designer).
Scaffolding
You can learn more about the new ASP.NET MVC 3 Scaffolding Support from Steve Sanderson's excellent talk about it at MIX:
- Scaffolding – ASP.NET, NuGet, MVCScaffolding – Steve Sanderon's MIX talk about it
- Scaffolding with ASP.NET MVC 3 – Excellent blog series about ASP.NET MVC 3 Scaffolding
I'll be doing more blog posts about EF Code First in the future. Below are links to some tutorials I've written in the past about it:
- Code First Development with Entity Framework 4.x
- EF Code First: Custom Database Schema Mapping
- Using EF Code First with an Existing Database
ASP.NET MVC 3
If you want to learn more about ASP.NET MVC 3, I highly recommend Scott Hanselman's excellent video presentations at the Dutch DevDays and at MIX:
- ASP.NET MVC 3 101 – From Beginning to Advanced
- Overview of the MS Web Stack of Love – Scott's talk at MIX
Summary
The new ASP.NET MVC 3 Tooling Update is full of goodness. If you haven't already downloaded and installed it I highly recommend you do so. Stay tuned for even more blog posts about it!Hope this helps,
Scott
P.S. I am also now using Twitter for quick updates and to share links. Follow me at: twitter.com/scottgu
Subscribe to:
Posts (Atom)