Add the Custom Configuration Settings to the Web.config
Before you deploy you're web part, you will wish to open the web.config files for each of the SharePoint web applications under which your SharePoint web part will be deployed and add the new configuration setting to the <appSettings> node. On your SharePoint Web Front End (WFE) server(s), the web applications will be located under the C:\inetpub\wwwroot\wss\VirtualDirectories directory and the web.config file will be located immediately under each given web application. In this particular instance, I'm going to reference a custom setting called "dbConnectionString" which is presented as follows:
<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<configuration> <configSections> ... <appSettings> <add key="dbConnectionString" value="Data Source=dbServer;Initial Catalog=dbName;Integrated Security=True" /> </appSettings> </configuration>After making the change, be sure to save the updated web.config file and, now, we move on to actually putting this info to good use...
Referencing the Custom Configuration Settings
To reference the custom configuration settings in your Visual Web Part, you will need to carry out the following steps:
- Open your Visual Web Part in Visual Studio
- In Solution Explorer, expand the Project tree, right-click on References and select Add Reference...
- Click on the .NET tab
- Locate and click on the System.Configuration component
- Click OK
- Open your Visual Web Part's .ascx.cs file
- Add the following code that will reference the custom configuration setting:
At this point, you can now deploy your web part to sites contained under the web applications that you added the custom setting to (via updating the web.config file, of course) and they will reference the value that you've specified.using System.Configuration; using System.Web.Configuration; ...protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { string dbConnectionString = string.Empty; string errorMessage = string.Empty; try { using (SPSite site = SPContext.Current.Site) { Configuration config = WebConfigurationManager.OpenWebConfiguration("/", site.WebApplication.Name); if (config.AppSettings.Settings["dbConnectionString"] != null) { dbConnectionString = config.AppSettings.Settings["dbConnectionString"].Value; } else { throw new Exception(string.Format("The 'dbConnectionString' <appSettings> node could not be located in the web application's, {0}, web.config file.", site.WebApplication.Name)); } } ... Do something with the configuration info } catch (Exception ex) { ...Handle the exception properly } } }
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.