IntelliJ 13.1.3 を実行しています。新しいプロジェクトを作成し、RESTful Web サービス (2.2) をチェックし、サーバー コード サンプルの生成のボックスをチェックして、[次へ] をクリックし、プロジェクト名を入力して、[完了] をクリックします。
これで、コード付きのサンプル プロジェクトができました。私は何も変更しておらず、これまでのところすべて自動的に生成されているので、実行するだけで機能するはずです。
悲しいことに、これは失敗します。IntelliJ は、特にサンプル コードが使用する HttpServerFactory クラスから何かをインポートする com.sun.jersey を見つけることができません。同じ問題と思われるこの質問を見つけたので、そこの指示に従ってください。これでうまくいき、プロジェクトがコンパイルされます。
それで、コンソール出力と、ブラウザで localhost にアクセスして「Hello World」を取得できることを期待して、実行を押しました。代わりに、例外でスタック トレースを取得します。コンソール出力は次のとおりです。
Jun 21, 2014 10:24:34 AM com.sun.jersey.api.core.ClasspathResourceConfig init
INFO: Scanning for root resource and provider classes in the paths:
D:\Program Files\Java\jdk1.8.0_05\jre\lib\charsets.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\deploy.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\javaws.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\jce.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\jfr.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\jfxswt.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\jsse.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\management-agent.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\plugin.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\resources.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\rt.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\access-bridge-64.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\cldrdata.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\dnsns.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\jaccess.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\jfxrt.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\localedata.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\nashorn.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\sunec.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\sunjce_provider.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\sunmscapi.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\sunpkcs11.jar
D:\Program Files\Java\jdk1.8.0_05\jre\lib\ext\zipfs.jar
D:\test\target\classes
D:\test\lib\jersey-container-servlet.jar
D:\test\lib\jersey-container-servlet-core.jar
D:\test\lib\jersey-client.jar
D:\test\lib\javax.ws.rs-api-2.0.jar
D:\test\lib\jersey-common.jar
D:\test\lib\jersey-server.jar
C:\Users\Douglas\.m2\repository\com\sun\jersey\jersey-server\1.18.1\jersey-server-1.18.1.jar
C:\Users\Douglas\.m2\repository\com\sun\jersey\jersey-core\1.18.1\jersey-core-1.18.1.jar
D:\Program Files\JetBrains\IntelliJ IDEA 13.1.3\lib\idea_rt.jar
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 39168
at jersey.repackaged.org.objectweb.asm.ClassReader.readClass(ClassReader.java:1976)
at jersey.repackaged.org.objectweb.asm.ClassReader.accept(ClassReader.java:464)
at jersey.repackaged.org.objectweb.asm.ClassReader.accept(ClassReader.java:420)
at com.sun.jersey.spi.scanning.AnnotationScannerListener.onProcess(AnnotationScannerListener.java:138)
at com.sun.jersey.core.spi.scanning.JarFileScanner.scan(JarFileScanner.java:97)
at com.sun.jersey.core.spi.scanning.JarFileScanner$1.f(JarFileScanner.java:74)
at com.sun.jersey.core.util.Closing.f(Closing.java:71)
at com.sun.jersey.core.spi.scanning.JarFileScanner.scan(JarFileScanner.java:71)
at com.sun.jersey.core.spi.scanning.FilesScanner.scan(FilesScanner.java:83)
at com.sun.jersey.core.spi.scanning.FilesScanner.scan(FilesScanner.java:74)
at com.sun.jersey.api.core.ScanningResourceConfig.init(ScanningResourceConfig.java:80)
at com.sun.jersey.api.core.ClasspathResourceConfig.init(ClasspathResourceConfig.java:119)
at com.sun.jersey.api.core.ClasspathResourceConfig.<init>(ClasspathResourceConfig.java:101)
at com.sun.jersey.api.container.ContainerFactory.createContainer(ContainerFactory.java:263)
at com.sun.jersey.api.container.ContainerFactory.createContainer(ContainerFactory.java:246)
at com.sun.jersey.api.container.httpserver.HttpServerFactory.create(HttpServerFactory.java:117)
at com.sun.jersey.api.container.httpserver.HttpServerFactory.create(HttpServerFactory.java:92)
at example.HelloWorld.main(HelloWorld.java:26)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:483)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:134)
Process finished with exit code 1
この問題について私が見つけたのは、この自己解決された投稿だけです。これは、注釈スキャンが失敗する原因となっている破損した Java クラスがどこかにあることを示唆していますが、プラットフォーム設定/SDK を確認しましたが、何も問題がないように見えます、とにかく完全に新規インストールで実行しています。
これを修正する方法、またはインポートを修正する必要がある理由についてのアイデアはありますか?