2012-04-08 2 views
1

일부 파일을 읽기 위해 일부 폴더를 사용해야하는 Java 애플릿이 있습니다. 폴더는 적절한 위치에 있으며 index.html (애플릿을 실행 함)과 동일한 디렉토리에 있습니다. 여기에 오류가 JApplet에 밖으로 뱉어 것입니다 : 당신이 볼 수 있듯이Java Applet의 파일 사용 권한 오류

java.lang.reflect.InvocationTargetException 
    at com.sun.deploy.util.DeployAWTUtil.invokeAndWait(DeployAWTUtil.java:116) 
    at sun.plugin2.applet.Plugin2Manager.runOnEDT(Plugin2Manager.java:3541) 
    at sun.plugin2.applet.Plugin2Manager.createApplet(Plugin2Manager.java:3072) 
    at sun.plugin2.applet.Plugin2Manager$AppletExecutionRunnable.run(Plugin2Manager.java:1497) 
    at java.lang.Thread.run(Thread.java:680) 
Caused by: java.security.AccessControlException: access denied (java.io.FilePermission ./results read) 
    at java.security.AccessControlContext.checkPermission(AccessControlContext.java:374) 
    at java.security.AccessController.checkPermission(AccessController.java:546) 
    at java.lang.SecurityManager.checkPermission(SecurityManager.java:532) 
    at java.lang.SecurityManager.checkRead(SecurityManager.java:871) 
    at java.io.File.list(File.java:971) 
    at java.io.File.listFiles(File.java:1129) 
    at WhoHasMore.JShellFrame.getDefaultResultsFileName(JShellFrame.java:453) 
    at WhoHasMore.JShellFrame.<init>(JShellFrame.java:28) 
    at WhoHasMore.<init>(WhoHasMore.java:23) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:513) 
    at java.lang.Class.newInstance0(Class.java:355) 
    at java.lang.Class.newInstance(Class.java:308) 
    at sun.plugin2.applet.Plugin2Manager$13.run(Plugin2Manager.java:3060) 
    at java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:199) 
    at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:677) 
    at java.awt.EventQueue.access$000(EventQueue.java:85) 
    at java.awt.EventQueue$1.run(EventQueue.java:638) 
    at java.awt.EventQueue$1.run(EventQueue.java:636) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87) 
    at java.awt.EventQueue.dispatchEvent(EventQueue.java:647) 
    at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:296) 
    at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:211) 
    at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:201) 
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:196) 
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:188) 
    at java.awt.EventDispatchThread.run(EventDispatchThread.java:122) 
Exception: java.lang.reflect.InvocationTargetException 

는 오류가 "결과"라는 폴더에서 읽을

Caused by: java.security.AccessControlException: access denied (java.io.FilePermission ./results read) 

왜 액세스가 거부에서 오는 것 같다? 이 문제를 어떻게 해결할 수 있습니까?

답변

1

사용하려는 방법 (java.io.File.listFiles)이 HTTP를 통해 작동하지 않습니다. 알려진 URL의 텍스트 파일에 파일 목록을 넣고 다운로드하거나 애플릿 jarfile의 일부로 만드는 것과 같은 다른 파일 나열 방법을 선택해야합니다.

0

"결과"라는 폴더에서 읽는 데 액세스가 거부되는 이유는 무엇입니까?

Java 샌드 박스가 애플릿이 사용자 시스템의 파일 시스템에 액세스하지 못하게합니다.

어떻게 수정합니까?

  • 서명 된 JAR를 작성하고
  • 는 인증서를 수락/당신의 JAR 파일을 사용자가 얻을 :

당신은 당신이해야합니다, 당신의 애플릿이 이런 종류의 일을 수행 할 수 있으려면 신뢰할 수있는 응용 프로그램으로

+0

어떻게하면됩니까? 이것에 필요한 코드는 무엇입니까? – CodeGuy

+0

정책 파일을 사용하여 수행 할 수 있습니까? 그렇다면 어떻게해야하고 파일 이름은 무엇이되어야합니까? 정책 파일은 어디에 위치합니까? – CodeGuy

+0

* "폴더는 적절한 위치에 있으며 index.html (애플릿을 실행 함)과 동일한 디렉토리에 있습니다."* 이것은 클라이언트 파일 시스템이 아니라 서버입니다. @ duskwuff는 올바른 접근 방식을 취했습니다. –