Ошибка YAJSW с открытым статическим классом - PullRequest
0 голосов
/ 03 февраля 2012

У меня есть Java-приложение, которое я пытаюсь начать использовать YAJSW.Это просто приложение "Hello World", и я следую инструкциям здесь: http://yajsw.sourceforge.net/#mozTocId527639

Я сделал следующее:

  • экспортировал мой проект из затмения какисполняемый файл JAR.

  • Я запустил genconfig - без проблем

  • Я отредактировал файл wrapper.conf и добавил местоположение файла JAR

  • запустил runConsole.bat, и я получаю эту ошибку:

    java.lang.IllegalAccessException: класс org.rzo.yajsw.app.WrapperJVMMain не может получить доступ к членукласса xxxx с модификаторами "public static"

Класс, на который он ссылается, является основным классом, который должен быть public static.Я застрял!У кого-нибудь есть совет?

1 Ответ

2 голосов
/ 11 апреля 2012

У меня была такая же проблема, (запуск yajsw-stable-11.0 на Java 1.6.0_30-b12, Win XP Pro v 2002 SP3):

INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|init 
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|ahessian jmx service bound to port 15002
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|set state IDLE->STARTING
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|Win service: before service init
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|starting Process
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|Controller State: UNKNOWN -> WAITING
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|+ ServiceMain callback
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|reporting status 0
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|reporting status 0
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|onstart
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|working dir C:\dev\workspaceTax\socket-proxy
INFO|wrapper|Service socket-proxy|12-04-11 11:48:32|create script: scripts/trayMessage.gv
INFO|wrapper|Service socket-proxy|12-04-11 11:48:33|found script scripts/trayMessage.gv
INFO|wrapper|Service socket-proxy|12-04-11 11:48:33|spawning wrapped process
INFO|wrapper|Service socket-proxy|12-04-11 11:48:33|started process with pid 3720
INFO|wrapper|Service socket-proxy|12-04-11 11:48:33|waiting for termination of process
INFO|wrapper|Service socket-proxy|12-04-11 11:48:33|set state STARTING->RUNNING
INFO|3720/0|Service socket-proxy|12-04-11 11:48:33|[INFO] DefaultFileReplicator - Using "C:\WINDOWS\TEMP\vfs_cache" as temporary files store.
INFO|3720/0|Service socket-proxy|12-04-11 11:48:33|java.lang.IllegalAccessException: Class org.rzo.yajsw.app.WrapperJVMMain can not access a member of class [...].socketproxy.Proxy with modifiers "public static"
INFO|wrapper|Service socket-proxy|12-04-11 11:48:33|Trigger found: Exception
INFO|3720/0|Service socket-proxy|12-04-11 11:48:33| at sun.reflect.Reflection.ensureMemberAccess(Unknown Source)
INFO|wrapper|Service socket-proxy|12-04-11 11:48:33|start script scripts/trayMessage.gv
INFO|3720/0|Service socket-proxy|12-04-11 11:48:33| at java.lang.reflect.Method.invoke(Unknown Source)
INFO|3720/0|Service socket-proxy|12-04-11 11:48:33| at org.rzo.yajsw.app.WrapperJVMMain.executeMain(WrapperJVMMain.java:53)
INFO|3720/0|Service socket-proxy|12-04-11 11:48:33| at org.rzo.yajsw.app.WrapperJVMMain.main(WrapperJVMMain.java:36)
INFO|wrapper|Service socket-proxy|12-04-11 11:48:33|end script scripts/trayMessage.gv
INFO|3720/0|Service socket-proxy|12-04-11 11:48:34|process terminated
INFO|3720/0|Service socket-proxy|12-04-11 11:48:34|Controller State: WAITING -> PROCESS_KILLED
INFO|wrapper|Service socket-proxy|12-04-11 11:48:34|restart process due to default exit code rule

В моем случае класс, содержащий статические publicМетод main не был объявлен как public, поэтому он был закрытым по умолчанию, что является значением по умолчанию.

class Proxy {
...
    public static void main(String args[]) throws IOException{
        ...
        }
}

Открытые методы закрытых классов пакета не видны классам, принадлежащим другому пакету, поэтому проблема заключалась вмое дело.См., Например, https://stackoverflow.com/questions/5260467/public-methods-in-package-private-classes.

public class Proxy {
...
    public static void main(String args[]) throws IOException{
        ...
        }
}

Объявление класса public, как указано выше, решило проблему для меня.Может быть, вы могли бы опубликовать более подробную информацию о всей проблеме, и кто-то опубликует решение.С уважением -GF

...