Странная ошибка - CS0012: тип x определен в сборке, на которую нет ссылок
-
08-07-2019 - |
Вопрос
Тип 'x' определен в сборке, на которую нет ссылок. Вы должны добавить ссылку на сборку 'abc123'.
У меня есть веб-приложение .NET 2.0, которое ссылается на мою сборку 'abc123'. Сборка существует в GAC, и я убедился, что это правильная (та же) версия. У остальной части приложения нет проблем, за исключением одной страницы .aspx. У рассматриваемой страницы есть повторитель, который отображает пользовательский элемент управления в качестве одного из его «полей». После привязки списка типа y к повторителю я передаю пользовательскому элементу управления список типа x (свойство y), как показано здесь:
<uc1:usercontrol id="ucusercontrol " runat="server" myPublicUserControlProperty='<%#Eval("CollectionOfX") %>'/>
В наборе свойств пользовательского элемента управления я связываю список типа x с видом сетки в пользовательском элементе управления.
Одна странная вещь, которую стоит отметить, это то, что этот отчет прекрасно работает на моем компьютере для разработки, но не на каких-либо серверах после развертывания. Мой компьютер - Windows XP, IIS6, VS2005. Серверы - Windows Server 2003, IIS6.
Надеюсь, я объяснил это достаточно хорошо. Заранее благодарим за любые идеи, которые вы можете предоставить.
Решение
Я сотрудник Майка, и мы разработали решение.
Тип X определен в его сборке, то есть только в GAC. Несмотря на то, что его веб-приложение ASP.NET имело ссылку, его не удалось загрузить из GAC только для этого UserControl. Остальная часть приложения работала как положено. Мы подтвердили неудачную загрузку, поместив копию сборки в каталог bin, и все заработало. Мы сняли сборку, и проблема вернулась. Р>
Нашим решением было вручную добавить запись в web.config в разделе сборок, чтобы указать ASP.NET на GAC. Р>
Похоже, что каждый раз, когда вы ссылаетесь на тип на странице (не на код), вам нужна информация о сборке, определенная в файле web.config или в директиве страницы.
<assemblies>
<add assembly="MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=[MyPublicKeyToken]"/>
</assemblies>
Другие советы
Существует также ошибка, которая может проявляться похожими симптомами, описанная здесь .
Обходной путь - удалить все из каталога C: \ WINDOWS \ Microsoft.NET \ Framework \ v2.0.50727 \ Temporary ASP.NET Files \, и, похоже, он проявляется только в режиме отладки.
При устранении неполадок этих типов Журнал Fusion Зритель всегда очень помогал.
Я обнаружил, что если type x
действительно является классом в вашем App_Code
, его очистка и повторное сохранение часто вынуждает веб-приложение перекомпилировать и решать проблему. р>
Чаще всего это происходит из-за кэшированных сборок. Одним из способов решения этой проблемы является создание "сильной ссылки". в файле proj или config. Ссылайтесь на этот пост
У меня была точно такая же ошибка, но в моем классе был конструктор public , который использовал в качестве параметра объект из другого проекта.
Я решил проблему, сделав этот конструктор внутренним.
Для меня это была проблема с контролем версий. Р>
В Visual Studio откройте " Ссылки " в вашем обозревателе решений и пролистайте его. Р>
Если у чего-либо есть желтый предупреждающий треугольник, запомните имя, удалите его и добавьте обратно (или ReSharper сделает это за вас). Р>
Произошло со мной несколько раз после создания проекта, когда сотрудник добавил новый пакет и ссылки.