Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / xsp / System / Web / Configuration / StrongNameUtility.cs / 1 / StrongNameUtility.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Configuration { using System.Diagnostics; using System.IO; using System.Runtime.InteropServices; using System.Security.Permissions; internal class StrongNameUtility { // Help class shouldn't be instantiated. private StrongNameUtility() { } /// Free the buffer allocated by strong name functions /// /// address of memory to free [DllImport("mscoree.dll")] internal extern static void StrongNameFreeBuffer(IntPtr pbMemory); ////// Return the last error /// ///error information for the last strong name call [DllImport("mscoree.dll")] internal extern static int StrongNameErrorInfo(); ////// Generate a new key pair for strong name use /// /// desired key container name /// flags /// [out] generated public / private key blob /// [out] size of the generated blob ///true if the key was generated, false if there was an error [DllImport("mscoree.dll")] internal extern static bool StrongNameKeyGen([MarshalAs(UnmanagedType.LPWStr)]string wszKeyContainer, uint dwFlags, [Out]out IntPtr ppbKeyBlob, [Out]out long pcbKeyBlob); internal static bool GenerateStrongNameFile(string filename) { // variables that hold the unmanaged key IntPtr keyBlob = IntPtr.Zero; long generatedSize = 0; // create the key bool createdKey = StrongNameKeyGen(null, 0 /*No flags. 1 is to save the key in the key container */, out keyBlob, out generatedSize); // if there was a problem, translate it and report it if (!createdKey || keyBlob == IntPtr.Zero) { throw Marshal.GetExceptionForHR(StrongNameErrorInfo()); } try { Debug.Assert(keyBlob != IntPtr.Zero); // make sure the key size makes sense Debug.Assert(generatedSize > 0 && generatedSize <= Int32.MaxValue); if (generatedSize <= 0 || generatedSize > Int32.MaxValue) { throw new InvalidOperationException(SR.GetString(SR.Browser_InvalidStrongNameKey)); } // get the key into managed memory byte[] key = new byte[generatedSize]; Marshal.Copy(keyBlob, key, 0, (int)generatedSize); // write the key to the specified file using (FileStream snkStream = new FileStream(filename, FileMode.Create, FileAccess.Write)) { using (BinaryWriter snkWriter = new BinaryWriter(snkStream)) { snkWriter.Write(key); } } } finally { // release the unmanaged memory the key resides in if (keyBlob != IntPtr.Zero) { StrongNameFreeBuffer(keyBlob); } } return true; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Configuration { using System.Diagnostics; using System.IO; using System.Runtime.InteropServices; using System.Security.Permissions; internal class StrongNameUtility { // Help class shouldn't be instantiated. private StrongNameUtility() { } /// Free the buffer allocated by strong name functions /// /// address of memory to free [DllImport("mscoree.dll")] internal extern static void StrongNameFreeBuffer(IntPtr pbMemory); ////// Return the last error /// ///error information for the last strong name call [DllImport("mscoree.dll")] internal extern static int StrongNameErrorInfo(); ////// Generate a new key pair for strong name use /// /// desired key container name /// flags /// [out] generated public / private key blob /// [out] size of the generated blob ///true if the key was generated, false if there was an error [DllImport("mscoree.dll")] internal extern static bool StrongNameKeyGen([MarshalAs(UnmanagedType.LPWStr)]string wszKeyContainer, uint dwFlags, [Out]out IntPtr ppbKeyBlob, [Out]out long pcbKeyBlob); internal static bool GenerateStrongNameFile(string filename) { // variables that hold the unmanaged key IntPtr keyBlob = IntPtr.Zero; long generatedSize = 0; // create the key bool createdKey = StrongNameKeyGen(null, 0 /*No flags. 1 is to save the key in the key container */, out keyBlob, out generatedSize); // if there was a problem, translate it and report it if (!createdKey || keyBlob == IntPtr.Zero) { throw Marshal.GetExceptionForHR(StrongNameErrorInfo()); } try { Debug.Assert(keyBlob != IntPtr.Zero); // make sure the key size makes sense Debug.Assert(generatedSize > 0 && generatedSize <= Int32.MaxValue); if (generatedSize <= 0 || generatedSize > Int32.MaxValue) { throw new InvalidOperationException(SR.GetString(SR.Browser_InvalidStrongNameKey)); } // get the key into managed memory byte[] key = new byte[generatedSize]; Marshal.Copy(keyBlob, key, 0, (int)generatedSize); // write the key to the specified file using (FileStream snkStream = new FileStream(filename, FileMode.Create, FileAccess.Write)) { using (BinaryWriter snkWriter = new BinaryWriter(snkStream)) { snkWriter.Write(key); } } } finally { // release the unmanaged memory the key resides in if (keyBlob != IntPtr.Zero) { StrongNameFreeBuffer(keyBlob); } } return true; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- AssociationSetEnd.cs
- AutoGeneratedField.cs
- OdbcCommandBuilder.cs
- DataViewManagerListItemTypeDescriptor.cs
- IdentityReference.cs
- ClockController.cs
- PrivateFontCollection.cs
- EntityDataSourceState.cs
- BaseTemplateBuildProvider.cs
- CalloutQueueItem.cs
- MutexSecurity.cs
- AnnotationResourceCollection.cs
- MarginsConverter.cs
- StateWorkerRequest.cs
- CodeIdentifiers.cs
- DecoderExceptionFallback.cs
- XmlLoader.cs
- FilterElement.cs
- WebAdminConfigurationHelper.cs
- Main.cs
- TypeDescriptorContext.cs
- Random.cs
- MembershipValidatePasswordEventArgs.cs
- HotSpot.cs
- InputProcessorProfiles.cs
- ProcessModelSection.cs
- MaterializeFromAtom.cs
- InputElement.cs
- XmlException.cs
- ListViewSortEventArgs.cs
- ByteStack.cs
- SoapAttributes.cs
- LocalFileSettingsProvider.cs
- WaitForChangedResult.cs
- CodeSnippetExpression.cs
- StyleCollection.cs
- SecurityElement.cs
- IconConverter.cs
- FloatUtil.cs
- HttpServerChannel.cs
- TypeKeyValue.cs
- ProfileModule.cs
- Paragraph.cs
- BrowserDefinition.cs
- FileAuthorizationModule.cs
- HttpClientCertificate.cs
- Highlights.cs
- XmlSchemaType.cs
- OciLobLocator.cs
- ToolConsole.cs
- ListItemCollection.cs
- ContentElementAutomationPeer.cs
- StylusEventArgs.cs
- _DomainName.cs
- PenCursorManager.cs
- WorkflowFileItem.cs
- EventLog.cs
- Throw.cs
- Cell.cs
- Number.cs
- HostElement.cs
- xmlformatgeneratorstatics.cs
- WebHeaderCollection.cs
- PhysicalFontFamily.cs
- Events.cs
- SystemWebExtensionsSectionGroup.cs
- ZipIOZip64EndOfCentralDirectoryBlock.cs
- Animatable.cs
- RichTextBoxConstants.cs
- DbConvert.cs
- CharEntityEncoderFallback.cs
- TextElementAutomationPeer.cs
- EntityConnection.cs
- UserControlBuildProvider.cs
- CryptoProvider.cs
- DictionarySectionHandler.cs
- PathTooLongException.cs
- InfoCardRSAPKCS1SignatureFormatter.cs
- SoapExtensionStream.cs
- Brushes.cs
- NeutralResourcesLanguageAttribute.cs
- OuterGlowBitmapEffect.cs
- PolicyStatement.cs
- DataException.cs
- QueryValue.cs
- SystemIcmpV4Statistics.cs
- BaseTreeIterator.cs
- SystemIcmpV6Statistics.cs
- NamespaceInfo.cs
- XmlMembersMapping.cs
- CheckBoxList.cs
- PenLineJoinValidation.cs
- XComponentModel.cs
- WebServiceParameterData.cs
- StateInitialization.cs
- BaseValidator.cs
- Config.cs
- Visitors.cs
- RuntimeEnvironment.cs
- ItemDragEvent.cs