Как исправить фатальную ошибку C1083 и LNK1104 в Windows при сборке openssl 3 с помощью conan?

Когда я пытаюсь собрать свое приложение, которое зависит от openssl3, с помощью conan, я получаю следующую ошибку, когда conan пытается собрать openssl3:

> conan install . --build=missing --profile:build=default_windows_x64_release --profile=default_windows_x64_debug
...
openssl/3.0.8: Generating aggregated env files
openssl/3.0.8: Generated aggregated env files: ['conanbuild.bat', 'conanrun.bat']
openssl/3.0.8: Calling build()
openssl/3.0.8: RUN: C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe ./Configure "VC-conan-Debug-Windows-x86_64-msvc-191" no-shared --prefix=/ --libdir=lib --openssldir = "C:\Users\username\.conan2\p\b\opens4a3ff4f862506\p\res" no-unit-test threads PERL=C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe no-tests --debug enable-fips no-md2 zlib --with-zlib-include = "C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/include" --with-zlib-lib = "C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/lib/zlib.lib"
conanvcvars.bat: Activating environment Visual Studio 15 - amd64 - winsdk_version=None - vcvars_ver=14.1
[vcvarsall.bat] Environment initialized for: 'x64'
Configuring OpenSSL version 3.0.8 for target VC-conan-Debug-Windows-x86_64-msvc-191
Using os-specific seed configuration
Created configdata.pm
Running configdata.pm
Created makefile.in
Created makefile
Created include\openssl\configuration.h

**********************************************************************
***                                                                ***
***   OpenSSL has been successfully configured                     ***
***                                                                ***
***   If you encounter a problem while building, please open an    ***
***   issue on GitHub <https://github.com/openssl/openssl/issues>  ***
***   and include the output from the following command:           ***
***                                                                ***
***       perl configdata.pm --dump                                ***
***                                                                ***
***   (If you are new to OpenSSL, you might want to consult the    ***
***   'Troubleshooting' section in the INSTALL.md file first)      ***
***                                                                ***
**********************************************************************

openssl/3.0.8: RUN: nmake
conanvcvars.bat: Activating environment Visual Studio 15 - amd64 - winsdk_version=None - vcvars_ver=14.1
[vcvarsall.bat] Environment initialized for: 'x64'

Microsoft (R) Program Maintenance Utility Version 14.16.27051.0
Copyright (C) Microsoft Corporation.  All rights reserved.

        "C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe" "-I." -Mconfigdata "util\dofile.pl" "-omakefile" "include\crypto\bn_conf.h.in" > include\crypto\bn_conf.h
        ...
        "C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\nmake.exe" /                   depend

Microsoft (R) Program Maintenance Utility Version 14.16.27051.0
Copyright (C) Microsoft Corporation.  All rights reserved.

        "C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\nmake.exe" /                   _build_sw

Microsoft (R) Program Maintenance Utility Version 14.16.27051.0
Copyright (C) Microsoft Corporation.  All rights reserved.

        "cl"  /Zi /Fdossl_static.pdb /MTd /Zl /Gs0 /GF /Gy -MTd -Zi -Ob0 -Od -FS -MTd -Zi -Ob0 -Od -FS -I"." -I"include" -I"apps\include" -D"L_ENDIAN" -D"OPENSSL_PIC" -D"OPENSSLDIR=\"C:\\Users\\username\\.conan2\\p\\b\\opens4a3ff4f862506\\p\\res\"" -D"ENGINESDIR=\"\\lib\\engines-3\"" -D"MODULESDIR=\"\\lib\\ossl-modules\"" -D"OPENSSL_BUILDING_OPENSSL" -D"ZLIB" -D"OPENSSL_SYS_WIN32" -D"WIN32_LEAN_AND_MEAN" -D"UNICODE" -D"_UNICODE" -D"_CRT_SECURE_NO_DEPRECATE" -D"_WINSOCK_DEPRECATED_NO_WARNINGS" -D"DEBUG" -D"_DEBUG" -I"C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/include"   -c /Foapps\lib\libapps-lib-app_libctx.obj "apps\lib\app_libctx.c"
Microsoft (R) C/C++ Optimizing Compiler Version 19.16.27051 for x64
Copyright (C) Microsoft Corporation.  All rights reserved.

app_libctx.c
C:\Users\username\.conan2\p\b\opens4a3ff4f862506\b\src\include\openssl/crypto.h(25): fatal error C1083: Cannot open include file: 'stdlib.h': No such file or directory
NMAKE : fatal error U1077: '"C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\cl.EXE"' : return code '0x2'
Stop.
NMAKE : fatal error U1077: '"C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\nmake.exe"' : return code '0x2'
Stop.

openssl/3.0.8: ERROR:
Package 'df45d737e7817e09557f98b927968632469772f8' build failed
openssl/3.0.8: WARN: Build folder C:\Users\username\.conan2\p\b\opens4a3ff4f862506\b\build-debug
ERROR: openssl/3.0.8: Error in build() method, line 520
        self._make()
while calling '_make', line 513
        self._run_make()
