Я получаю следующую ошибку на одном из наших производственных серверов. Не уверен, почему он работает на сервере DEV?
Описание ошибки синтаксического анализатора : во время анализа ресурса, необходимого для обслуживания этого запроса, произошла ошибка. Пожалуйста, просмотрите следующую конкретную информацию об ошибке разбора и измените исходный файл соответствующим образом.
Сообщение об ошибке синтаксического анализатора : не удалось загрузить тип «TestMvcApplication.MvcApplication».
Ошибка источника :
Строка 1: <% @ Application Codebehind = "Global.asax.cs" Inherits = "TestMvcApplication.MvcApplication" Language = "C #"%>
Исходный файл: /global.asax Строка: 1
Не уверен, сталкивался ли кто-нибудь с этой ошибкой раньше и как она была исправлена, но я дошел до конца. Любая помощь будет оценена.
Я также должен упомянуть, что это опубликованный код, поэтому все компилируется. Может ли быть что-то не так с моими настройками компилятора?
источник
Ответы:
Ни один из других ответов не работал для меня. Я исправил ошибку, изменив путь вывода веб-проекта. У меня было установлено bin \ debug, но веб-проект не работает, если путь вывода не установлен просто "bin"
источник
У меня было это пару раз. Это особенно расстраивает, поскольку это сразу, и сообщение об ошибке не имеет ни малейшего представления о том, что может быть проблемой.
Чтобы это исправить, щелкните правой кнопкой мыши заголовок вашего проекта, в данном случае «TestMvcApplication» и нажмите « build» .
Это вынуждает код компилироваться перед его запуском. Не спрашивайте меня, почему, но это было решением 100% времени для меня.
источник
Я обнаружил, что, когда вы вынуждены использовать Configuration Manager для запуска под x86 или чем-то иным, кроме стандартных настроек «из коробки» для стандартного проекта, IDE создает группу подкаталогов в папке bin для веб-проекта.
Как только это начинает происходить, если сервер Cassini работает, то проект не работает должным образом.
Я исправил это, зайдя в свойства веб-проекта -> Настройки сборки и изменив путь вывода на bin \
Потом пересобирай и все работает как надо.
источник
После долгого тяжелого взгляда я наткнулся на реальную проблему здесь.
Сборки были повреждены клиентом FTP, который я использовал для загрузки файлов в размещенную среду.
Я изменил свой FTP-клиент, и все работает как задумано.
источник
У меня была та же самая проблема: моя была, потому что у веб-проекта была целевая платформа x86. Я работал на 64-битной машине; другие проекты в решении были установлены на 64-битные.
Чтобы проверить настройки, щелкните правой кнопкой мыши проект и выберите «Свойства». На вкладке «Сборка» проверьте значение «Цель платформы».
Также проверьте конфигурацию сборки вашего решения (меню «Сборка»> «Диспетчер конфигурации»), чтобы убедиться, что все ваши проекты собираются на одной платформе.
В обоих случаях убедитесь, что вы проверили настройки как для режима отладки, так и для режима выпуска - в противном случае он будет работать на вашем компьютере, но не при его развертывании!
источник
Я перепробовал все вышеперечисленные решения, но не повезло. Добавление строки
<add assembly="*" />
в web.config исправило это для меня. (Вы также можете добавить в файл machine.config или корневой файл web.config соответствующей версии .NET Framework, я не пробовал). Спасибо MS Support за решение.источник
<assemblies><clear/>...
предотвратить наследование ссылок на сборки от родительского приложения во вложенном приложении IIS.У меня было то, что выглядело как та же ошибка. Я перепробовал много предложений со многих страниц только для того, чтобы выяснить, что проблема в том, что на моем веб-сайте установлена неправильная версия .Net
Независимо от того, сколько перекомпилируется или кто-то говорит «проблема конфигурации», никто не считает, что нужно проверять версию .net.
источник
Это происходит со мной, когда я переименовываю свой проект / решение. Перейти в папку проекта в Windows Explorer (выйти из VS). Найдите и откройте файл Global (может быть, вы найдете 2 файла, которые не имеют расширения «.asax.cs»), и отредактируйте строку ошибки с правильным путем. Удачи!
источник
Я столкнулся с той же самой проблемой пару дней назад - насколько я могу судить, это была проблема с 64-разрядным IIS, работающим с 32-разрядным веб-приложением. Мы изменили наш производственный сервер на 32-битный, и эта проблема исчезла.
источник
Убедитесь, что ваше пространство имен по умолчанию в свойствах веб-проекта совпадает с пространством имен в Global.asax.cs. Я изменил пространство имен по умолчанию, сделав его подпространством имен, и изменив его обратно, я решил эту проблему.
источник
Для полноты картины я включил в себя мою проблему и то, как я ее решил:
Если вам нравится я и у вас есть httphandlers через web.config, и у вас есть перенаправления из вашего global.asax.cs (возможно, в Session_Start ()), как в моем случае, вы получаете эту ошибку, если ваш стартовый проект не имеет определенной ссылки, которая указывает на цель, на которую указывает ваш httphandler !! (но вы не получите ошибки сборки, только ошибки времени выполнения)
Так:
Приветствия.
источник
Единственный раз, когда я испытал это, был когда MVC Framework не был установлен на сервере. Может ли это быть так?
Отсутствующий раздел Pages в Views \ Web.config также может быть причиной ошибки.
источник
У меня была такая же ошибка, и ни одно из ваших решений не помогло. Я думаю, что моей проблемой было просто имя, которое я выбрал для проекта. Я назвал свой проект «интерфейс», который, когда я получил ошибку синтаксического анализа, он сказал, что он не может загрузить:
Где по какой-то причине был знак «@». Я предполагаю, что слово «интерфейс» зарезервировано для чего-то другого, и оно добавило символ @, но это явно что-то сломало. Я удалил проект и сделал новый с другим именем без проблем.
источник
Вот еще один:
Я надеюсь, что это кому-то поможет где-то :)
источник
У меня было много проблем и ошибок, которые нужно было решить, некоторые из приведенных выше ответов помогли, но последний трюк, который заставил меня сработать, был следующим: перейдите в свой проект, щелкните свойства.
Перейдите на вкладку «Пакет / публикация в Интернете» и убедитесь, что для конфигурации выбрано «Выпуск» и «Платформа для всех платформ».
Последнее, убедитесь, что «Элементы для развертывания (применяется ко всем методам развертывания)» установлен на «Все файлы в этой папке проекта»
Тогда это работало хорошо для меня.
источник
Эта проблема сложна, потому что легко спутать первопричину с какой бы то ни было непосредственной причиной.
В моем случае непосредственной причиной было то, что решение настроено для использования NuGet Package Restore, но сервер не был подключен к Интернету, поэтому NuGet не удалось загрузить зависимости при сборке в первый раз.
Я считаю, что основная причина заключается в том, что решение не может правильно разрешить зависимости. Это может быть неверная конфигурация пути, неправильная версия сборки, конфликтующие сборки или частичное развертывание. Но во всех случаях ошибка просто говорит о том, что он не может найти тип, указанный в global.asax, потому что он не может его собрать.
источник
Убедитесь, что пространство имен в
Global.asax
файле совпадает с пространством имен в файле,Global.cs
т.е.global.asax:
Some.Website.Webapplication
Global.cs:
Some.Website
(без «Веб-приложения»)источник
Я попробовал большинство из приведенных выше ответов, и они не сработали. По какой-то причине закрытие и повторное открытие VS решило проблему для меня.
источник
Моя проблема была решена, когда я преобразовал в IIS физическую папку, в которой находились файлы, в приложение. Щелкните правой кнопкой мыши> преобразовать в приложение.
источник
Для меня это было потому, что я временно исключил файл из проекта. Я просто включил его обратно в проект, и тогда это сработало.
источник
В моем случае ссылка на System.Web.MVC отсутствовала в моем проекте. Но после добавления ссылки проблема была такой же, поэтому я проверил свойства моей папки Bin, это было ReadOnly. Просто после того, как сделать его доступным для записи, все работает нормально.
источник
Я получал ошибку, потому что я развернул приложение как виртуальный каталог, и я получал ошибку синтаксического анализатора «не удалось загрузить тип», затем я развернул приложение как веб-сайт, и я больше не получал эту ошибку.
источник
Ни один из других ответов не решил эту ошибку для меня.
Я нашел решение, которое сработало, которое я предлагаю для тех, кто в той же ситуации:
источник
Я действительно никогда не понимал, что вызывает это для меня. Я думаю, что где-то я, должно быть, пропустил некоторые файлы. Я получил ошибку после публикации на новом сервере. В конце концов я скопировал сайт с рабочего сайта. Затем сайт заработал, как и дальнейшие публикации на новом сервере.
источник
Следуй этим шагам:
источник
Для меня в мой проект была включена DLL, которую нужно было запускать в 32-битной среде.
Сервер был настроен для запуска веб-сайта в 32-разрядном режиме, но я не смог запустить приложение на моей 64-разрядной машине, поскольку
localhost
папка не была указана для запуска в 32-разрядном режиме.источник
У меня просто была похожая проблема.
Причина была в том, что я менял файл .aspx.c и должен был сделать чистое восстановление. После этого все заработало.
источник
Моя проблема заключалась в том, что я пытался создать веб-приложение ASPX в подпапке папки, в которой уже был файл web.config, и
Поэтому я открыл родительскую папку в Visual Studio как веб-сайт («Открыть»> «Веб-сайт») и смог добавить страницу ASPX нового элемента, в которой не было проблем с анализом / загрузкой.
источник
Для меня проблема была только в определенных (длинных) ссылках на веб-сайте и была отслежена до URLScan, имеющего конфигурацию по умолчанию с ограничением длины URL-адреса 260.
источник
У меня была такая же проблема. Пробовать:
Щелкните правой кнопкой мыши по проекту и выберите «Очистить», затем снова щелкните правой кнопкой мыши по нему и выберите «Перестроить» и запустите проект, чтобы увидеть, работает ли он.
источник