no win32com in java.library.path

0

Próbuje odplaić projekty na macu m1 w Parallels i z dwoma mam problem ponieważ dostaje taki bład

Error loading win32com: java.lang.UnsatisfiedLinkError: no win32com in java.library.path
Error loading win32com: java.lang.UnsatisfiedLinkError: no win32com in java.library.path

Exception in thread "main" java.lang.UnsatisfiedLinkError: no bridge2java in java.library.path

Jak mogę to naprawic ?

1

Java używa zmiennej java.library.path do określenia lokalizacji, w które ma szukać natywnych bibliotek (*.so, *.dll etc.). To, że dostajesz błąd "Error loading win32com: java.lang.UnsatisfiedLinkError: no win32com in java.library.path", oznacza, że java próbowała załadować bibliotekę, korzystając z ustawień systemowych, ale nie była w stanie jej odnaleźć.

Możesz to "naprawić" wskazując javie, gdzie ma szukać natywnych bibliotek win32com/bridge2java (*.dll/*.so), np. używając przełącznika -Djava.library.path=/katalog/w/ktorym/masz/win32com_i_bridge2java.

Odpalasz np. java -Djava.library.path=$HOME/projekt/biblioteki_natywne -jar moj.jar (bądź definiując java.library.path w ustawieniach projektowych)

Może się okazać, że te natywne biblioteki na Macu nie działają, bo są w projekcie stworzone pod konkretną platformę/wersję systemu operacyjnego.

Domyślnie java.library.path określne jest na podstawie ustawień systemowych:

  • Linux: $LD_LIBRARY_PATH
  • Win: $PATH
  • Mac: $DYLD_LIBRARY_PATH

Alternatywnie możesz skopiować owe biblioteki do DYLD_LIBRARY_PATH, albo ustawić DYLD_LIBRARY_PATH, tak by zawierało na katalog z bibliotekami win32com, bridge2java.
Pod linuksem można ustawić w profilu użytkownika. Na macu pewnie jakoś podobnie:
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$HOME/projekty/projekX/biblioteki_natywne

0

@yarel dostaje coś takiego

C:\Users\dev>java -Djava.library.path=C:\Developer\win32com.dll
Usage: java [-options] class [args...]
           (to execute a class)
   or  java [-options] -jar jarfile [args...]
           (to execute a jar file)
where options include:
    -d32          use a 32-bit data model if available
    -d64          use a 64-bit data model if available
    -client       to select the "client" VM
    -server       to select the "server" VM
                  The default VM is client.

    -cp <class search path of directories and zip/jar files>
    -classpath <class search path of directories and zip/jar files>
                  A ; separated list of directories, JAR archives,
                  and ZIP archives to search for class files.
    -D<name>=<value>
                  set a system property
    -verbose:[class|gc|jni]
                  enable verbose output
    -version      print product version and exit
    -version:<value>
                  Warning: this feature is deprecated and will be removed
                  in a future release.
                  require the specified version to run
    -showversion  print product version and continue
    -jre-restrict-search | -no-jre-restrict-search
                  Warning: this feature is deprecated and will be removed
                  in a future release.
                  include/exclude user private JREs in the version search
    -? -help      print this help message
    -X            print help on non-standard options
    -ea[:<packagename>...|:<classname>]
    -enableassertions[:<packagename>...|:<classname>]
                  enable assertions with specified granularity
    -da[:<packagename>...|:<classname>]
    -disableassertions[:<packagename>...|:<classname>]
                  disable assertions with specified granularity
    -esa | -enablesystemassertions
                  enable system assertions
    -dsa | -disablesystemassertions
                  disable system assertions
    -agentlib:<libname>[=<options>]
                  load native agent library <libname>, e.g. -agentlib:hprof
                  see also, -agentlib:jdwp=help and -agentlib:hprof=help
    -agentpath:<pathname>[=<options>]
                  load native agent library by full pathname
    -javaagent:<jarpath>[=<options>]
                  load Java programming language agent, see java.lang.instrument
    -splash:<imagepath>
                  show splash screen with specified image
See http://www.oracle.com/technetwork/java/javase/documentation/index.html for more details.
0

@Dev007: Pisałeś o Macu, a teraz pokazujesz efekt wykonania komendy pod Windows? Jeśli wpisałeś na pałę, to masz losowy wynik.

Nie wiem jak "uruchamiasz projekt", więc trudno mi określić, gdzie powinieneś umieścić ustawienia "java.library.path", tak by to miało ręce i nogi.

Najprostszym i najbardziej ułomnym rozwiązaniem jest dodanie ścieżki do zmiennej PATH (o ile to Windows). Umiesz pod windowsem dodać katalog do zmiennej PATH ?

Jeśli chcesz uruchamiać konsoli:
java -Djava.library.path=C:/Developer/win32com;C:/Developer/innyKatalog -jar TwojJar.jar

Zauważ, że dodawane są to katalogi (C:/Developer/win32com), a nie pliku C:\Developer\win32com.dll

0

@yarel: Przeraszam mój błąd. Ze względu na projekt musze to uruchomic na Windowsie z uzyciem Parallels( Mac m1). Mam projekt w już skonfigurowanym eclipse z 2012 roku, Dodalem w environment variables ta scieżkę ale nad nie działa. Chyba że coś żle robie ? Screenshot 2022-04-25 175908.png

0

@Dev007: zmiany w PATH widoczne są dla nowych procesów o ile proces je uruchamiający jest ich świadom. Jeśli projekt odpalasz z jakiegoś IDE, to należałoby zrestartować IDE, tak by IDE miało świadomość istnienia zmian w PATH. W przeciwnym razie proces (wirtualnej maszyny java) odziedziczy ustawienia środowiskowe z IDE.

Jeśli biblioteka win32com.dll jest w katalogu C:\Development, to w PATH powinno być dodane C:\Development, a nie jak Ci zasugerowałem C:\Development\win32com.

Dodaj sobie gdzieś logowanie System.getSystemProperty("java.library.path"), to będziesz widział z którego katalogu Java próbuje zaczytywać biblioteki natywne i czy widzi ten katalog, który ustawiłeś via PATH.

0

@yarel: Zadziałało ale teraz dostaałem to

	at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1738)
	at java.lang.Runtime.loadLibrary0(Runtime.java:823)
	at java.lang.System.loadLibrary(System.java:1028)
	at com.ibm.bridge2java.OleEnvironment.Initialize(OleEnvironment.java:10)
	at tr.com.yurticikargo.kopsproject.client.YKEdsFrame.main(YKEdsFrame.java:41)
Error 2 opening registry key HARDWARE\DEVICEMAP\SERIALCOMM
Error 2 opening registry key HARDWARE\DEVICEMAP\SERIALCOMM

0

O panie, web archive z 2008 pokazuje, że technologia ze stajni IBM o nazwie "bridge 2jave" trafiła do lamusa w 2001 roku :D
Z tego co pokazuje web archive, te technologia umożliwiała "A tool that allows Java programs to communicate with ActiveX objects." Targetem był wówczas Win95,98 oraz NT.

Możliwe, że DLL jest załadowany i próbuje dogrzebać się w rejestrze do kluczy "HARDWARE\DEVICEMAP\SERIALCOMM". Nie wiem jak wyglądała struktura rejestru Windowsa w 2001 roku, ale dziś DEVICEMAP jest pod "HKEY_LOCAL_MACHINE\HARDWARE\DEVICEMAP"

screenshot-20220426190501.png

https://web.archive.org/web/20080513073212/http://www.alphaworks.ibm.com/tech/bridge2java

0

@yarel: Zaladowalem jeszcze raz PATH i mam teraz minimalna zmiane i nie pojawia mi się to ponizej

Error 2 opening registry key HARDWARE\DEVICEMAP\SERIALCOMM
Error 2 opening registry key HARDWARE\DEVICEMAP\SERIALCOMM

1 użytkowników online, w tym zalogowanych: 0, gości: 1