while calling '_run_make', line 490
        self.run(" ".join(command), env = "conanbuild")
        ConanException: Error 2 while executing

Я подозреваю, что это происходит потому, что MSVS неправильно устанавливает все включения и пути. Я так думаю, потому что когда я выполняю «set INCLUDE» в командной строке разработчика для VS 2017, я получаю следующее:

>set include
INCLUDE=C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\ATLMFC\include;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\include;C:\PROGRA~1\IBM\SQLLIB\INCLUDE;C:\PROGRA~1\IBM\SQLLIB\LIB

С другой стороны, когда я вручную добавляю недостающие включения в командную строку разработчика, например:

set INCLUDE=%INCLUDE%;C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\winrt;C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\shared;C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\um;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Auxiliary\VS\UnitTest\include;C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\ucrt;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Auxiliary\VS\include;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\atlmfc\include;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\include;C:\3coreserver\commlib2a\openssl\windows\vs2012\include;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\PlatformSDK\include;C:\Program Files (x86)\Windows Kits\10\Source\10.0.16299.0\ucrt;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Auxiliary\VS\src;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\crt\src;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\atlmfc\src\atl;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\atlmfc\src\mfcm;C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\atlmfc\src\mfc;

Я получаю другую ошибку:

legacyprov.c
        cmd /C ""cl" /Zs /showIncludes  /Zi /Fddso.pdb /Gs0 /GF /Gy -MTd -Zi -Ob0 -Od -FS -MTd -Zi -Ob0 -Od -FS -I"include" -I"providers\implementations\include" -I"providers\common\include" -D"OPENSSL_BUILDING_OPENSSL" -D"ZLIB" -D"OPENSSL_SYS_WIN32" -D"WIN32_LEAN_AND_MEAN" -D"UNICODE" -D"_UNICODE" -D"_CRT_SECURE_NO_DEPRECATE" -D"_WINSOCK_DEPRECATED_NO_WARNINGS" -D"DEBUG" -D"_DEBUG" -I"C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/include"   "providers\legacyprov.c" > providers\legacy-dso-legacyprov.d 2>&1"
        "C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe" "util\mkrc.pl" legacy > providers\legacy.rc
        "rc"  /foproviders\legacy-dso-legacy.res "providers\legacy.rc"
Microsoft (R) Windows (R) Resource Compiler Version 10.0.10011.16384
Copyright (C) Microsoft Corporation.  All rights reserved.

        "C:/Users/username/.conan2/p/straw898fb56546adc/p/bin/perl.exe" "util\mkdef.pl" --type dso --ordinals util\providers.num --name legacy --OS windows > providers\legacy.def
        IF EXIST providers\legacy.dll.manifest DEL /F /Q providers\legacy.dll.manifest
        cmd /C ""link" -debug /dll -debug -debug @C:\Users\username\AppData\Local\Temp\2\nm17C5.tmp || (DEL /Q legacy.* providers\legacy.* & EXIT 1)"
Microsoft (R) Incremental Linker Version 14.16.27051.0
Copyright (C) Microsoft Corporation.  All rights reserved.

providers\legacy-dso-legacyprov.obj
/out:providers\legacy.dll
providers\liblegacy.lib
providers\libcommon.lib
libcrypto.lib
C:/Users/username/.conan2/p/b/zlib69dc6f0d4df93/p/lib/zlib.lib ws2_32.lib gdi32.lib advapi32.lib crypt32.lib user32.lib
/def:providers\legacy.def providers\legacy-dso-legacy.res
LINK : fatal error LNK1104: cannot open file 'ws2_32.lib'
Could Not Find C:\Users\username\.conan2\p\b\opensdbeefee112c1f\b\src\legacy.*
NMAKE : fatal error U1077: 'cmd' : return code '0x1'
Stop.
NMAKE : fatal error U1077: '"C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\HostX64\x64\nmake.exe"' : return code '0x2'
Stop.

У меня установлен Microsoft SDK (10.0.16299.0) для VS 2017, но пути включения и библиотеки не установлены по умолчанию.

Я не понимаю, как это исправить, пожалуйста, помогите.

Редактировать 1. Некоторые версии:

>python --version
Python 3.10.10
>conan --version
Conan version 2.4.1
>cmake --version
cmake version 3.25.1

CMake suite maintained and supported by Kitware (kitware.com/cmake).

Редактировать 2. Что я уже пытался исправить:

  1. переустановка Windows SDK через установщик Visual Studio с промежуточными перезагрузками (проблема не решена)
  2. удаление MSVS 2022, который также был установлен вместе с MSVS 2017 (проблема не решена)
  3. восстановление MSVS 2017 (проблема не решена)
  4. добавление местоположения Windows SDK (C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0*) в PATH (проблема не решена)
  5. полная переустановка MSVS 2017 (проблема не решена)

Как ты устанавливал из MS VStudio или что ты из него устанавливал?

CristiFati 18.06.2024 15:03

В качестве альтернативы: github.com/CristiFati/Prebuilt-Binaries/tree/master/OpenSSL/‌​…

CristiFati 18.06.2024 15:42

