Auf Englisch lesen

Freigeben über


ConfigurationPropertyAttribute Klasse

Definition

Weist .NET deklarativ an, eine Konfigurationseigenschaft zu instanziieren. Diese Klasse kann nicht vererbt werden.

C#
[System.AttributeUsage(System.AttributeTargets.Property)]
public sealed class ConfigurationPropertyAttribute : Attribute
Vererbung
ConfigurationPropertyAttribute
Attribute

Beispiele

Das folgende Beispiel zeigt, wie die Eigenschaften eines benutzerdefinierten ConfigurationSection Objekts mithilfe des ConfigurationPropertyAttribute -Attributs definiert werden.

Das Beispiel enthält zwei Klassen. Die UrlsSection benutzerdefinierte Klasse verwendet , ConfigurationPropertyAttribute um eigene Eigenschaften zu definieren. Die UsingConfigurationPropertyAttribute -Klasse verwendet zum UrlsSection Lesen und Schreiben des benutzerdefinierten Abschnitts in der Anwendungskonfigurationsdatei.

C#
using System;
using System.Configuration;

// Define a custom section.
// This class shows how to use the ConfigurationPropertyAttribute.
public class UrlsSection : ConfigurationSection
{
    [ConfigurationProperty("name", DefaultValue = "Contoso",
        IsRequired = true, IsKey = true)]
    public string Name
    {
        get
        {
            return (string)this["name"];
        }
        set
        {
            this["name"] = value;
        }
    }

    [ConfigurationProperty("url", DefaultValue = "http://www.contoso.com",
        IsRequired = true)]
    [RegexStringValidator(@"\w+:\/\/[\w.]+\S*")]
    public string Url
    {
        get
        {
            return (string)this["url"];
        }
        set
        {
            this["url"] = value;
        }
    }

    [ConfigurationProperty("port", DefaultValue = (int)0, IsRequired = false)]
    [IntegerValidator(MinValue = 0, MaxValue = 8080, ExcludeRange = false)]
    public int Port
    {
        get
        {
            return (int)this["port"];
        }
        set
        {
            this["port"] = value;
        }
    }
}
C#
using System;
using System.Configuration;

public class UsingConfigurationPropertyAttribute
{

    // Create a custom section and save it in the 
    // application configuration file.
    static void CreateCustomSection()
    {
        try
        {

            // Create a custom configuration section.
            UrlsSection customSection = new UrlsSection();

            // Get the current configuration file.
            System.Configuration.Configuration config =
                    ConfigurationManager.OpenExeConfiguration(
                    ConfigurationUserLevel.None);

            // Add the custom section to the application
            // configuration file.
            if (config.Sections["CustomSection"] == null)
            {
                config.Sections.Add("CustomSection", customSection);
            }

            // Save the application configuration file.
            customSection.SectionInformation.ForceSave = true;
            config.Save(ConfigurationSaveMode.Modified);

            Console.WriteLine("Created custom section in the application configuration file: {0}",
                config.FilePath);
            Console.WriteLine();
        }
        catch (ConfigurationErrorsException err)
        {
            Console.WriteLine("CreateCustomSection: {0}", err.ToString());
        }
    }

    static void ReadCustomSection()
    {
        try
        {
            // Get the application configuration file.
            System.Configuration.Configuration config =
                    ConfigurationManager.OpenExeConfiguration(
                    ConfigurationUserLevel.None) as Configuration;

            // Read and display the custom section.
            UrlsSection customSection =
                config.GetSection("CustomSection") as UrlsSection;
            Console.WriteLine("Reading custom section from the configuration file.");
            Console.WriteLine("Section name: {0}", customSection.Name);
            Console.WriteLine("Url: {0}", customSection.Url);
            Console.WriteLine("Port: {0}", customSection.Port);
            Console.WriteLine();
        }
        catch (ConfigurationErrorsException err)
        {
            Console.WriteLine("ReadCustomSection(string): {0}", err.ToString());
        }
    }
    
    static void Main(string[] args)
    {
       
        // Get the name of the application.
        string appName =
            Environment.GetCommandLineArgs()[0];

        // Create a custom section and save it in the 
        // application configuration file.
        CreateCustomSection();

        // Read the custom section saved in the
        // application configuration file.
        ReadCustomSection();

        Console.WriteLine("Press enter to exit.");

        Console.ReadLine();
    }
}

Im Folgenden ist ein Auszug der Konfigurationsdatei aufgeführt, der den benutzerdefinierten Abschnitt enthält, wie im vorherigen Beispiel definiert.

