2011-06-25 25 views
0

Windows XP SP3でEclipse 3.6を使用してGWTアプリケーションを開発しています。アプリケーションは、サーバ上のグラフィックスを含むフォルダの内容をクライアントに表示する必要があります。また、グラフィックスフォルダは、Webコンテナ内ではなく、ハードディスク内の別の場所にあります。 Eclispeは、Jetty HTTPサーバーを使用してWebアプリケーションを実行します。 RemoteServiceServletで次のスニペットを使用して、ファイルへのアクセスをテストし、テキストファイルの内容を取得します。JettyのWebコンテナ以外のファイルにアクセスする

File inputFile = new File("C:\\mytext.txt"); 
FileReader fin = new FileReader(inputFile); 
char c[] = new char[(char)inputFile.length()]; 
int i; 
i = fin.read(c); 
s = new String(c); 

残念ながら私はエラーが発生し、コード(または設定ファイル)を修正するためにそれをどのように翻訳するかわかりません。

Initializing AppEngine server 
Unable to access http://appengine.google.com/api/updatecheck?runtime=java&release=1.5.1&timestamp=1308100600&api_versions=['1.0'] 
java.net.UnknownHostException: appengine.google.com 
    at java.net.PlainSocketImpl.connect(Unknown Source) 
    at java.net.SocksSocketImpl.connect(Unknown Source) 
    at java.net.Socket.connect(Unknown Source) 
    at java.net.Socket.connect(Unknown Source) 
    at sun.net.NetworkClient.doConnect(Unknown Source) 
    at sun.net.www.http.HttpClient.openServer(Unknown Source) 
    at sun.net.www.http.HttpClient.openServer(Unknown Source) 
    at sun.net.www.http.HttpClient.<init>(Unknown Source) 
    at sun.net.www.http.HttpClient.New(Unknown Source) 
    at sun.net.www.http.HttpClient.New(Unknown Source) 
    at sun.net.www.protocol.http.HttpURLConnection.getNewHttpClient(Unknown Source) 
    at sun.net.www.protocol.http.HttpURLConnection.plainConnect(Unknown Source) 
    at sun.net.www.protocol.http.HttpURLConnection.connect(Unknown Source) 
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream(Unknown Source) 
    at java.net.URL.openStream(Unknown Source) 
    at com.google.appengine.tools.info.RemoteVersionFactory.getVersion(RemoteVersionFactory.java:76) 
    at com.google.appengine.tools.info.UpdateCheck.checkForUpdates(UpdateCheck.java:99) 
    at com.google.appengine.tools.info.UpdateCheck.doNagScreen(UpdateCheck.java:174) 
    at com.google.appengine.tools.info.UpdateCheck.maybePrintNagScreen(UpdateCheck.java:142) 
    at com.google.appengine.tools.development.gwt.AppEngineLauncher.maybePerformUpdateCheck(AppEngineLauncher.java:137) 
    at com.google.appengine.tools.development.gwt.AppEngineLauncher.start(AppEngineLauncher.java:103) 
    at com.google.gwt.dev.DevMode.doStartUpServer(DevMode.java:500) 
    at com.google.gwt.dev.DevModeBase.startUp(DevModeBase.java:1055) 
    at com.google.gwt.dev.DevModeBase.run(DevModeBase.java:804) 
    at com.google.gwt.dev.DevMode.main(DevMode.java:309) 