У меня не получилось воспроизвести. Я только что попробовал на своей машине conan install --requires=openssl/3.0.8 -s compiler.version=191 --build=missing, и все получилось правильно. Возможно, ваша установка VS2017 не завершена? Я использовал последнюю версию Конана 2.4. Было бы лучше подать заявку на github.com/conan-io/conan/issues и предоставить дополнительную информацию.

drodri 18.06.2024 20:44

@drodri, вполне вероятно, что мой MSVS сломан. Я уже пытаюсь переустановить его, но это займет довольно много времени из-за моей рабочей политики. Но переустановка MSVS 2017 звучит как обходной путь, а не исправление, и я хотел бы найти постоянное решение, например, установить некоторые переменные env, изменить свойства реестра или каким-то образом настроить конфигурацию MSVS 2017. Кстати, я тоже использую conan 2.4, упомяну об этом в своем вопросе.

a_girl 18.06.2024 21:01

То, что вы только что описали, — это обходные пути, и переустановка — это исправление.

user207421 18.06.2024 23:56

Я согласен с @user207421, похоже, ваш VS2017 был сломан, cannot open file 'ws2_32.lib' системная библиотека VS является сильным показателем. Я не думаю, что попытка определить env-vars или реестр — это правильное решение, а скорее хак, и правильное решение — убедиться, что установка VS2017 правильна.

drodri 19.06.2024 12:15
stackoverflow.com/a/76300204/4788546
CristiFati 20.06.2024 11:17

@user207421 user207421, я попытался переустановить MSVS 2017. Это не решило проблему.

a_girl 20.06.2024 12:25
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
8
73
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я отвечаю на свой вопрос, так как нашел основную причину и временное решение.

В моем случае причина этой проблемы заключается в том, что у меня нет прав на чтение реестра Windows с помощью команды reg query и у моего пользователя не включен regedit из-за политик безопасности, установленных на моем рабочем месте.

Объяснение:

Microsoft Visual Studio настраивает среду разработки, вызывая сценарий vcvarsall.bat, который зависит от сценария winsdk.bat, который использует команду reg query для установки некоторых переменных среды разработки, необходимых для сборки некоторых пакетов (openssl 3.0.8 в моем случае).

РЕАЛЬНЫМ решением было бы получить хотя бы доступ только для чтения к реестру Windows.

Поскольку это может быть недостижимо, я нашел обходной путь:

  1. Найдите winsdk.bat вашей Microsoft Visual Studio (он должен быть где-то в C:\Program Files (x86)\Microsoft Visual Studio\2017\*\Common7\Tools\vsdevcmd\core\winsdk.bat, в моем случае * был Professional, но это также может быть Community или что-то еще, в зависимости от установленной версии MSVS)
  2. Откройте этот файл в блокноте с правами администратора (поскольку он защищен от изменения обычным пользователем; я добился этого, открыв Windows PowerShell от имени администратора, да, это мне разрешено, и запустив notepad winsdk.bat)
  3. Найдите функции, в которых вызывается reg query. Эти 2 функции: GetWin10SdkDirHelper и GetUniversalCRTSdkDirHelper.
  4. Сразу после их вызова следует установить переменные, которые обычно устанавливаются этими функциями, «вручную»:
call :GetWin10SdkDirHelper HKLM\SOFTWARE\Wow6432Node > nul 2>&1
set WindowsSdkDir=C:\Program Files (x86)\Windows Kits\10\
echo "debug 1" %WindowsSdkDir%
...
call :GetUniversalCRTSdkDirHelper HKLM\SOFTWARE\Wow6432Node > nul 2>&1
set UniversalCRTSdkDir=C:\Program Files (x86)\Windows Kits\10\
echo "debug 2" %UniversalCRTSdkDir%

В вашем конкретном случае путь к Windows SDK может быть другим. Я убедился, что в моей системе для этих конкретных записей реестра сначала установлены эти значения, но вы можете попробовать указать путь к вашему Windows 10 SDK и посмотреть, работает ли он.

Для этого обходного пути требуются определенные права администратора, которые позволяют вам изменять winsdk.bat, поэтому он может вам не подойти.

Существует также второй обходной путь — установка переменных dev env вручную.

Откройте «Командную строку разработчика для VS 2017» и введите следующие команды (ваши версии Windows SDK могут отличаться, но идея та же):

set INCLUDE=%INCLUDE%;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\ucrt;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\shared;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\um;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\winrt;C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\cppwinrt

set LIB=%LIB%;C:\Program Files (x86)\Windows Kits\10\lib\10.0.22621.0\ucrt\x86;C:\Program Files (x86)\Windows Kits\10\lib\10.0.22621.0\um\x86

set PATH=%PATH%;C:\Program Files (x86)\Windows Kits\10\bin\10.0.22621.0\x86;C:\Program Files (x86)\Windows Kits\10\bin\x86

После этого запустите conan build.

Предупреждение: этот обходной путь не является постоянным, и вам придется устанавливать эти переменные env каждый раз, когда вам нужно собрать пакеты, для которых требуется Windows SDK.

Другие вопросы по теме