SecureString
Contents
[
Hide
]SecureString class
Secure string, represents text that should be kept confidential. This class DON’T ENCRYPTING the internal data. Objects of this class should only be allocated using System::MakeObject() function. Never create instance of this type on stack or using operator new, as it will result in runtime errors and/or assertion faults. Always wrap this class into System::SmartPtr pointer and use this pointer to pass it to functions as argument.
class SecureString : public System::IDisposable
Methods
| Method | Description | 
|---|---|
| void AppendChar(char16_t) | Appends a character to the end of the string. | 
| void Clear() | Delete all characters from the current secure string. | 
| SecureStringPtr Copy() const | Creates a duplicate of this secure string. | 
| void Dispose() override | Release all resources used by the current object. | 
| virtual bool Equals(ptr) | Compares objects using C# Object.Equals semantics. | 
| static std::enable_if<IsSmartPtr<T1>::value&&IsSmartPtr<T2>::value, bool>::type Equals(T1 const&, T2 const&) | Compares reference type objects in C# style. | 
| static std::enable_if<!IsSmartPtr<T1>::value&&!IsSmartPtr<T2>::value, bool>::type Equals(T1 const&, T2 const&) | Compares value type objects in C# style. | 
| static bool Equals(float const&, float const&) | Emulates C#-style floating point comparison where two NaNs are considered equal even though according to IEC 60559:1989 NaN is not equal to any value, including NaN. | 
| static bool Equals(double const&, double const&) | Emulates C#-style floating point comparison where two NaNs are considered equal even though according to IEC 60559:1989 NaN is not equal to any value, including NaN. | 
| virtual bool FastCast(const Details::FastRttiBase&, void **) const | For internal purposes only. | 
| int32_t get_Length() const | Gets number of characters in this secure string. | 
| Detail::SmartPtrCounter * GetCounter() | Gets reference counter data structure associated with the object. | 
| virtual int32_t GetHashCode() const | Analog of C# Object.GetHashCode() method. Enables hashing of custom objects. | 
| virtual const TypeInfo& GetType() const | Gets actual type of object. Analog of C# System.Object.GetType() call. | 
| void InsertAt(int32_t, char16_t) | Inserts a character at the specified index. | 
| virtual bool Is(const TypeInfo&) const | Check if object represents an instance of type described by targetType. Analog of C# ‘is’ operator. | 
| bool IsReadOnly() const | Gets flag that indicates whether this object is marked read-only. | 
| void Lock() | Implements C# lock() statement locking. Call directly or use LockContext sentry object. | 
| void MakeReadOnly() | Makes this secure string read-only. | 
| virtual ptr MemberwiseClone() const | Analog of C# Object.MemberwiseClone() method. Enables cloning custom types. | 
| Object() | Creates object. Initializes all internal data structures. | 
| Object(Object const&) | Copy constructor. Doesn’t copy anything, really, just initializes new object and enables copy constructing subclasses. | 
| SecureString& operator=(const SecureString&) | |
| Object& operator=(Object const&) | Assignment operator. Doesn’t copy anything, really, just initializes new object and enables copy constructing subclasses. | 
| static bool ReferenceEquals(ptr const&, ptr const&) | Compares objects by reference. | 
| static std::enable_if<!IsSmartPtr<T>::value, bool>::type ReferenceEquals(T const&, T const&) | Compares objects by reference. | 
| static std::enable_if<!IsSmartPtr<T>::value, bool>::type ReferenceEquals(T const&, std::nullptr_t) | Reference-compares value type object with nullptr. | 
| bool ReferenceEquals(String const&, std::nullptr_t) | Specialization of Object::ReferenceEquals for case of string and nullptr. | 
| bool ReferenceEquals(String const&, String const&) | Specialization of Object::ReferenceEquals for case of strings. | 
| void RemoveAt(int32_t) | Removes the character at the specified position. | 
| int RemovedSharedRefs(int) | Decreases shared reference count by specified value. | 
| SecureString() | RTTI information. | 
| SecureString(const char16_t *, int32_t) | Constructor. | 
| SecureString(const SecureString&) | |
| void SetAt(int32_t, char16_t) | Replaces the existing character at the specified position. | 
| virtual void SetTemplateWeakPtr(uint32_t) | Set n’th template argument a weak pointer (rather than shared). Allows switching pointers in containers to weak mode. | 
| int SharedCount() const | Gets current value of shared reference counter. | 
| Object * SharedRefAdded() | Increments shared reference count. Shouldn’t be called directly; instead, use smart pointers or ThisProtector. | 
| int SharedRefRemovedSafe() | Decrements and returns shared reference count. Shouldn’t be called directly; instead, use smart pointers or ThisProtector. | 
| virtual String ToString() const | Analog of C# Object.ToString() method. Enables converting custom objects to string. | 
| String ToUnsecureString() const | Copies contents of this secure string into unsecure String object. Use with caution. | 
| static const TypeInfo& Type() | Implements C# typeof(System.Object) construct. | 
| void Unlock() | Implements C# lock() statement unlocking. Call directly or use LockContext sentry object. | 
| Detail::SmartPtrCounter * WeakRefAdded() | Increments weak reference count. Shouldn’t be called directly; instead, use smart pointers or ThisProtector. | 
| void WeakRefRemoved() | Decrements weak reference count. Shouldn’t be called directly; instead, use smart pointers or ThisProtector. | 
| virtual ~Object() | Destroys object. Frees all internal data structures. | 
| ~SecureString() | Destructor. | 
See Also
- Class IDisposable
- Namespace System::Security
- Library Aspose.Slides