XML
<?xml version="1.0" encoding="utf-8"?>  
<configuration>  
    <configSections>  
        <section name="CustomSection" type="UrlsSection, UsingConfigurationPropertyAttribute, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" />  
    </configSections>  
    <CustomSection name="Contoso" url="http://www.contoso.com" />  
</configuration>  

Hinweise

Sie verwenden die ConfigurationPropertyAttribute , um eine Konfigurationseigenschaft zu ergänzen, die .NET anweist, die Eigenschaft mithilfe des Werts des Decorating-Parameters zu instanziieren und zu initialisieren.

Hinweis

Die einfachste Möglichkeit zum Erstellen eines benutzerdefinierten Konfigurationselements ist die Verwendung des attributierten (deklarativen) Modells. Sie deklarieren die benutzerdefinierten öffentlichen Eigenschaften und versehen sie mit dem ConfigurationPropertyAttribute -Attribut. Für jede Eigenschaft, die mit diesem Attribut gekennzeichnet ist, verwendet .NET Reflektion, um die Dekorationsparameter zu lesen und eine zugehörige ConfigurationProperty instance zu erstellen. Sie können auch das programmgesteuerte Modell verwenden. In diesem Fall liegt es in Ihrer Verantwortung, die benutzerdefinierten öffentlichen Eigenschaften zu deklarieren und deren Sammlung zurückzugeben.

Das .NET-Konfigurationssystem stellt Attributtypen bereit, die Sie während der Erstellung von benutzerdefinierten Konfigurationselementen verwenden können. Es gibt zwei Arten von Attributtypen:

  1. Die Typen, die .NET anweisen, wie die benutzerdefinierten Konfigurationselementeigenschaften instanziiert werden. Zu diesen Typen gehören:

  2. Die Typen, die .NET anweisen, wie die benutzerdefinierten Konfigurationselementeigenschaften überprüft werden. Zu diesen Typen gehören:

Konstruktoren

ConfigurationPropertyAttribute(String)

Initialisiert eine neue Instanz der ConfigurationPropertyAttribute-Klasse.

Eigenschaften

DefaultValue

Ruft den Standardwert für die ergänzte Eigenschaft ab oder legt diesen fest.

IsDefaultCollection

Ruft einen Wert ab, der angibt, ob dies die Standardeigenschaftenauflistung für die ergänzte Konfigurationseigenschaft ist, oder legt diesen fest.

IsKey

Ruft einen Wert ab, der angibt, ob dies eine Haupteigenschaft für die ergänzte Elementeigenschaft ist, oder legt diesen fest.

IsRequired

Ruft einen Wert ab, der angibt, ob die ergänzte Elementeigenschaft erforderlich ist, oder legt diesen fest.

Name

Ruft den Namen der ergänzten Konfigurationselementeigenschaft ab.

Options

Ruft die ConfigurationPropertyOptions für die ergänzte Eigenschaft des Konfigurationselements ab oder legt diese fest.

TypeId

Ruft bei Implementierung in einer abgeleiteten Klasse einen eindeutigen Bezeichner für dieses Attribute ab.

(Geerbt von Attribute)

Methoden

Equals(Object)

Gibt einen Wert zurück, der angibt, ob diese Instanz gleich einem angegebenen Objekt ist.

(Geerbt von Attribute)
GetHashCode()

Gibt den Hashcode für diese Instanz zurück.

(Geerbt von Attribute)
GetType()

Ruft den Type der aktuellen Instanz ab.

(Geerbt von Object)
IsDefaultAttribute()

Gibt beim Überschreiben in einer abgeleiteten Klasse an, ob der Wert der Instanz der Standardwert für die abgeleitete Klasse ist.

(Geerbt von Attribute)
Match(Object)

Beim Überschreiben in einer abgeleiteten Klasse wird ein Wert zurückgegeben, der angibt, ob diese Instanz einem bestimmten Objekt entspricht.

(Geerbt von Attribute)
MemberwiseClone()

Erstellt eine flache Kopie des aktuellen Object.

(Geerbt von Object)
ToString()

Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt.

(Geerbt von Object)

Explizite Schnittstellenimplementierungen

_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Ordnet eine Reihe von Namen einer entsprechenden Reihe von Dispatchbezeichnern zu.

(Geerbt von Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Ruft die Typinformationen für ein Objekt ab, mit deren Hilfe die Typinformationen für eine Schnittstelle abgerufen werden können.

(Geerbt von Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Ruft die Anzahl der Schnittstellen mit Typinformationen ab, die von einem Objekt bereitgestellt werden (0 oder 1).

(Geerbt von Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Stellt den Zugriff auf von einem Objekt verfügbar gemachte Eigenschaften und Methoden bereit.

(Geerbt von Attribute)

Gilt für:

Produkt Versionen
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9

Weitere Informationen