Commit d307438b authored by neo.wang's avatar neo.wang

Merge branch 'dev_neo' of 10.157.107.88:root/atms into dev_neo_ftp

parents ea74a6a8 5c5a94bb
...@@ -6,11 +6,16 @@ import org.apache.commons.pool2.impl.GenericObjectPool; ...@@ -6,11 +6,16 @@ import org.apache.commons.pool2.impl.GenericObjectPool;
import org.apache.commons.pool2.impl.GenericObjectPoolConfig; import org.apache.commons.pool2.impl.GenericObjectPoolConfig;
import org.springframework.beans.factory.annotation.Value; import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import pwc.taxtech.atms.exception.ServiceException;
import javax.annotation.PostConstruct; import javax.annotation.PostConstruct;
import java.io.BufferedOutputStream;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.OutputStream;
@Component @Component
public class FTPClientPool { public class FTPClientPool {
...@@ -39,9 +44,14 @@ public class FTPClientPool { ...@@ -39,9 +44,14 @@ public class FTPClientPool {
clientConfig.setPassword(ftpPwd); clientConfig.setPassword(ftpPwd);
ftpClientConfig = clientConfig; ftpClientConfig = clientConfig;
pool = new GenericObjectPool<>(new FtpClientFactory(clientConfig), config); pool = new GenericObjectPool<>(new FtpClientFactory(clientConfig), config);
Runtime.getRuntime().addShutdownHook(new Thread(() -> {
pool.close();
}));
ftpRootPath = pool.borrowObject().printWorkingDirectory(); ftpRootPath = pool.borrowObject().printWorkingDirectory();
} }
// this method should only be used in test
public FTPClient getClient() throws Exception { public FTPClient getClient() throws Exception {
return pool.borrowObject(); return pool.borrowObject();
} }
...@@ -56,7 +66,7 @@ public class FTPClientPool { ...@@ -56,7 +66,7 @@ public class FTPClientPool {
*/ */
public void upload(String filePath, String fileName, InputStream inputStream) throws Exception { public void upload(String filePath, String fileName, InputStream inputStream) throws Exception {
String upPath; String upPath;
FTPClient client = getClient(); FTPClient client = pool.borrowObject();
try { try {
if (StringUtils.isBlank(filePath)) { if (StringUtils.isBlank(filePath)) {
upPath = ftpRootPath; upPath = ftpRootPath;
...@@ -83,12 +93,18 @@ public class FTPClientPool { ...@@ -83,12 +93,18 @@ public class FTPClientPool {
* @throws Exception Exception * @throws Exception Exception
*/ */
public InputStream download(String filePath) throws Exception { public InputStream download(String filePath) throws Exception {
FTPClient client = getClient(); FTPClient client = pool.borrowObject();
try { if (StringUtils.isBlank(filePath)) throw new ServiceException("file path should not empty");
client.changeWorkingDirectory(ftpRootPath); client.changeWorkingDirectory(ftpRootPath);
return StringUtils.isBlank(filePath) ? null : client.retrieveFileStream(filePath); try (InputStream in = client.retrieveFileStream(filePath); OutputStream out = new ByteArrayOutputStream();){
int len = 0;
byte[] bytes = new byte[1024];
while ((len = in.read(bytes)) != -1) {
out.write(bytes, 0, len);
}
return new ByteArrayInputStream(((ByteArrayOutputStream) out).toByteArray());
} finally { } finally {
//pool.returnObject(client); pool.returnObject(client);
} }
} }
...@@ -131,7 +147,7 @@ public class FTPClientPool { ...@@ -131,7 +147,7 @@ public class FTPClientPool {
if (StringUtils.isBlank(filePath)) { if (StringUtils.isBlank(filePath)) {
return; return;
} }
FTPClient client = getClient(); FTPClient client = pool.borrowObject();
try { try {
if (!isExist(filePath, client)) { if (!isExist(filePath, client)) {
return; return;
......
...@@ -21,20 +21,18 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> { ...@@ -21,20 +21,18 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> {
this.config = config; this.config = config;
} }
@Override @Override
public PooledObject<FTPClient> makeObject() throws Exception { public PooledObject<FTPClient> makeObject() throws Exception {
FTPClient ftpClient = new FTPClient(); FTPClient ftpClient = new FTPClient();
if (null != config.getClientTimeout()) { if (null != config.getClientTimeout()) {
ftpClient.setConnectTimeout(config.getClientTimeout()); ftpClient.setConnectTimeout(config.getClientTimeout());
} }
try {
ftpClient.connect(config.getHost(), config.getPort()); ftpClient.connect(config.getHost(), config.getPort());
int reply = ftpClient.getReplyCode(); int reply = ftpClient.getReplyCode();
if (!FTPReply.isPositiveCompletion(reply)) { if (!FTPReply.isPositiveCompletion(reply)) {
ftpClient.disconnect(); ftpClient.disconnect();
logger.warn("FTPServer refused connection"); logger.warn("FTPServer refused connection");
return null; throw new ServiceException("FTPServer refused connection");
} }
boolean result = ftpClient.login(StringUtils.defaultString(config.getUsername()), boolean result = ftpClient.login(StringUtils.defaultString(config.getUsername()),
StringUtils.defaultString(config.getPassword())); StringUtils.defaultString(config.getPassword()));
...@@ -51,10 +49,10 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> { ...@@ -51,10 +49,10 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> {
// if (StringUtils.equals(config.getPassiveMode(), "true")) { // if (StringUtils.equals(config.getPassiveMode(), "true")) {
// ftpClient.enterLocalPassiveMode(); // ftpClient.enterLocalPassiveMode();
// } // }
} catch (Exception e) {
logger.error("create ftp client error", e); logger.debug("mk objec ftp client {}", ftpClient.toString());
}
return new DefaultPooledObject<>(ftpClient); return new DefaultPooledObject<>(ftpClient);
} }
@Override @Override
...@@ -62,12 +60,12 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> { ...@@ -62,12 +60,12 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> {
FTPClient ftpClient = pooledObject.getObject(); FTPClient ftpClient = pooledObject.getObject();
try { try {
if (ftpClient != null && ftpClient.isConnected()) { if (ftpClient != null && ftpClient.isConnected()) {
logger.debug("destroy ftp client {}", ftpClient.toString());
ftpClient.logout(); ftpClient.logout();
} }
} catch (IOException io) {
io.printStackTrace();
} finally { } finally {
try { try {
if (ftpClient != null && ftpClient.isConnected())
ftpClient.disconnect(); ftpClient.disconnect();
} catch (IOException io) { } catch (IOException io) {
io.printStackTrace(); io.printStackTrace();
...@@ -78,6 +76,7 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> { ...@@ -78,6 +76,7 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> {
@Override @Override
public boolean validateObject(PooledObject<FTPClient> pooledObject) { public boolean validateObject(PooledObject<FTPClient> pooledObject) {
try { try {
logger.debug("validate object ftp client {} ", pooledObject.getObject().toString());
return pooledObject.getObject().sendNoOp(); return pooledObject.getObject().sendNoOp();
} catch (IOException e) { } catch (IOException e) {
throw new RuntimeException("Failed to validate client: " + e, e); throw new RuntimeException("Failed to validate client: " + e, e);
...@@ -86,12 +85,12 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> { ...@@ -86,12 +85,12 @@ public class FtpClientFactory implements PooledObjectFactory<FTPClient> {
@Override @Override
public void activateObject(PooledObject<FTPClient> pooledObject) throws Exception { public void activateObject(PooledObject<FTPClient> pooledObject) throws Exception {
logger.debug("activateObject {}", pooledObject.getObject().toString());
} }
@Override @Override
public void passivateObject(PooledObject<FTPClient> pooledObject) throws Exception { public void passivateObject(PooledObject<FTPClient> pooledObject) throws Exception {
logger.debug("passivateObject {}", pooledObject.getObject().toString());
} }
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment