|
|
@@ -1,11 +1,9 @@
|
|
|
package com.uas.service.Impl;
|
|
|
|
|
|
-import com.jcraft.jsch.JSchException;
|
|
|
import com.uas.service.DownloadService;
|
|
|
import com.uas.util.BaseUtil;
|
|
|
import com.uas.util.FtpUtil;
|
|
|
import com.uas.util.JdbcUtil;
|
|
|
-import com.uas.util.SFTPUtil;
|
|
|
import org.apache.commons.net.ftp.FTPClient;
|
|
|
import org.codehaus.jackson.map.ObjectMapper;
|
|
|
import org.dom4j.Document;
|
|
|
@@ -32,24 +30,8 @@ public class DownloadServiceImpl implements DownloadService {
|
|
|
|
|
|
@Override
|
|
|
public void downloadRun(){
|
|
|
- //联合创泰-富森
|
|
|
- downloadByDepotAndSob("N_YITOA_LHCT-FS","N_YITOA_LHCT","聯合創泰科技有限公司");
|
|
|
- //联合创泰-顺丰
|
|
|
- downloadByDepotAndSob("N_YITOA_LHCT-SF","N_YITOA_LHCT","聯合創泰科技有限公司");
|
|
|
//联合创泰-准时达
|
|
|
- downloadByDepotAndSob("N_YITOA_LHCT-ZSD","N_YITOA_LHCT","聯合創泰科技有限公司");
|
|
|
- //联合创泰-SLC上海保税仓
|
|
|
- downloadByDepotAndSob("N_YITOA_LHCT-SLC","N_YITOA_LHCT","聯合創泰科技有限公司");
|
|
|
- //联合创泰-中芯
|
|
|
- //downloadByDepotAndSob("N_YITOA_LHCT-ZX","N_YITOA_LHCT","聯合創泰科技有限公司");
|
|
|
- //联合创泰-泓明
|
|
|
- downloadByDepotAndSob("N_YITOA_LHCT-HM","N_YITOA_LHCT","聯合創泰科技有限公司");
|
|
|
- //英唐创泰香港-富森
|
|
|
- downloadByDepotAndSob("N_YITOA_LHCT_HK-FS","N_YITOA_LHCT_HK","英唐創泰香港科技有限公司");
|
|
|
- //联合创泰电子-准时达
|
|
|
- downloadByDepotAndSob("LHCT_SZ-ZSD","LHCT_SZ","联合创泰(深圳)电子有限公司");
|
|
|
- //供应链测试-顺丰
|
|
|
- downloadByDepotAndSob("N_YITOA_LHCT_T-SF","N_YITOA_LHCT_T","聯合創泰科技有限公司");
|
|
|
+ downloadByDepotAndSob("BSD_HK-ZSD","BSD_HK","Upstar Technology (HK) Limited");
|
|
|
|
|
|
|
|
|
}
|
|
|
@@ -60,37 +42,15 @@ public class DownloadServiceImpl implements DownloadService {
|
|
|
public void downloadByDepotAndSob(String depot,String sob,String enterprise){
|
|
|
BaseUtil.getLogger().info("download xml" + " from "+depot);
|
|
|
FTPClient client = null;
|
|
|
- SFTPUtil sftp = null;
|
|
|
List<String> sqls = new ArrayList<String>();
|
|
|
boolean executeRes = false;
|
|
|
Connection connect = null;
|
|
|
-
|
|
|
try {
|
|
|
Map<String,Object> servMap = JdbcUtil.getFtpConfigs();
|
|
|
Map<String,Object> ftpMap = (Map<String,Object>)servMap.get(depot);
|
|
|
- if ("N_YITOA_LHCT-SF".equals(depot)||"N_YITOA_LHCT_T-SF".equals(depot)){
|
|
|
- sftp = new SFTPUtil(ftpMap.get("user").toString(),ftpMap.get("password").toString(),
|
|
|
- ftpMap.get("ip").toString(),
|
|
|
- Integer.parseInt(ftpMap.get("port").toString()));
|
|
|
- try {
|
|
|
- sftp.login();
|
|
|
- } catch (JSchException e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
- }else {
|
|
|
- client = FtpUtil.connect(ftpMap);
|
|
|
- }
|
|
|
- if(client!=null||sftp!=null) {
|
|
|
- List<File> files = null;
|
|
|
- if ("N_YITOA_LHCT-SF".equals(depot)||"N_YITOA_LHCT_T-SF".equals(depot)) {
|
|
|
- files = sftp.download(ftpMap.get("downloadpath").toString());
|
|
|
-
|
|
|
- }else if("N_YITOA_LHCT-SLC".equals(depot)){
|
|
|
- files = FtpUtil.downloadDirFileByType(client, "XML",
|
|
|
- ftpMap.get("downloadpath").toString());
|
|
|
- }else{
|
|
|
- files = FtpUtil.downloadAllFileByType(client, "XML");
|
|
|
- }
|
|
|
+ client = FtpUtil.connect(ftpMap);
|
|
|
+ if(client!=null) {
|
|
|
+ List<File> files = FtpUtil.downloadAllFileByType(client, "XML");
|
|
|
String fileName = "";
|
|
|
if (files != null && files.size() > 0) {
|
|
|
connect = JdbcUtil.getConnectBySob(sob);
|
|
|
@@ -104,28 +64,18 @@ public class DownloadServiceImpl implements DownloadService {
|
|
|
}
|
|
|
Statement statement = connect.createStatement();
|
|
|
sqls = parseXmlFileToSqls(file, statement);
|
|
|
- String s = file.getName().substring(0, file.getName().indexOf(".")) + ".xml";
|
|
|
if (sqls == null) {
|
|
|
- sftp.rename(ftpMap.get("downloadpath").toString() + "/" + s, "goodsreceipt/backup/" + s);
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
executeRes = JdbcUtil.executeSqls(connect, sqls);
|
|
|
|
|
|
if (executeRes) {
|
|
|
- if ("N_YITOA_LHCT-SF".equals(depot)||"N_YITOA_LHCT_T-SF".equals(depot)) {
|
|
|
- Boolean rename = sftp.rename(ftpMap.get("downloadpath").toString() + "/" + s, "goodsreceipt/backup/" + s);
|
|
|
- } else {
|
|
|
- //移动处理完的文件到bak文件夹下
|
|
|
- client.rename(file.getName(), "bak/" + file.getName());
|
|
|
- }
|
|
|
+ //移动处理完的文件到bak文件夹下
|
|
|
+ client.rename(file.getName(), "/HKHub/UPSTAR/reply_bak/" + file.getName());
|
|
|
}else{
|
|
|
- if ("N_YITOA_LHCT-SF".equals(depot)||"N_YITOA_LHCT_T-SF".equals(depot)) {
|
|
|
- Boolean rename = sftp.rename(ftpMap.get("downloadpath").toString() + "/" + s, "goodsreceipt/backup/" + s);
|
|
|
- } else {
|
|
|
- //移动处理完的文件到failed文件夹下
|
|
|
- client.rename(file.getName(), "failed/" + file.getName());
|
|
|
- }
|
|
|
+ //移动处理完的文件到failed文件夹下
|
|
|
+ client.rename(file.getName(), "/HKHub/UPSTAR/erro_reply/" + file.getName());
|
|
|
}
|
|
|
statement.close();
|
|
|
} catch (Exception e) {
|
|
|
@@ -149,9 +99,6 @@ public class DownloadServiceImpl implements DownloadService {
|
|
|
FtpUtil.closeFtpClient(client);
|
|
|
client = null;
|
|
|
}
|
|
|
- if (sftp!=null){
|
|
|
- sftp.logout();
|
|
|
- }
|
|
|
//把当前的连接关闭
|
|
|
try {
|
|
|
if(connect!=null){
|