Use Visual C# .NET to work with code-behind class files in an ASP.NET application
This article describes how to develop .aspx pages that use code-behind class files in Microsoft ASP.NET applications. The code samples in this article include the requirements for both code-behind class files that are precompiled and code-behind class files that are compiled on demand.
Original product version: ASP.NET
Original KB number: 308143
Requirements
The following list outlines the recommended hardware, software, and network infrastructure that you need:
- Windows
- .NET Framework
- Internet Information Services (IIS)
Create an ASP.NET web application by using Visual C# .NET
This section demonstrates how to create a new ASP.NET web application that is named CodeBehindSamples.
- Start Visual Studio .NET.
- On the File menu, point to New, and then click Project.
- Under Project Type, click Visual C# Projects. Under Templates, click ASP.NET Web Application.
- In the Name box, type CodeBehindSamples. In the Location box, type the ServerName. If you are using the local server, leave the Location as
http://localhost
.
Use code-behind class files
If you use code-behind class files with .aspx pages, you can separate the presentation code from the core application logic (or code-behind). The code-behind class file is compiled so that it can be created and used as an object. This allows access to its properties, its methods, and its event handlers. For this to work, the .aspx page must specify to inherit from the code-behind base class. To do this, use the Inherits
attribute for the @ Page
directive. The .aspx page inherits from the code-behind class, and the code-behind class inherits from the Page
class.
By default, if you are using Visual Studio .NET, a Codebehind
attribute is added to the @ Page
directive. The .NET Framework does not actually use this attribute. Instead, Visual Studio .NET uses this attribute to maintain a reference to the associated code-behind file for the .aspx page.
To demonstrate how Visual Studio .NET uses the Codebehind
attribute, remove the Codebehind
attribute. You can no longer right-click the .aspx page and then click View Code. This behavior occurs because Visual Studio .NET no longer contains a reference for the class file it can use for the page. Remember that this is not how the .NET Framework uses code-behind class files, but how Visual Studio .NET manages these project files.
Use the Inherits attribute with precompiled classes
If you precompile your code-behind classes into an assembly, you can use the Inherits
attribute to specify the class from which to inherit. In this scenario, you do not have to include the actual code-behind class file when you deploy the application. Instead, you must deploy the assembly and the .aspx page. You must put the assembly in the Bin
folder for the application when you deploy the application.
This section demonstrates how to create a new Web Form that uses the precompiled approach and inherits from the code-behind class.
To add a new Web Form that is named InheritSample.aspx to your Visual Studio .NET project, follow these steps:
- In Solution Explorer, right-click the project node, click Add, and then click Add Web Form.
- In the Name box, type InheritSample.aspx, and then click Open.
Switch to Design view, and then add a Web Form Label control to the .aspx page.
Right-click the .aspx page, and then click View Code. The code-behind file opens in the editor.
In the code-behind file, add the following code to the
Page_Load
event handler:private void Page_Load(object sender, System.EventArgs e) { Label1.Text = "(Precompiled): Page_Load fired!"; }
Note
This code only demonstrates that the code-behind class is involved in the sample at run time in the later steps.
Switch from the code-behind class file to the .aspx page in the editor, and then switch to HTML view.
At the top of the page, review the code for the
@ Page
directive. The code should be similar to the following default code:<%@ Page language="c#" Codebehind="InheritSample.aspx.cs" AutoEventWireup="false" Inherits="CodeBehindSamples.InheritSample" %>
In this example, the .aspx page inherits from the code-behind class that is named
InheritSamples
in theCodeBehindSamples
namespace. By default, a web application that is created in Visual Studio .NET uses aProjectName.ClassName
structure for theInherits
attribute value.On the File menu, click Save All to save the Web Form and other associated project files.
In the Visual Studio .NET IDE, on the Build menu, click Build to build the project.
On the Project menu, click Show All Files.
In Solution Explorer, click to expand the
Bin
folder. The assembly that is generated when you compile the project from the previous section (which is CodeBehindSamples.dll in this example) appears in theBin
folder.In Visual Studio .NET, right-click the page in Solution Explorer, and then click View in Browser to run the code. The label is populated with the following value:
(Precompiled): Page_Load fired!
Use the Src attribute and compile on demand
If your code-behind class files will be compiled on demand instead of precompiled, you must use the Src
attribute to specify the relative path of the code-behind class file. Make sure that you include the actual class file when you use this method to deploy the application.
Note
For more information about potential issues when developing your applications in Visual Studio .NET with using the Src
attribute, see the References section in this article. Visual Studio .NET is designed to take advantage of precompiling your application code into an assembly instead of using the compile on demand approach that is described in this section.
To add a new Web Form that is named SrcSample.aspx to your project in Visual Studio .NET, follow these steps:
- In Solution Explorer, right-click the project node, click Add, and then click Add Web Form.
- In the Name box, type SrcSample.aspx, and then click Open.
Switch to Design view, and then add a Web Form Label control to the .aspx page.
Right-click the .aspx page, and then click View Code. The code-behind file opens in the editor.
In the code-behind file, add the following code to the
Page_Load
event:private void Page_Load(object sender, System.EventArgs e) { Label1.Text = "(Src): Page_Load fired!"; }
Switch from the code-behind class file to the .aspx page in the editor, and then switch to HTML view.
At the top of the page, review the code for the
@ Page
directive. The code should be similar to the following default code:<%@ Page language="c#" Codebehind="SrcSample.aspx.cs" AutoEventWireup="false" Inherits="CodeBehindSamples.SrcSample"%>
To simplify this example, delete the Global.asax file from your project. This is only done in this example to prevent additional errors that are related to the code-behind page of the Global.asax file.
On the File menu, click Save All to save the Web Form and other associated project files.
Note
Because you want the code-behind class file for this sample to compile on demand, do not build the solution now.
If you followed the steps that are listed in the Use the Inherits attribute with precompiled classes section, you must delete the assembly in the
Bin
directory of the application before you follow the rest of the steps in this section.For more information, visit the Troubleshooting section of this article.
To run the page, start Internet Explorer and then manually enter the URL of the page. Do not select the View in Browser or the Browse With options from the Visual Studio .NET IDE. Otherwise, if you are using Visual Studio .NET 2003, the code-behind page will be precompiled into an assembly that is located in the
Bin
directory by default. After viewing the page, you will receive an error message that is similar as below:Could not load type 'CodeBehindSamples.SrcSample'.
This error occurs because the code-behind class file is not yet compiled, and you have not yet included the
Src
attribute to reference the code-behind class file.Add the
Src
attribute to the@ Page
directive as follows:<%@ Page language="c#" Codebehind="SrcSample.aspx.cs" AutoEventWireup="false" Inherits="CodeBehindSamples.SrcSample" Src="SrcSample.aspx.cs"%>
The
Src
attribute is listed with the relative path of the code-behind class file (SrcSample.aspx.cs), and theInherits
attribute value is set to referenceCodeBehindSamples.SrcSample
.On the File menu, click Save All to save the Web Form and other associated project files. Remember, do not build the solution because you want the code-behind class file for this sample to be compiled on demand.
To run the page, start Internet Explorer and then manually enter the URL of the page. Do not select the View in Browser or the Browse With options from the Visual Studio .NET IDE. Otherwise, if you are using Visual Studio .NET 2003, the code-behind page will be precompiled into an assembly that is located in the
Bin
directory by default. At this point, the page should be loaded in the browser, and the label is populated with the following value:(Src): Page_Load fired!
The code-behind class file has now been compiled on demand and functions correctly.
Troubleshooting
You may receive an error message that is similar to the following if you precompile your application in Visual Studio .NET and then try to apply the compile on demand approach by using the
Src
attribute:Compiler Error Message: CS1595: 'ProjectName.CodeBehindClassName' is defined in multiple places; using definition from '%windir%:\WINDOWS\Microsoft.NET\Framework\v1.1.4322\Temporary ASP.NET Files\YourProjectName\d1444413\36fce407\assembly\dl2\009389be\231afa2d_d586c301\YourAssemblyName.DLL'
Keep in mind that the directory names following YourProjectName in the path that is listed in the error message will probably be different because ASP.NET automatically handles the building of the directories and their names.
If you use the
Src
attribute, you must follow these steps to resolve the issue that is associated with the error message:Delete the YourProjectName directory that is referenced in the error message. You may also have to run the
iisreset
command from the command prompt before you complete this step. Otherwise, you may receive the following error message:Cannot delete GeneratedName.dll: Access is denied.
Make sure the disk is not full or write-protected and that the file is not currently in use.Delete the assembly in the
Bin
directory of the application.To run the page, start Internet Explorer and then manually enter the URL to the page. Do not select the View in Browser or the Browse With options from the Visual Studio .NET IDE. Otherwise, if you use Visual Studio .NET 2003, the code-behind page will be precompiled into an assembly that is located in the
Bin
directory by default.
Note
Microsoft recommends that you use the precompiled approach instead of the compile on demand method (by using the
Src
attribute) if you develop your applications with Visual Studio .NET to avoid these types of issues.If you want to or if you must contain your Web Form pages in a single file, develop your .aspx pages to contain your code instead of the code-behind class file.
For more information about how to develop single-file Web Forms in Visual Studio .NET, see Visual Studio 2003 Retired Technical documentation.
If you do not precompile the code-behind class file and if you do not add the
Src
attribute to the@ Page
directive, or if the virtual path for the attribute is not correct, you will receive the following error message:Could not load type 'CodeBehindSamples.SrcSample'.
When you deploy .aspx pages, if their associated code-behind class files are precompiled, you only have to deploy the assembly to the
Bin
folder of the application. You do not have to deploy the actual code-behind class files with the application.When you deploy .aspx pages, if their associated code-behind class files are not precompiled, you must deploy the code-behind class files with the application. Additionally, you must add the
Src
attribute to the@ Page
directive because the class file must be available when it is compiled on demand.
References
For more information about assemblies, see Assemblies.
For more articles, samples, and other resources that are related to ASP.NET programming, see ASP.NET.
For more information about the @ Page directive and its various attributes, see @ Page.
For more information about general Web Forms syntax, see Web Forms Syntax.
For more information, see ASP.NET Code-behind model overview.