2009-10-12 3 views
0

애플릿은 SFTP 서버에서 파일을 다운로드합니다. JSch 라이브러리는 세션을 생성하고이를 사용하여 SFTP 서버에 연결하고 SFTP 채널을 생성 한 다음 해당 서버에서 해당 파일에 대한 GET 명령을 실행하는 데 사용됩니다. 애플릿이 서명되었습니다. 파일을 다운로드애플릿에서 JSch를 사용하여 SFTP 서버에 연결할 때 AccessControlException이 발생 함

코드 :

public static void prepareSession() throws JSchException { 

    try { 
    session = jsch.getSession(user,host,port); 
    session.setConfig("StrictHostKeyChecking", "no");   
     session.setPassword(password); 
    } catch (JSchException e) { 
    e.printStackTrace(); 
    throw new JSchException(e.getLocalizedMessage(),e); 
    } 
} 

public synchronized static void downloadFile() throws Exception { 
    ChannelSftp channelSFTP = null; 
    try { 
    if (!session.isConnected()) { 
    session.connect(); 
    } 
    Channel channel=session.openChannel("sftp"); 
     channel.connect(); 
     channelSFTP=(ChannelSftp)channel; 

     String destFile = SFTPImpl.destFolder + "/" + SFTPImpl.sourceFile + ".part"; 

     log.info("Downloading file: " + SFTPImpl.sourceFile + " -- START"); 
     channelSFTP.get(SFTPImpl.sourceFile,destFile,SFTPImpl.monitor,ChannelSftp.OVERWRITE);  

    } catch (JSchException e) { 
    log.error("Error occurred within library", e); 
    throw new JSchException(e.getMessage(),e); 
    } catch (SftpException e) { 
    log.error("Error occurred in SFTP communication. Error ID: " + e.id, e); 
    throw new SftpException(e.id,e.getMessage(),e); 
    } catch (Exception e) { 
    throw new Exception(e.getMessage(),e); 
    }finally { 
    if (channelSFTP != null && channelSFTP.isConnected()) { 
    channelSFTP.quit(); 
     channelSFTP.disconnect(); 
     session.disconnect(); 
    } 
    } 
} 

애플릿은 자바 배포 도구 키트를 사용하여 배포됩니다. 애플릿 배포에 대한 HTML 페이지 코드는 다음과 같습니다

<script src="http://www.java.com/js/deployJava.js"></script> 
    <script> 
    var attributes = {code:'com.sftptest.applet.SFTPApplet', archive:'signedsftp.jar,jsch.jar,log4j-1.2.15.jar', width:400, height:400} ; 
     var parameters = {jnlp_href: 'sftpdownload-applet.jnlp'} ; 
     deployJava.runApplet(attributes, parameters, '1.6'); 
    </script> 

sftpdownload-applet.jnlp 파일 :

<?xml version="1.0" encoding="UTF-8"?> 
<jnlp spec="1.0+" codebase="" href=""> 
    <information> 
     <title>SFTP Downloader</title> 
     <vendor>local</vendor> 
    </information> 
    <resources> 
     <!-- Application Resources --> 
     <j2se version="1.6+" 
       href="http://java.sun.com/products/autodl/j2se" /> 
     <jar href="signedsftpsftp.jar" main="true" /> 
     <jar href="jsch.jar" /> 
     <jar href="log4j-1.2.15.jar" /> 
    </resources> 
    <applet-desc 
     name="SFTP Downloader Applet" 
     main-class="com.sftptest.applet.SFTPApplet" 
     width="400" 
     height="400"> 
    </applet-desc> 
    <update check="background"/> 
</jnlp> 

애플릿이 다운로드 위치를 선택하는 데 사용되는 파일 츄가 포함되어 있습니다. 다운로드 위치를 선택하자 마자 애플릿이 파일 다운로드를 시작해야합니다. 그러나 잠시 후 다음과 같은 오류가 콘솔에오고있다 : 예외 로그에서

[Oct 12 20:39:16] ERROR (SFTPImpl.java:130) - Error occurred within library 
com.jcraft.jsch.JSchException: java.security.AccessControlException: access denied (java.net.SocketPermission sftpcal.cognizant.com resolve) 
at com.jcraft.jsch.Util.createSocket(Util.java:341) 
at com.jcraft.jsch.Session.connect(Session.java:182) 
at com.jcraft.jsch.Session.connect(Session.java:150) 
at com.sftptest.SFTPImpl.downloadFile(SFTPImpl.java:111) 
at com.sftptest.ui.DownloadPanel$DownloadTask.doInBackground(DownloadPanel.java:316) 
at com.sftptest.ui.DownloadPanel$DownloadTask.doInBackground(DownloadPanel.java:1) 
at javax.swing.SwingWorker$1.call(SwingWorker.java:278) 
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303) 
at java.util.concurrent.FutureTask.run(FutureTask.java:138) 
at javax.swing.SwingWorker.run(SwingWorker.java:317) 
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) 
at java.lang.Thread.run(Thread.java:637) 

나는 예외가 JSch 프레임 워크의 Util.createSocket() 방법에서 오는 것을 보았다 :

static Socket createSocket(String host, int port, int timeout) throws JSchException{ 
    Socket socket=null; 
    if(timeout==0){ 
     try{ 
     socket=new Socket(host, port); 
     return socket; 
     } 
     catch(Exception e){ 
     String message=e.toString(); 
     if(e instanceof Throwable) 
      throw new JSchException(message, (Throwable)e); 
     throw new JSchException(message); 
     } 
    } 

이 &이 알려 도와주세요 더 많은 정보가 필요한 경우.

답변

2

예, 애플릿에 서명했으나 jnlp에서 소켓 생성 권한을 요청하는 것을 잊었습니다.

<security> 
    <j2ee-application-client-permissions/> 
</security> 
+0

나는 두려워서 같은 오류가 발생했습니다. 내가 말했듯이 jnlp 파일을 변경하고 애플릿을 해고했다. 다른 일을해야합니까? – kaychaks

+0

흠. ' '대신''를 포함하면 어떻게됩니까? ** 그 **가 작동하지 않으면, 당신은 제대로 배포하지 않았습니다. –

+0

또한 jsch.jar에 서명해야하는지 궁금합니다. –

관련 문제