Ответ 1
Полностью удалив NuGet через расширения и обновления, перезагрузка VS, а затем повторная установка NuGet через расширения и обновления, решила проблему для меня. Полная переустановка VS не нужна.
Только что открывшая VS 2015 Enterprise RTM, открыла существующий рабочий проект, получив следующую ошибку:
Microsoft Visual Studio
Пакет 'NuGetPackage' загрузился неправильно.
Проблема может быть вызвана изменением конфигурации или установкой другого расширения. Вы можете получить дополнительную информацию, просмотрев файл
C:\Users\REDACTED\AppData\Roaming\Microsoft\VisualStudio\14.0\ActivityLog.xml
.Перезапуск Visual Studio может помочь решить эту проблему.
Продолжить, чтобы показать это сообщение об ошибке?
[Да] [Нет]
Перезапуск не помог. Я просмотрел файл журнала и нашел следующие разделы, относящиеся к nuget:
<entry>
<record>555</record>
<time>2015/07/20 16:06:34.364</time>
<type>Error</type>
<source>Extension Manager</source>
<description>Extension will not be loaded because an extension with the same ID
'Microsoft.Dev14.VsixTemplatesPackage.443cca91-ec20-41e5-a165-f28e56b89650'
is already loaded at C:\PROGRAM FILES (X86)\MICROSOFT VISUAL STUDIO 14.0\COMMON7\IDE\
EXTENSIONS\G2URSPAC.VAZ\...</description>
<path>C:\PROGRAM FILES (X86)\MICROSOFT VISUAL STUDIO 14.0\COMMON7\IDE\EXTENSIONS\
NUGETIFIEDEXTENSIBILITYTEMPLATES\</path>
</entry>
<entry>
<record>556</record>
<time>2015/07/20 16:06:34.364</time>
<type>Error</type>
<source>Extension Manager</source>
<description>Extension will not be loaded because an extension with the same ID
'Microsoft.VisualStudio.TeamFoundation.TeamExplorer.Extensions' is already
loaded at C:\PROGRAM FILES (X86)\MICROSOFT VISUAL STUDIO 14.0\COMMON7\IDE\EXTENSIONS\
B1NUOYPH.H2N\...</description>
<path>C:\PROGRAM FILES (X86)\MICROSOFT VISUAL STUDIO 14.0\COMMON7\IDE\COMMONEXTENSIONS\
MICROSOFT\TEAMFOUNDATION\TEAM EXPLORER\</path>
</entry>
Что будет предлагать дублирующее расширение, но это не похоже на менеджер расширений.
Это на машине, на которой установлен VS2013. У него не было никаких предварительных/RC-сборников VS2015, установленных когда-либо.
Полностью удалив NuGet через расширения и обновления, перезагрузка VS, а затем повторная установка NuGet через расширения и обновления, решила проблему для меня. Полная переустановка VS не нужна.
Обновление Nuget до последней версии, похоже, решило проблему.
Инструменты > Расширения и обновления
Обновления > Галерея Visual Studio
Нажмите Обновить в диспетчере пакетов Nuget
После полностью чистой установки Visual Studio Professional 2015 с веб-сайта MSDN я запустил VS2015 в качестве администратора, открыл консоль диспетчера пакетов с Tools -> NuGet Package Manager... -> Package Manager Console
, и я получил эту ошибку:
"Windows PowerShell updated your execution policy successfully,
but the setting is overridden by a policy defined at a more
specific scope. Due to the override, your shell will retain its
current effective execution policy of Unrestricted.
Type "Get-ExecutionPolicy -List" to view your execution policy
settings. For more information please see "Get-Help Set-ExecutionPolicy"
Следуя приведенным выше шагам к
1) Используйте Tools -> Extensions and Updates...
для удаления NuGet Package Manager for Visual Studio 2015
.
2) Перезапустите Visual Studio.
3) Используйте Tools -> Extensions and Updates...
для переустановить NuGet Package Manager for Visual Studio 2015
.
4) Перезапустите Visual Studio.
Теперь, когда я открываю консоль диспетчера пакетов, Powershell загружается правильно, и все хорошо. Большое спасибо за это!
Имейте в виду
Повторная установка диспетчера пакетов NuGet делает НЕ, похоже, удалять существующий файл NuGet.Config, хранящийся в каталоге c:\users\name\AppData\Roaming\NuGet!
У Mine отсутствовал раздел "packagesSources" (почему, я не знаю), но поскольку этот файл не был воссоздан, NuGet все еще не работает!
Итак, либо вручную введите этот раздел, либо удалите этот файл конфигурации, а затем переустановите NuGet через расширения и обновления, которые воссоздают новый!
Удаление всех файлов из этой папки C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE\Extensions\imf5jbeu.eak
, похоже, сработало для меня.
Кажется, что nuget в VS2015 настроен для отображения только пакетов microsoft. Чтобы иметь возможность искать все пакеты в nuget.org, откройте "Инструменты" > "Параметры" > "Диспетчер пакетов NuGet" > "Источники пакетов", нажмите "Добавить", поместите nuget.org в качестве "Имя" и https://www.nuget.org/api/v2/ в качестве источника, затем нажмите "ОК". Теперь в Nuget Package Manager вы можете выбрать nuget.org(или All) в качестве источника пакета, и вы сможете искать все пакеты (а не только те, которые поступают от Microsoft).
У меня была та же проблема и она была решена с помощью уже упомянутого решения, но потребовалось больше попыток. Необходимо полностью перезапустить VS после удаления и установки расширения NuGetPackage, и в моей системе он не работал, пока я не закрыл свое открытое решение. Надеемся, что расширение NuGetPackage станет более стабильным в ближайшем будущем.
При обновлении проектов с пакетами nuget от Vx20XX до VS2015 может возникнуть проблема с пакетами nuget.
Пример сообщения об ошибке: Этот проект ссылается на пакеты NuGet, отсутствующие на этом компьютере. Включите восстановление пакета NuGet, чтобы загрузить их. Для получения дополнительной информации см. http://go.microsoft.com/fwlink/?LinkID=322105.
Я исправил свою проблему, написав небольшую программу, которая делает восстановление MSBuild-интегрированного пакета и автоматическое восстановление пакетов
Вы можете скачать исполняемый файл инструмента здесь.
Пожалуйста, дайте мне знать результат:-)!
Код в качестве ссылки:
<Window x:Class="FixNuGetProblemsInVs2015.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:FixNuGetProblemsInVs2015"
mc:Ignorable="d"
Title="Fix NuGet Packages problems in Visual Studio 2015 (By Eric Ouellet)" Height="350" Width="525">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="Auto"></RowDefinition>
<RowDefinition Height="Auto"></RowDefinition>
<RowDefinition Height="*"></RowDefinition>
<RowDefinition Height="Auto"></RowDefinition>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto"></ColumnDefinition>
<ColumnDefinition Width="10"></ColumnDefinition>
<ColumnDefinition></ColumnDefinition>
</Grid.ColumnDefinitions>
<TextBlock Grid.Row="0" Grid.Column="0">Root directory of projects</TextBlock>
<Grid Grid.Row="0" Grid.Column="2">
<Grid.ColumnDefinitions>
<ColumnDefinition></ColumnDefinition>
<ColumnDefinition Width="Auto"></ColumnDefinition>
</Grid.ColumnDefinitions>
<TextBox Grid.Column="0" Name="DirProjects"></TextBox>
<Button Grid.Column="1" VerticalAlignment="Bottom" Name="BrowseDirProjects" Click="BrowseDirProjectsOnClick">Browse...</Button>
</Grid>
<!--<TextBlock Grid.Row="1" Grid.Column="0">Directory of NuGet Packages</TextBlock>
<Grid Grid.Row="1" Grid.Column="2">
<Grid.ColumnDefinitions>
<ColumnDefinition></ColumnDefinition>
<ColumnDefinition Width="Auto"></ColumnDefinition>
</Grid.ColumnDefinitions>
<TextBox Grid.Column="0" Name="DirPackages"></TextBox>
<Button Grid.Column="1" Name="BrowseDirPackages" Click="BrowseDirPackagesOnClick">Browse...</Button>
</Grid>-->
<TextBox Grid.Row="2" Grid.Column="0" Grid.ColumnSpan="3" Name="TxtLog" IsReadOnly="True"></TextBox>
<Button Grid.Row="3" Grid.Column="0" Click="ButtonRevertOnClick">Revert back</Button>
<Button Grid.Row="3" Grid.Column="2" Click="ButtonFixOnClick">Fix</Button>
</Grid>
</Window>
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Forms;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Xml;
using System.Xml.Linq;
using Application = System.Windows.Application;
using MessageBox = System.Windows.MessageBox;
/// <summary>
/// Applying recommanded modifications in section : "MSBuild-Integrated package restore vs. Automatic Package Restore"
/// of : http://docs.nuget.org/Consume/Package-Restore/Migrating-to-Automatic-Package-Restore
/// </summary>
namespace FixNuGetProblemsInVs2015
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
DirProjects.Text = @"c:\prj";
// DirPackages.Text = @"C:\PRJ\NuGetPackages";
}
private void BrowseDirProjectsOnClick(object sender, RoutedEventArgs e)
{
FolderBrowserDialog dlg = new FolderBrowserDialog();
dlg.SelectedPath = DirProjects.Text;
if (dlg.ShowDialog() == System.Windows.Forms.DialogResult.OK)
{
DirProjects.Text = dlg.SelectedPath;
}
}
//private void BrowseDirPackagesOnClick(object sender, RoutedEventArgs e)
//{
// FolderBrowserDialog dlg = new FolderBrowserDialog();
// dlg.SelectedPath = DirPackages.Text;
// if (dlg.ShowDialog() == System.Windows.Forms.DialogResult.OK)
// {
// DirPackages.Text = dlg.SelectedPath;
// }
//}
// private string _dirPackages;
private void ButtonFixOnClick(object sender, RoutedEventArgs e)
{
DoJob(false);
}
private void ButtonRevertOnClick(object sender, RoutedEventArgs e)
{
DoJob(true);
}
private void DoJob(bool revert = false)
{
TxtLog.Text = "";
string dirProjects = DirProjects.Text;
// _dirPackages = DirPackages.Text;
if (!Directory.Exists(dirProjects))
{
MessageBox.Show("Projects directory does not exists: " + dirProjects);
return;
}
//if (!Directory.Exists(_dirPackages))
//{
// MessageBox.Show("Packages directory does not exists: " + _dirPackages);
// return;
//}
RecurseFolder(dirProjects, revert);
}
private void RecurseFolder(string dirProjects, bool revert = false)
{
if (revert)
{
Revert(dirProjects);
}
else
{
FixFolder(dirProjects);
}
foreach (string subfolder in Directory.EnumerateDirectories(dirProjects))
{
RecurseFolder(subfolder, revert);
}
}
private const string BackupSuffix = ".fix_nuget_backup";
private void Revert(string dirProject)
{
foreach (string filename in Directory.EnumerateFiles(dirProject))
{
if (filename.ToLower().EndsWith(BackupSuffix))
{
string original = filename.Substring(0, filename.Length - BackupSuffix.Length);
if (File.Exists(original))
{
File.Delete(original);
}
File.Move(filename, original);
Log("File reverted: " + filename + " ==> " + original);
}
}
}
private void FixFolder(string dirProject)
{
BackupFile(System.IO.Path.Combine(dirProject, "nuget.targets"));
BackupFile(System.IO.Path.Combine(dirProject, "nuget.exe"));
foreach (string filename in Directory.EnumerateFiles(dirProject))
{
if (filename.ToLower().EndsWith(".csproj"))
{
FromProjectFileRemoveNugetTargets(filename);
}
}
}
private void BackupFile(string path)
{
if (File.Exists(path))
{
string backup = path + BackupSuffix;
if (!File.Exists(backup))
{
File.Move(path, backup);
Log("File backup: " + backup);
}
else
{
Log("Project has already a backup: " + backup);
}
}
}
private void FromProjectFileRemoveNugetTargets(string prjFilename)
{
XDocument xml = XDocument.Load(prjFilename);
List<XElement> elementsToRemove = new List<XElement>();
foreach (XElement element in xml.Descendants())
{
if (element.Name.LocalName == "Import")
{
var att = element.Attribute("Project");
if (att != null)
{
if (att.Value.Contains("NuGet.targets"))
{
elementsToRemove.Add(element);
}
}
}
if (element.Name.LocalName == "Target")
{
var att = element.Attribute("Name");
if (att != null && att.Value == "EnsureNuGetPackageBuildImports")
{
elementsToRemove.Add(element);
}
}
}
if (elementsToRemove.Count > 0)
{
elementsToRemove.ForEach(element => element.Remove());
BackupFile(prjFilename);
xml.Save(prjFilename);
Log("Project updated: " + prjFilename);
}
}
private void Log(string msg)
{
TxtLog.Text += msg + "\r\n";
}
}
}
Перейдите в:
Инструменты
Расширения и обновления
Вставить в поле поиска справа Nuget Package Manager
и настройте его (полная настройка).
После этого у вас будет пакет управления пакетами Nuget в разделе "Инструменты".
Я нашел это в google, получил аналогичную ошибку: пакет "NuGetPackage" загрузился неправильно.
Произошла ошибка при чтении файла xxx. Есть дубликат пакеты.
Проверьте файл packages.config в каждом проекте и удалите из него дублируемую строку пакета, и он должен работать.