Logging to JettyLogger(null) via com.google.apphosting.utils.jetty.JettyLogger 
Successfully processed C:\Documents and Settings\Giorgos\workspace\Zserver\war\WEB-INF/appengine-web.xml 
Successfully processed C:\Documents and Settings\Giorgos\workspace\Zserver\war\WEB-INF/web.xml 
The server is running at http://localhost:8888/ 
[ERROR] javax.servlet.ServletContext log: Exception while dispatching incoming RPC call 
com.google.gwt.user.server.rpc.UnexpectedException: Service method 'public abstract java.lang.String mytest.client.GreetingService.greetServer(java.lang.String) throws java.lang.IllegalArgumentException' threw an unexpected exception: java.security.AccessControlException: access denied (java.io.FilePermission C:\mytext.txt read) 
    at com.google.gwt.user.server.rpc.RPC.encodeResponseForFailure(RPC.java:385) 
    at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:588) 
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processCall(RemoteServiceServlet.java:208) 
    at com.google.gwt.user.server.rpc.RemoteServiceServlet.processPost(RemoteServiceServlet.java:248) 
    at com.google.gwt.user.server.rpc.AbstractRemoteServiceServlet.doPost(AbstractRemoteServiceServlet.java:62) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511) 
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1166) 
    at com.google.appengine.tools.development.HeaderVerificationFilter.doFilter(HeaderVerificationFilter.java:35) 
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
    at com.google.appengine.api.blobstore.dev.ServeBlobFilter.doFilter(ServeBlobFilter.java:58) 
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
    at com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:43) 
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
    at com.google.appengine.tools.development.StaticFileFilter.doFilter(StaticFileFilter.java:122) 
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
    at com.google.appengine.tools.development.BackendServersFilter.doFilter(BackendServersFilter.java:97) 
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1157) 
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:388) 
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) 
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182) 
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765) 
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:418) 
    at com.google.apphosting.utils.jetty.DevAppEngineWebAppContext.handle(DevAppEngineWebAppContext.java:70) 
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
    at com.google.appengine.tools.development.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:351) 
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
    at org.mortbay.jetty.Server.handle(Server.java:326) 
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542) 
    at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:938) 
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:755) 
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:218) 
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404) 
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:409) 
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582) 
Caused by: java.security.AccessControlException: access denied (java.io.FilePermission C:\mytext.txt read) 
    at java.security.AccessControlContext.checkPermission(Unknown Source) 
    at java.security.AccessController.checkPermission(Unknown Source) 
    at java.lang.SecurityManager.checkPermission(Unknown Source) 
    at com.google.appengine.tools.development.DevAppServerFactory$CustomSecurityManager.checkPermission(DevAppServerFactory.java:166) 
    at java.lang.SecurityManager.checkRead(Unknown Source) 
    at java.io.FileInputStream.<init>(Unknown Source) 
    at java.io.FileReader.<init>(Unknown Source) 
    at mytest.server.GreetingServiceImpl.greetServer(GreetingServiceImpl.java:34) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
    at java.lang.reflect.Method.invoke(Unknown Source) 
    at com.google.appengine.tools.development.agent.runtime.Runtime.invoke(Runtime.java:100) 
    at com.google.gwt.user.server.rpc.RPC.invokeAndEncodeResponse(RPC.java:569) 
    ... 34 more 

答えて

1

多くの無関係な問題があります:あなたの質問では、スタックトレースを考える

  1. では、Google App Engineのためのアプリケーションを開発しているようです。 GAEはファイルシステムへのアクセスを許可しないため、アクセス制御例外が発生します。
  2. テキストファイルはグラフィックファイルではありません。私はあなたがしようとしていることを理解していません。
  3. new char[(char)inputFile.length()];行が間違っています。なぜファイルの長さをcharにキャストしていますか?
  4. read methodは、すべてのファイルを一度に読み取ることを保証するものではありません。読み取った文字の数を返します。戻り値は無視しないでください。 the tutorial about IOを読んでください。
+0

:)私はこの分野の初心者です。 GAE用ではないWebアプリケーションを実行することは可能ですか?テキストファイルは、ファイルにアクセスできるかどうかを確認するためのテストに過ぎませんでした。テキストファイルをwarフォルダ内に置くと、ファイルにアクセスできますが、フォルダを作成してファイルを動的に追加する必要があるため、ファイルシステムにアクセスする必要があります。あなたはそれを達成するためにどこを見てほしいですか? –

+0

GWTのチュートリアルに従い、AppEngineでの使用/展開に関する部分は避けてください:http://code.google.com/intl/fr/webtoolkit/gettingstarted.html –

関連する問題