JSocket을 사용하여 SFTP를 통해 메인 프레임에 파일을 저장하려고합니다.JSch SFTP에서 IBM z/OS로 전송 실패 : 파일을 쓰지 못했습니다. 중첩 예외는 3입니다. 사용 권한이 거부되었습니다.
session = jsch.getSession(username, host, port);
Properties config = getProperties(host, port);
session.setConfig(config);
...
...
protected Properties getProperties(String host, int port) throws JSchException {
Properties config = new Properties();
config.put("StrictHostKeyChecking", strictHostChecking ? "yes" : "no");
config.put("kex", "diffie-hellman-group-exchange-sha1");
config.put("PreferredAuthentications", "password");
return config;
}
세션 연결 괜찮 :
다음public void uploadFile(String contents) throws Exception {
JSch.setLogger(new JSCHLogger());
connectIfDisconected();
LOGGER.info("Channel isConnected=: " + channel.isConnected());
OutputStream os = channel.put("//!DTS4.UP.G5TB4.S60301");
os.write(contents.getBytes());
os.flush();
os.close();
}
protected void connectIfDisconected() throws JSchException {
if (!session.isConnected()) {
LOGGER.info(LogEvent.create(".connectIfDisconected()", "Reconnecting session and channel..."));
session.connect();
if (channel != null) {
channel.exit();
}
channel = (ChannelSftp) session.openChannel("sftp");
} else if (!channel.isConnected()) {
LOGGER.info(LogEvent.create(".connectIfDisconected()", "Reconnecting channel..."));
channel.connect();
}
}
세션 구성입니다 : 여기
코드입니다! 내가 터미널 모두를 사용하여 동일한 시도하고 언제com.three60t.tex.app.exceptions.business.BusinessException: Error while delivering to Client communicator : Permission denied
at com.three60t.integration.posttrade.utils.DefaultReporter.reportError(DefaultReporter.java:68)
at com.three60t.integration.posttrade.transformationService.InternalTransformationService.reportError(InternalTransformationService.java:439)
at com.three60t.integration.posttrade.transformationService.InternalTransformationService.deliver(InternalTransformationService.java:378)
at com.three60t.integration.posttrade.transformationService.InternalTransformationService.doDeliver(InternalTransformationService.java:314)
at com.three60t.integration.posttrade.transformationService.InternalTransformationService.transform(InternalTransformationService.java:305)
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:497)
at com.three60t.tex.communication.message.handler.MessageDispatcher.dispatchToObject(MessageDispatcher.java:722)
at com.three60t.tex.communication.message.handler.MessageDispatcher.doExecuteObject(MessageDispatcher.java:543)
at com.three60t.tex.communication.message.handler.MessageDispatcher.access$200(MessageDispatcher.java:77)
at com.three60t.tex.communication.message.handler.MessageDispatcher$1.run(MessageDispatcher.java:264)
at com.three60t.tex.communication.message.handler.MessageDispatcher$3.run(MessageDispatcher.java:444)
at com.three60t.concurrent.executor.v2.RunnableWithTimings.run(RunnableWithTimings.java:81)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
Caused by: 3: Permission denied
at com.jcraft.jsch.ChannelSftp.throwStatusError(ChannelSftp.java:2846)
at com.jcraft.jsch.ChannelSftp.put(ChannelSftp.java:753)
at com.jcraft.jsch.ChannelSftp.put(ChannelSftp.java:700)
at com.jcraft.jsch.ChannelSftp.put(ChannelSftp.java:694)
at com.three60t.integration.tradeimporters.sftp.DtccSftpClient.uploadFile(DtccSftpClient.java:34)
at com.three60t.integration.tradeimporters.sftp.SFTPTransportDtcc.upload(SFTPTransportDtcc.java:41)
at com.three60t.framework.communication.integration.SFTPTransport.upload(SFTPTransport.java:148)
at com.three60t.integration.tradeimporters.sftp.SFTPTransportDtcc.upload(SFTPTransportDtcc.java:25)
at com.three60t.integration.tradeimporters.sftp.SFTPTransportDtcc.deliver(SFTPTransportDtcc.java:55)
at com.three60t.integration.posttrade.transformationService.InternalTransformationService.deliver(InternalTransformationService.java:362)
... 15 more
라인
OutputStream os = channel.put(targetFile);
에 다음과 같은 예외를 받고 있어요 파일을 넣어 시도하고 있지만
잘 작동합니다!
sftp [email protected]
Connecting to fdmoverspse.dtcc.com...
[email protected]'s password:
sftp> put myfile.xml //!DTS4.UP.G5TB4.S60301
Uploading myfile.xml to //!DTS4.UP.G5TB4.S60301
myfile.xml 100% 7901 7.7KB/s 00:00
sftp>
수정 방법은 무엇입니까?
"어떻게 터미널을 사용하여 동일하게"하고 있습니까? 우리에게 보여줘! –
연결하려는 LPAR에 대한 z/OS syslog에 보안 관련 메시지가 있습니까? – cschneid
그리고 ChannelSftp에는 무엇이 있습니까? "잘 연결되었습니다!"라는 말의 근거는 무엇입니까? –