I have to work on an existing application, comprises of many projects including a database project.
In the statup project, which is a windows app., when making a call to a Adapter.Fill(dataTable);
a scary error appears saying that:
An error occurred in the Microsoft .NET Framework while trying to load assembly id 65675. The server may be running out of resources, or the assembly may not be trusted with PERMISSION_SET = EXTERNAL_ACCESS or UNSAFE. Run the query again, or check documentation to see how to solve the assembly trust issues. For more information about this error:
System.IO.FileLoadException: Could not load file or assembly 'xxxxx.yyyy.database, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null' or one of its dependencies. The given assembly name or codebase was invalid. (Exception from HRESULT: 0x80131047)
System.IO.FileLoadException:
at System.Reflection.Assembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, Assembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection)
at System.Reflection.Assembly.InternalLoad(AssemblyName assemblyRef, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
at System.Reflection.Assembly.InternalLoad(String assemblyString, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
at System.Reflection.Assembly.Load(String assemblyString)
(.Net SqlClient Data Provider)
at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection)
at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection)
at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj)
at System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)
at System.Data.SqlClient.SqlDataReader.ConsumeMetaData()
at System.Data.SqlClient.SqlDataReader.get_MetaData()
at System.Data.SqlClient.SqlCommand.FinishExecuteReader(SqlDataReader ds, RunBehavior runBehavior, String resetOptionsString)
at System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async)
at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)
at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method)
at System.Data.SqlClient.SqlCommand.ExecuteReader(CommandBehavior behavior, String method)
at System.Data.SqlClient.SqlCommand.ExecuteDbDataReader(CommandBehavior behavior)
at System.Data.Common.DbCommand.System.Data.IDbCommand.ExecuteReader(CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.FillInternal(DataSet dataset, DataTable[] datatables, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.Fill(DataTable[] dataTables, Int32 startRecord, Int32 maxRecords, IDbCommand command, CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.Fill(DataTable dataTable)
at XXX.YY.Data.dsLandholdingsTableAdapters.LandholdingsTableAdapter.Fill(LandholdingsDataTable dataTable, String IV_LRNO, String SearchField, String SearchVal, Nullable`1 SearchType) in E:ProjectsPPPXXXYYYDatadsLandholdings.Designer.cs:line 5678
at XXX.YYY.Browse.BrowseLandholdings.btnSearch_Click(Object sender, EventArgs e) in E:ProjectsPPPPXXXXYYYBrowseBrowseLandholdings.cs:line 352
After investigating on the web, I found that it may help to change the «Permission level» on the «Database» tab of my «Database project properties» from «safe» to either «Unsafe» or «External».
But the error is still coming up after doing mentioned change!
Does anyone possibly have any idea why this is happening?
Any help appreciated in advance.
#c# #.net #winforms #dll
#c# #.net #winforms #dll
Вопрос:
Я должен работать над существующим приложением, состоящим из множества проектов, включая проект базы данных. В проекте statup, который является приложением Windows., при вызове Adapter.Fill(dataTable);
появляется пугающая ошибка, в которой говорится, что:
An error occurred in the Microsoft .NET Framework while trying to load assembly id 65675. The server may be running out of resources, or the assembly may not be trusted with PERMISSION_SET = EXTERNAL_ACCESS or UNSAFE. Run the query again, or check documentation to see how to solve the assembly trust issues. For more information about this error:
System.IO.FileLoadException: Could not load file or assembly 'xxxxx.yyyy.database, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null' or one of its dependencies. The given assembly name or codebase was invalid. (Exception from HRESULT: 0x80131047)
System.IO.FileLoadException:
at System.Reflection.Assembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, Assembly locationHint, StackCrawlMarkamp; stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection)
at System.Reflection.Assembly.InternalLoad(AssemblyName assemblyRef, Evidence assemblySecurity, StackCrawlMarkamp; stackMark, Boolean forIntrospection)
at System.Reflection.Assembly.InternalLoad(String assemblyString, Evidence assemblySecurity, StackCrawlMarkamp; stackMark, Boolean forIntrospection)
at System.Reflection.Assembly.Load(String assemblyString)
(.Net SqlClient Data Provider)
at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection)
at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection)
at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj)
at System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)
at System.Data.SqlClient.SqlDataReader.ConsumeMetaData()
at System.Data.SqlClient.SqlDataReader.get_MetaData()
at System.Data.SqlClient.SqlCommand.FinishExecuteReader(SqlDataReader ds, RunBehavior runBehavior, String resetOptionsString)
at System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async)
at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)
at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method)
at System.Data.SqlClient.SqlCommand.ExecuteReader(CommandBehavior behavior, String method)
at System.Data.SqlClient.SqlCommand.ExecuteDbDataReader(CommandBehavior behavior)
at System.Data.Common.DbCommand.System.Data.IDbCommand.ExecuteReader(CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.FillInternal(DataSet dataset, DataTable[] datatables, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.Fill(DataTable[] dataTables, Int32 startRecord, Int32 maxRecords, IDbCommand command, CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.Fill(DataTable dataTable)
at XXX.YY.Data.dsLandholdingsTableAdapters.LandholdingsTableAdapter.Fill(LandholdingsDataTable dataTable, String IV_LRNO, String SearchField, String SearchVal, Nullable`1 SearchType) in E:ProjectsPPPXXXYYYDatadsLandholdings.Designer.cs:line 5678
at XXX.YYY.Browse.BrowseLandholdings.btnSearch_Click(Object sender, EventArgs e) in E:ProjectsPPPPXXXXYYYBrowseBrowseLandholdings.cs:line 352
После исследования в Интернете я обнаружил, что это может помочь изменить «Уровень разрешений» на вкладке «База данных» моего «Свойства проекта базы данных» с «безопасного» на «Небезопасный» или «Внешний».
Но ошибка все еще появляется после внесения упомянутых изменений!
У кого-нибудь есть какие-либо идеи, почему это происходит?
Заранее приветствуется любая помощь.
Комментарии:
1. Это исключение исходит из вашего процесса, сохраненного в CLR? Или в приложении WinForms? Есть ли еще трассировка стека, которую вы можете опубликовать? Какие-либо события журнала событий на сервере?
2. Да, я бы сначала посмотрел на повреждение файла и проверил на другом компьютере.
3. Вы также должны зарегистрировать все зависимости.
4. @HansPassant,@VladimirPerevalov : попробовал на другой машине, та же проблема!
5. Может оказаться полезным средство просмотра журнала Fusion. Это может дать вам более подробную информацию о том, почему сборка не загружается: msdn.microsoft.com/en-us/library/e74a18c4 (v =vs.71).aspx
Ответ №1:
Это помогло мне:
USE <DATABASE>;
EXEC sp_configure 'clr enabled' ,1
GO
RECONFIGURE
GO
EXEC sp_configure 'clr enabled' -- make sure it took
GO
USE <DATABASE>
GO
EXEC sp_changedbowner 'sa'
USE <DATABASE>
GO
ALTER DATABASE <DATABASE> SET TRUSTWORTHY ON;
Комментарии:
1. Идеально! Проблема возникла при создании базы данных путем восстановления резервной копии, созданной на другом сервере
2.Если это происходит в SQL Server 2017, еще одной проблемой является неподписанная сборка. Правильное исправление: подпишите его. Быстрый взлом:
sp_configure 'clr strict security', 0
(на уровне сервера) передset trustworthy on
.
Ответ №2:
У меня это сработало
EXEC sp_configure 'show advanced options', '1';
GO
RECONFIGURE;
GO
--Enable CLR (.NET Common Language Runtime)
exec sp_configure 'clr enabled', '1';
GO
RECONFIGURE;
GO
--Enable xp_CmdShell stored procedure to run Command Line programs from within T-SQL
--EXEC sp_configure 'xp_cmdshell', 1
--GO
EXEC sp_configure 'show advanced options', '0';
GO
RECONFIGURE;
/****this is another one****/
USE master
GO
ALTER DATABASE <DB_NAME>SET TRUSTWORTHY ON
USE <DB_NAME>
GO
EXEC sp_changedbowner 'sa'
/****when error occured relating to m,emory***/
Ответ №3:
Наконец-то я смог это исправить,
- Включите «Интеграцию с CLR» в SQL server.
- Разверните объект CLR, которым в моем случае был проект базы данных, и я также установил уровень разрешений на внешний.
Спасибо за все комментарии / ответы.
Ответ №4:
Трассировка стека указывает на сборку, которую не удалось загрузить. Если вы используете .dll-файлы для сборки или загрузки чего-либо (импорт / экспорт данных), вы можете захотеть начать с этого.
Убедитесь, что сборка является правильной версией для вашего приложения или что она вообще существует в каталоге.
Кроме того, дважды проверьте соглашение об именовании в сборке. Трассировка стека показывает, что имя сборки или кодовая база недопустимы. Можно ли анализировать язык в вашем приложении? Есть ли опечатка в названии?
Возможно, это действительно элементарные места для начала, поэтому приношу свои извинения, если вы пробовали это. Я сталкивался с подобными трассировками раньше, и в моем случае это обычно приводило к отсутствию.несовместимость dll или версий.
Ответ №5:
Убедитесь, что сборка, которую вы используете, xxxxx.гггг.сборка базы данных из не предназначена для более старой версии .NET Framework.
Ответ №6:
Для пользователей SQL Server 16 или выше, которые хотят использовать надежные сборки и поддерживать включенную систему строгой безопасности clr, вот шаги, которые сработали для меня:
- Удалите свои проблемные сборки, которые не работают (если я не сделал этого первым, следующие шаги не сработали)
DROP ASSEMBLY [YourAssembly]
- Запустите изменения конфигурации:
USE [YourDatabase]
EXEC sp_configure 'clr enabled', '1'
EXEC sp_configure 'show advanced options', '1'
EXEC sp_configure 'clr strict security', '1' --we want to use strict security
RECONFIGURE
- Добавьте свои сборки
USE [YourDatabase]
CREATE ASSEMBLY [YourAssembly] ...
Здесь может возникнуть ошибка, связанная с разрешениями владельца базы данных. Мы хотим установить владельца основной базы данных таким же, как у целевой базы данных.
The database owner SID recorded in the master database differs from the database owner SID recorded in database.
USE [YourDatabase]
DECLARE @serverOwner VARCHAR(MAX)
SELECT serverOwner = suser_sname( owner_sid ) FROM sys.databases WHERE name = 'master'
exec sp_changedbowner @serverOwner
Затем повторно запустите сценарий создания сборки.
- Добавьте доверенную сборку
USE [YourDatabase]
declare
@hash binary(64)
,@description nvarchar(4000)
select
@hash = HASHBYTES('SHA2_512', af.content)
, @description = a.clr_name
FROM sys.assemblies a
JOIN sys.assembly_files af
ON a.assembly_id = af.assembly_id
WHERE a.is_user_defined = 1 AND
af.name = 'YourAssembly'
EXEC sys.sp_add_trusted_assembly
@hash
,@description
Мне нужно работать над существующим приложением, состоящим из многих проектов, включая проект базы данных.
В проекте statup, который является приложением Windows, при вызове Adapter.Fill(dataTable);
появляется страшная ошибка, говорящая, что:
An error occurred in the Microsoft .NET Framework while trying to load assembly id 65675. The server may be running out of resources, or the assembly may not be trusted with PERMISSION_SET = EXTERNAL_ACCESS or UNSAFE. Run the query again, or check documentation to see how to solve the assembly trust issues. For more information about this error:
System.IO.FileLoadException: Could not load file or assembly 'xxxxx.yyyy.database, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null' or one of its dependencies. The given assembly name or codebase was invalid. (Exception from HRESULT: 0x80131047)
System.IO.FileLoadException:
at System.Reflection.Assembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, Assembly locationHint, StackCrawlMark& stackMark, Boolean throwOnFileNotFound, Boolean forIntrospection)
at System.Reflection.Assembly.InternalLoad(AssemblyName assemblyRef, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
at System.Reflection.Assembly.InternalLoad(String assemblyString, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection)
at System.Reflection.Assembly.Load(String assemblyString)
(.Net SqlClient Data Provider)
at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection)
at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection)
at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj)
at System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)
at System.Data.SqlClient.SqlDataReader.ConsumeMetaData()
at System.Data.SqlClient.SqlDataReader.get_MetaData()
at System.Data.SqlClient.SqlCommand.FinishExecuteReader(SqlDataReader ds, RunBehavior runBehavior, String resetOptionsString)
at System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async)
at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)
at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method)
at System.Data.SqlClient.SqlCommand.ExecuteReader(CommandBehavior behavior, String method)
at System.Data.SqlClient.SqlCommand.ExecuteDbDataReader(CommandBehavior behavior)
at System.Data.Common.DbCommand.System.Data.IDbCommand.ExecuteReader(CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.FillInternal(DataSet dataset, DataTable[] datatables, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.Fill(DataTable[] dataTables, Int32 startRecord, Int32 maxRecords, IDbCommand command, CommandBehavior behavior)
at System.Data.Common.DbDataAdapter.Fill(DataTable dataTable)
at XXX.YY.Data.dsLandholdingsTableAdapters.LandholdingsTableAdapter.Fill(LandholdingsDataTable dataTable, String IV_LRNO, String SearchField, String SearchVal, Nullable`1 SearchType) in E:ProjectsPPPXXXYYYDatadsLandholdings.Designer.cs:line 5678
at XXX.YYY.Browse.BrowseLandholdings.btnSearch_Click(Object sender, EventArgs e) in E:ProjectsPPPPXXXXYYYBrowseBrowseLandholdings.cs:line 352
После изучения в Интернете я обнаружил, что это может помочь изменить «уровень разрешений» на вкладке «База данных» моих «свойств проекта базы данных» с «безопасного» на «Небезопасный» или «Внешний».
Но после внесения изменений произошла ошибка!
Кто-нибудь может подумать, почему это происходит?
Любая помощь была оценена заранее.
На ноутбуке под windows 7 ultimate не устанавливается .net 3.5.1 правильно
если устанавливать с помощью скачанного дистибутива — система ругается так:
если устанавливать через «Включение или отключение компонентов», установка проходит хорошо, но после всевозможных перезагрузок и обновлений, любая программа на .net при запуске ругается сначала так:
потом так:
(пишет одно и то же, но во втором случае есть есть кнопа выход)
в сведениях следующее:
Кликните здесь для просмотра всего текста
Подробная информация об использовании оперативной
(JIT) отладки вместо данного диалогового
окна содержится в конце этого сообщения.
************** Текст исключения **************
System.IO.FileNotFoundException: Невозможно загрузить файл или сборку «Accessibility, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a» или один из зависимых от них компонентов. Не удается найти указанный файл.
Имя файла: «Accessibility, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a»
в System.Windows.Forms.Control.OnHandleCreated(EventArgs e)
в System.Windows.Forms.Form.OnHandleCreated(EventArgs e)
в System.Windows.Forms.Control.WmCreate(Message& m)
в System.Windows.Forms.Control.WndProc(Message& m)
в System.Windows.Forms.ScrollableControl.WndProc(Message& m)
в System.Windows.Forms.ContainerControl.WndProc(Message& m)
в System.Windows.Forms.Form.WmCreate(Message& m)
в System.Windows.Forms.Form.WndProc(Message& m)
в System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
в System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
в System.Windows.Forms.NativeWindow.Callback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)
Предупреждение: регистрация привязки сборок выключена.
Чтобы включить регистрацию ошибок привязки сборок, установите значение параметра реестра [HKLMSoftwareMicrosoftFusion!EnableLog] (DWORD) в 1.
Примечание. Регистрация ошибок привязки сборок может привести к некоторому снижению производительности.
Чтобы отключить эту функцию, удалите параметр реестра [HKLMSoftwareMicrosoftFusion!EnableLog].
************** Загруженные сборки **************
mscorlib
Версия сборки: 2.0.0.0
Версия Win32: 2.0.50727.5466 (Win7SP1GDR.050727-5400)
CodeBase: file:///C:/Windows/Microsoft.NET/Framework/v2.0.50727/mscorlib.dll
—————————————-
Multi-MC Loader
Версия сборки: 1.1.0.0
Версия Win32: 1.1.0.0
CodeBase: file:///D:/mc/Multi-MC%20Loader/Multi-MC%20Loader.exe
—————————————-
Microsoft.VisualBasic
Версия сборки: 8.0.0.0
Версия Win32: 8.0.50727.5420 (Win7SP1.050727-5400)
CodeBase: file:///C:/Windows/assembly/GAC_MSIL/Microsoft.VisualBasic/8.0.0.0__b03f5f7f11d50a3a/Microsoft.VisualBasic.dll
—————————————-
System.Windows.Forms
Версия сборки: 2.0.0.0
Версия Win32: 2.0.50727.5460 (Win7SP1GDR.050727-5400)
CodeBase: file:///C:/Windows/assembly/GAC_MSIL/System.Windows.Forms/2.0.0.0__b77a5c561934e089/System.Windows.Forms.dll
—————————————-
System
Версия сборки: 2.0.0.0
Версия Win32: 2.0.50727.5466 (Win7SP1GDR.050727-5400)
CodeBase: file:///C:/Windows/assembly/GAC_MSIL/System/2.0.0.0__b77a5c561934e089/System.dll
—————————————-
System.Drawing
Версия сборки: 2.0.0.0
Версия Win32: 2.0.50727.5462 (Win7SP1GDR.050727-5400)
CodeBase: file:///C:/Windows/assembly/GAC_MSIL/System.Drawing/2.0.0.0__b03f5f7f11d50a3a/System.Drawing.dll
—————————————-
System.Windows.Forms.resources
Версия сборки: 2.0.0.0
Версия Win32: 2.0.50727.5420 (Win7SP1.050727-5400)
CodeBase: file:///C:/Windows/assembly/GAC_MSIL/System.Windows.Forms.resources/2.0.0.0_ru_b77a5c561934e089/System.Windows.Forms.resources.dll
—————————————-
mscorlib.resources
Версия сборки: 2.0.0.0
Версия Win32: 2.0.50727.5466 (Win7SP1GDR.050727-5400)
CodeBase: file:///C:/Windows/Microsoft.NET/Framework/v2.0.50727/mscorlib.dll
—————————————-
System.Xml
Версия сборки: 2.0.0.0
Версия Win32: 2.0.50727.5420 (Win7SP1.050727-5400)
CodeBase: file:///C:/Windows/assembly/GAC_MSIL/System.Xml/2.0.0.0__b77a5c561934e089/System.Xml.dll
—————————————-
System.Runtime.Remoting
Версия сборки: 2.0.0.0
Версия Win32: 2.0.50727.5420 (Win7SP1.050727-5400)
CodeBase: file:///C:/Windows/assembly/GAC_MSIL/System.Runtime.Remoting/2.0.0.0__b77a5c561934e089/System.Runtime.Remoting.dll
—————————————-
************** Оперативная отладка (JIT) **************
Для подключения оперативной (JIT) отладки файл .config данного
приложения или компьютера (machine.config) должен иметь
значение jitDebugging, установленное в секции system.windows.forms.
Приложение также должно быть скомпилировано с включенной
отладкой.
Например:
<configuration>
<system.windows.forms jitDebugging=»true» />
</configuration>
При включенной отладке JIT любое необрабатываемое исключение
пересылается отладчику JIT, зарегистрированному на данном компьютере,
вместо того чтобы обрабатываться данным диалоговым окном.
если игнорировать ошибки и все время жать «Продолжить», программа работает неправильно, иногда показывает ту же ошибку
проверяю работоспособность .net установщиком paint.net (если компонент включен, то выпадает та самая ошибка «невозможно загрузить файл или сборку», если отключен — предлагает установить сам, но показывает окно «Для установки необходимо использовать…»). с другими приложениями на .net история та же
Пробовал много раз включать отключать этот компонент, с перезагрузками и без, с последующим обновлением системы и без — на всех этапах наблюдаю одну из этих ошибок.
Прошу помочь восстановить работоспособность .net без переустановки системы.
Предполагаю, что есть смысл использовать какой-то клинер системы, но я всегда относился очень осторожно ко всяким клинерам и ускорителям, поэтому посоветуйте какой-нибудь и скажите какую функцию надо использовать (чтоб лишнего не испортить)
28.01.2022
Руководства
12,701 Views
Статья представляет собой пошаговое решение ошибки установки .NET Framework 3.5 на Windows 10. Решение подходит для ошибок: 0x8024401С, 0x800F081F, 0x800F0950 (и, возможно, других, связанных с ошибкой установки .NET Framework 3.5)
Довольно часто, при установке .NET Framework 3.5 на Windows 10, возникает ошибка: «Не удалось установить следующий компонент: .NET Framework 3.5 (включает .NET 2.0 и 3.0)»
Ниже представлено пошаговое решение данной проблемы.
Решение:
1. После возникновения ошибки: «Не удалось установить следующий компонент: .NET Framework 3.5 (включает .NET 2.0 и 3.0)» нажмите в окне Закрыть (Рис.1).
Рис.1
.
2. Нажмите клавиши Win + R (либо: Пуск, затем откройте там папку Служебные — Windows и выберите в ней Выполнить). В открывшемся окне в поле для ввода введите: regedit и нажмите ОК (Рис.2).
Рис.2
.
3. В окне Редактор реестра перейдите к разделу (это можно сделать через левую часть окна): HKEY_LOCAL_MACHINESOFTWAREPoliciesMicrosoftWindowsWindowsUpdateAU (прим. можете скопировать отсюда и вставить в соответствующее поле в Редакторе реестра., либо найти нужную директорию через дерево папок в левой части окна Редактора реестра), затем сделайте двойной клик по параметру UseWUServer (Рис.3).
Рис.3
.
4. В открывшемся окне Именение параметра DWORD (32 бита) установите в поле Значение 0 (прим. вместо 1) и нажмите ОК (Рис.4).
Рис.4
.
5. Убедитесь, что значение параметра с именем UseWUServer изменилось на 0, после чего перезагрузите компьютер (Рис.5).
Рис.5
.
6. После перезагрузки компьютера, запустите установку .NET Framework 3.5, убедитесь, что установка прошла успешно и нажмите Закрыть (Рис.6).
Рис.6
.
7. После успешной установки .NET Framework 3.5, руководствуясь вышеописанным, установите значение 1 для параметра с именем UseWUServer, нажмите ОК и перезагрузите компьютер (Рис.7).
Рис.7
.
Установка .NET Framework 3.5 завершена!
.