x11.8smb修复问题,相关方展示集团单位 #2
|
@ -4,7 +4,9 @@ import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.util.Vector;
|
import java.util.Vector;
|
||||||
|
|
||||||
|
import org.springframework.beans.factory.annotation.Configurable;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
import org.springframework.web.multipart.MultipartFile;
|
||||||
|
|
||||||
import com.jcraft.jsch.Channel;
|
import com.jcraft.jsch.Channel;
|
||||||
|
@ -15,18 +17,36 @@ import com.jcraft.jsch.Session;
|
||||||
import com.jcraft.jsch.SftpATTRS;
|
import com.jcraft.jsch.SftpATTRS;
|
||||||
import com.jcraft.jsch.SftpException;
|
import com.jcraft.jsch.SftpException;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
public class Smb {
|
public class Smb {
|
||||||
|
|
||||||
@Value("${smb.host}")
|
|
||||||
private static String host;
|
public static String host;
|
||||||
@Value("${smb.port}")
|
public static Integer port;
|
||||||
private static Integer port ;
|
public static String user;
|
||||||
@Value("${smb.user}")
|
public static String password;
|
||||||
private static String user;
|
public static String basePath;
|
||||||
@Value("${smb.password}")
|
|
||||||
private static String password;
|
@Value("${smb.host}")
|
||||||
@Value("${smb.basePath}")
|
public void setHostPath(String hostProperties){
|
||||||
private static String basePath;
|
host = hostProperties;
|
||||||
|
}
|
||||||
|
@Value("${smb.port}")
|
||||||
|
public void setPortPath(Integer portProperties){
|
||||||
|
port = portProperties;
|
||||||
|
}
|
||||||
|
@Value("${smb.user}")
|
||||||
|
public void setUserPath(String userProperties){
|
||||||
|
user = userProperties;
|
||||||
|
}
|
||||||
|
@Value("${smb.password}")
|
||||||
|
public void setPasswordPath(String passwordProperties){
|
||||||
|
password = passwordProperties;
|
||||||
|
}
|
||||||
|
@Value("${smb.basePath}")
|
||||||
|
public void setBasePath(String basePathProperties){
|
||||||
|
basePath = basePathProperties;
|
||||||
|
}
|
||||||
|
|
||||||
// private static String host = "39.103.224.166";
|
// private static String host = "39.103.224.166";
|
||||||
//
|
//
|
||||||
|
@ -47,221 +67,221 @@ public class Smb {
|
||||||
//
|
//
|
||||||
// private static String basePath = "/mnt/qask/file/";
|
// private static String basePath = "/mnt/qask/file/";
|
||||||
|
|
||||||
public static final String SMBBAES_PATH = basePath;
|
public static final String SMBBAES_PATH = basePath;
|
||||||
|
|
||||||
|
|
||||||
|
public static void sshSftp(MultipartFile file, String fileName, String path) throws Exception {
|
||||||
|
Session session = null;
|
||||||
|
Channel channel = null;
|
||||||
|
JSch jsch = new JSch();
|
||||||
|
if (port <= 0) {
|
||||||
|
// 连接服务器,采用默认端口
|
||||||
|
session = jsch.getSession(user, host);
|
||||||
|
} else {
|
||||||
|
// 采用指定的端口连接服务器
|
||||||
|
session = jsch.getSession(user, host, port);
|
||||||
|
}
|
||||||
|
|
||||||
public static void sshSftp(MultipartFile file, String fileName, String path) throws Exception {
|
// 如果服务器连接不上,则抛出异常
|
||||||
Session session = null;
|
if (session == null) {
|
||||||
Channel channel = null;
|
throw new Exception("session is null");
|
||||||
JSch jsch = new JSch();
|
}
|
||||||
if (port <= 0) {
|
// 设置登陆主机的密码
|
||||||
// 连接服务器,采用默认端口
|
session.setPassword(password);
|
||||||
session = jsch.getSession(user, host);
|
// 设置第一次登陆的时候提示,可选值:(ask | yes | no)
|
||||||
} else {
|
session.setConfig("StrictHostKeyChecking", "no");
|
||||||
// 采用指定的端口连接服务器
|
// 设置登陆超时时间
|
||||||
session = jsch.getSession(user, host, port);
|
session.connect(30000);
|
||||||
}
|
OutputStream outstream = null;
|
||||||
|
|
||||||
// 如果服务器连接不上,则抛出异常
|
try {
|
||||||
if (session == null) {
|
// 创建sftp通信通道
|
||||||
throw new Exception("session is null");
|
channel = (Channel) session.openChannel("sftp");
|
||||||
}
|
channel.connect(1000);
|
||||||
// 设置登陆主机的密码
|
ChannelSftp sftp = (ChannelSftp) channel;
|
||||||
session.setPassword(password);
|
// 进入服务器指定的文件夹
|
||||||
// 设置第一次登陆的时候提示,可选值:(ask | yes | no)
|
|
||||||
session.setConfig("StrictHostKeyChecking", "no");
|
|
||||||
// 设置登陆超时时间
|
|
||||||
session.connect(30000);
|
|
||||||
OutputStream outstream = null;
|
|
||||||
|
|
||||||
try {
|
|
||||||
// 创建sftp通信通道
|
|
||||||
channel = (Channel) session.openChannel("sftp");
|
|
||||||
channel.connect(1000);
|
|
||||||
ChannelSftp sftp = (ChannelSftp) channel;
|
|
||||||
// 进入服务器指定的文件夹
|
|
||||||
// File dir = new File(basePath+"/"+path);
|
// File dir = new File(basePath+"/"+path);
|
||||||
// dir.setWritable(true, false);
|
// dir.setWritable(true, false);
|
||||||
// if(!dir.exists()){
|
// if(!dir.exists()){
|
||||||
// dir.mkdirs();
|
// dir.mkdirs();
|
||||||
// }
|
// }
|
||||||
createDir(basePath + path, sftp);
|
createDir(basePath + path, sftp);
|
||||||
sftp.cd(basePath + path);
|
sftp.cd(basePath + path);
|
||||||
// 列出服务器指定的文件列表
|
// 列出服务器指定的文件列表
|
||||||
// Vector v = sftp.ls("*");
|
// Vector v = sftp.ls("*");
|
||||||
// for(int i=0;i<v.size();i++){
|
// for(int i=0;i<v.size();i++){
|
||||||
// System.out.println(v.get(i));
|
// System.out.println(v.get(i));
|
||||||
// }
|
// }
|
||||||
// 以下代码实现从本地上传一个文件到服务器,如果要实现下载,对换以下流就可以了
|
// 以下代码实现从本地上传一个文件到服务器,如果要实现下载,对换以下流就可以了
|
||||||
|
|
||||||
sftp.put(file.getInputStream(), fileName);
|
sftp.put(file.getInputStream(), fileName);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
} finally {
|
} finally {
|
||||||
// 关流操作
|
// 关流操作
|
||||||
if (outstream != null) {
|
if (outstream != null) {
|
||||||
outstream.flush();
|
outstream.flush();
|
||||||
outstream.close();
|
outstream.close();
|
||||||
}
|
}
|
||||||
if (session != null) {
|
if (session != null) {
|
||||||
session.disconnect();
|
session.disconnect();
|
||||||
}
|
}
|
||||||
if (channel != null) {
|
if (channel != null) {
|
||||||
channel.disconnect();
|
channel.disconnect();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void sshSftpForInput(InputStream fileI, String fileName, String path) throws Exception {
|
public static void sshSftpForInput(InputStream fileI, String fileName, String path) throws Exception {
|
||||||
Session session = null;
|
Session session = null;
|
||||||
Channel channel = null;
|
Channel channel = null;
|
||||||
JSch jsch = new JSch();
|
JSch jsch = new JSch();
|
||||||
if (port <= 0) {
|
if (port <= 0) {
|
||||||
// 连接服务器,采用默认端口
|
// 连接服务器,采用默认端口
|
||||||
session = jsch.getSession(user, host);
|
session = jsch.getSession(user, host);
|
||||||
} else {
|
} else {
|
||||||
// 采用指定的端口连接服务器
|
// 采用指定的端口连接服务器
|
||||||
session = jsch.getSession(user, host, port);
|
session = jsch.getSession(user, host, port);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 如果服务器连接不上,则抛出异常
|
// 如果服务器连接不上,则抛出异常
|
||||||
if (session == null) {
|
if (session == null) {
|
||||||
throw new Exception("session is null");
|
throw new Exception("session is null");
|
||||||
}
|
}
|
||||||
// 设置登陆主机的密码
|
// 设置登陆主机的密码
|
||||||
session.setPassword(password);
|
session.setPassword(password);
|
||||||
// 设置第一次登陆的时候提示,可选值:(ask | yes | no)
|
// 设置第一次登陆的时候提示,可选值:(ask | yes | no)
|
||||||
session.setConfig("StrictHostKeyChecking", "no");
|
session.setConfig("StrictHostKeyChecking", "no");
|
||||||
// 设置登陆超时时间
|
// 设置登陆超时时间
|
||||||
session.connect(30000);
|
session.connect(30000);
|
||||||
OutputStream outstream = null;
|
OutputStream outstream = null;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// 创建sftp通信通道
|
// 创建sftp通信通道
|
||||||
channel = (Channel) session.openChannel("sftp");
|
channel = (Channel) session.openChannel("sftp");
|
||||||
channel.connect(1000);
|
channel.connect(1000);
|
||||||
ChannelSftp sftp = (ChannelSftp) channel;
|
ChannelSftp sftp = (ChannelSftp) channel;
|
||||||
// 进入服务器指定的文件夹
|
// 进入服务器指定的文件夹
|
||||||
// File dir = new File(basePath+"/"+path);
|
// File dir = new File(basePath+"/"+path);
|
||||||
// dir.setWritable(true, false);
|
// dir.setWritable(true, false);
|
||||||
// if(!dir.exists()){
|
// if(!dir.exists()){
|
||||||
// dir.mkdirs();
|
// dir.mkdirs();
|
||||||
// }
|
// }
|
||||||
createDir(basePath + path, sftp);
|
createDir(basePath + path, sftp);
|
||||||
sftp.cd(basePath + path);
|
sftp.cd(basePath + path);
|
||||||
// 列出服务器指定的文件列表
|
// 列出服务器指定的文件列表
|
||||||
// Vector v = sftp.ls("*");
|
// Vector v = sftp.ls("*");
|
||||||
// for(int i=0;i<v.size();i++){
|
// for(int i=0;i<v.size();i++){
|
||||||
// System.out.println(v.get(i));
|
// System.out.println(v.get(i));
|
||||||
// }
|
// }
|
||||||
// 以下代码实现从本地上传一个文件到服务器,如果要实现下载,对换以下流就可以了
|
// 以下代码实现从本地上传一个文件到服务器,如果要实现下载,对换以下流就可以了
|
||||||
|
|
||||||
sftp.put(fileI, fileName);
|
sftp.put(fileI, fileName);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
} finally {
|
} finally {
|
||||||
// 关流操作
|
// 关流操作
|
||||||
if (outstream != null) {
|
if (outstream != null) {
|
||||||
outstream.flush();
|
outstream.flush();
|
||||||
outstream.close();
|
outstream.close();
|
||||||
}
|
}
|
||||||
if (session != null) {
|
if (session != null) {
|
||||||
session.disconnect();
|
session.disconnect();
|
||||||
}
|
}
|
||||||
if (channel != null) {
|
if (channel != null) {
|
||||||
channel.disconnect();
|
channel.disconnect();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void createDir(String createpath, ChannelSftp sftp) {
|
public static void createDir(String createpath, ChannelSftp sftp) {
|
||||||
try {
|
try {
|
||||||
if (isDirExist(createpath, sftp)) {
|
if (isDirExist(createpath, sftp)) {
|
||||||
sftp.cd(createpath);
|
sftp.cd(createpath);
|
||||||
}
|
}
|
||||||
String pathArry[] = createpath.split("/");
|
String pathArry[] = createpath.split("/");
|
||||||
StringBuffer filePath = new StringBuffer("/");
|
StringBuffer filePath = new StringBuffer("/");
|
||||||
for (String path : pathArry) {
|
for (String path : pathArry) {
|
||||||
if (path.equals("")) {
|
if (path.equals("")) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
filePath.append(path + "/");
|
filePath.append(path + "/");
|
||||||
if (isDirExist(filePath.toString(), sftp)) {
|
if (isDirExist(filePath.toString(), sftp)) {
|
||||||
sftp.cd(filePath.toString());
|
sftp.cd(filePath.toString());
|
||||||
} else {
|
} else {
|
||||||
// 建立目录
|
// 建立目录
|
||||||
sftp.mkdir(filePath.toString());
|
sftp.mkdir(filePath.toString());
|
||||||
// 进入并设置为当前目录
|
// 进入并设置为当前目录
|
||||||
sftp.cd(filePath.toString());
|
sftp.cd(filePath.toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sftp.cd(createpath);
|
sftp.cd(createpath);
|
||||||
} catch (SftpException e) {
|
} catch (SftpException e) {
|
||||||
// throw new SystemException("创建路径错误:" + createpath);
|
// throw new SystemException("创建路径错误:" + createpath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isDirExist(String directory, ChannelSftp sftp) {
|
public static boolean isDirExist(String directory, ChannelSftp sftp) {
|
||||||
boolean isDirExistFlag = false;
|
boolean isDirExistFlag = false;
|
||||||
try {
|
try {
|
||||||
SftpATTRS sftpATTRS = sftp.lstat(directory);
|
SftpATTRS sftpATTRS = sftp.lstat(directory);
|
||||||
isDirExistFlag = true;
|
isDirExistFlag = true;
|
||||||
return sftpATTRS.isDir();
|
return sftpATTRS.isDir();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
if (e.getMessage().toLowerCase().equals("no such file")) {
|
if (e.getMessage().toLowerCase().equals("no such file")) {
|
||||||
isDirExistFlag = false;
|
isDirExistFlag = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return isDirExistFlag;
|
return isDirExistFlag;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 删除文件
|
* 删除文件
|
||||||
*Rhidd
|
* Rhidd
|
||||||
* @throws SftpException
|
*
|
||||||
* @throws JSchException
|
* @throws SftpException
|
||||||
*/
|
* @throws JSchException
|
||||||
public static void deleteFile(String directoryFile) throws Exception {
|
*/
|
||||||
|
public static void deleteFile(String directoryFile) throws Exception {
|
||||||
|
|
||||||
Session session = null;
|
Session session = null;
|
||||||
JSch jsch = new JSch();
|
JSch jsch = new JSch();
|
||||||
if (port <= 0) {
|
if (port <= 0) {
|
||||||
// 连接服务器,采用默认端口
|
// 连接服务器,采用默认端口
|
||||||
session = jsch.getSession(user, host);
|
session = jsch.getSession(user, host);
|
||||||
} else {
|
} else {
|
||||||
// 采用指定的端口连接服务器
|
// 采用指定的端口连接服务器
|
||||||
session = jsch.getSession(user, host, port);
|
session = jsch.getSession(user, host, port);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 如果服务器连接不上,则抛出异常
|
// 如果服务器连接不上,则抛出异常
|
||||||
if (session == null) {
|
if (session == null) {
|
||||||
throw new Exception("session is null");
|
throw new Exception("session is null");
|
||||||
}
|
}
|
||||||
// 设置登陆主机的密码
|
// 设置登陆主机的密码
|
||||||
session.setPassword(password);
|
session.setPassword(password);
|
||||||
// 设置第一次登陆的时候提示,可选值:(ask | yes | no)
|
// 设置第一次登陆的时候提示,可选值:(ask | yes | no)
|
||||||
session.setConfig("StrictHostKeyChecking", "no");
|
session.setConfig("StrictHostKeyChecking", "no");
|
||||||
// 设置登陆超时时间
|
// 设置登陆超时时间
|
||||||
session.connect(30000);
|
session.connect(30000);
|
||||||
// 打开openChannel的sftp
|
// 打开openChannel的sftp
|
||||||
ChannelSftp channelSftp = (ChannelSftp) session.openChannel("sftp");
|
ChannelSftp channelSftp = (ChannelSftp) session.openChannel("sftp");
|
||||||
// 远程连接
|
// 远程连接
|
||||||
channelSftp.connect();
|
channelSftp.connect();
|
||||||
// 删除文件
|
// 删除文件
|
||||||
try {
|
try {
|
||||||
Vector<ChannelSftp.LsEntry> vector = channelSftp.ls(basePath + directoryFile);
|
Vector<ChannelSftp.LsEntry> vector = channelSftp.ls(basePath + directoryFile);
|
||||||
if (vector.size() == 1) { // 文件,直接删除
|
if (vector.size() == 1) { // 文件,直接删除
|
||||||
channelSftp.rm(basePath + directoryFile);
|
channelSftp.rm(basePath + directoryFile);
|
||||||
System.out.println("4、" + directoryFile + " 删除的文件.....");
|
System.out.println("4、" + directoryFile + " 删除的文件.....");
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
|
||||||
}
|
}
|
||||||
// 切断远程连接
|
// 切断远程连接
|
||||||
channelSftp.exit();
|
channelSftp.exit();
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -875,11 +875,11 @@
|
||||||
(select group_concat(chr.NAME) from BUS_HIDDENCHECK bh left join sys_user chr on chr.USER_ID=bh.USER_ID where bh.HIDDEN_ID=f.HIDDEN_ID ) CHECKNAME
|
(select group_concat(chr.NAME) from BUS_HIDDENCHECK bh left join sys_user chr on chr.USER_ID=bh.USER_ID where bh.HIDDEN_ID=f.HIDDEN_ID ) CHECKNAME
|
||||||
from
|
from
|
||||||
<include refid="tableName"></include> f
|
<include refid="tableName"></include> f
|
||||||
left join sys_user cr on cr.USER_ID = f.CREATOR
|
left join qa-gwj-prevention.`vi_user_all` cr on cr.USER_ID = f.CREATOR
|
||||||
left join sys_user re on re.USER_ID = f.RECTIFICATIONOR
|
left join qa-gwj-prevention.`vi_user_all` re on re.USER_ID = f.RECTIFICATIONOR
|
||||||
left join sys_user ch on ch.USER_ID = f.CHECKOR
|
left join qa-gwj-prevention.`vi_user_all` ch on ch.USER_ID = f.CHECKOR
|
||||||
left join sys_user rev on rev.USER_ID = f.REVIEWOR
|
left join qa-gwj-prevention.`vi_user_all` rev on rev.USER_ID = f.REVIEWOR
|
||||||
left join sys_user conUser on conUser.USER_ID = f.CONFIRM_USER
|
left join qa-gwj-prevention.`vi_user_all` conUser on conUser.USER_ID = f.CONFIRM_USER
|
||||||
left join oa_department crd on crd.DEPARTMENT_ID = f.HIDDENFINDDEPT
|
left join oa_department crd on crd.DEPARTMENT_ID = f.HIDDENFINDDEPT
|
||||||
left join oa_department red on red.DEPARTMENT_ID = f.RECTIFICATIONDEPT
|
left join oa_department red on red.DEPARTMENT_ID = f.RECTIFICATIONDEPT
|
||||||
left join oa_department chd on chd.DEPARTMENT_ID = f.CHECKDEPT
|
left join oa_department chd on chd.DEPARTMENT_ID = f.CHECKDEPT
|
||||||
|
|
|
@ -508,16 +508,18 @@
|
||||||
f.*
|
f.*
|
||||||
FROM
|
FROM
|
||||||
bus_hidden f
|
bus_hidden f
|
||||||
LEFT JOIN sys_user confirmUser on confirmUser.USER_ID = f.CONFIRM_USER <!-- 隐患确认人 -->
|
|
||||||
left join bus_hidden_user bhu on bhu.HIDDEN_ID = f.HIDDEN_ID
|
left join bus_hidden_user bhu on bhu.HIDDEN_ID = f.HIDDEN_ID
|
||||||
left join sys_user bhuUser on bhuUser.user_id = bhu.user_id
|
|
||||||
left join oa_department bhuUserDept on bhuUser.DEPARTMENT_ID = bhuUserDept.DEPARTMENT_ID
|
left join `qa-gwj-prevention`.vi_user_all zgUser on zgUser.user_id = f.RECTIFICATIONOR
|
||||||
|
LEFT JOIN `qa-gwj-prevention`.vi_user_all confirmUser on confirmUser.USER_ID = f.CONFIRM_USER <!-- 隐患确认人 -->
|
||||||
|
left join `qa-gwj-prevention`.vi_user_all bhuUser on bhuUser.user_id = bhu.user_id
|
||||||
|
left join `qa-gwj-prevention`.vi_department_all bhuUserDept on bhuUser.DEPARTMENT_ID = bhuUserDept.DEPARTMENT_ID
|
||||||
|
|
||||||
LEFT JOIN bus_hiddencheck hch on hch.HIDDEN_ID = f.HIDDEN_ID
|
LEFT JOIN bus_hiddencheck hch on hch.HIDDEN_ID = f.HIDDEN_ID
|
||||||
left join sys_dictionaries type1 on type1.bianma = f.HIDDENTYPE
|
left join sys_dictionaries type1 on type1.bianma = f.HIDDENTYPE
|
||||||
left join oa_department zgUserDept on zgUserDept.DEPARTMENT_ID = f.RECTIFICATIONDEPT
|
left join oa_department zgUserDept on zgUserDept.DEPARTMENT_ID = f.RECTIFICATIONDEPT
|
||||||
left join bus_hiddenregion hreg on hreg.HIDDENREGION_ID = f.HIDDENPART
|
left join bus_hiddenregion hreg on hreg.HIDDENREGION_ID = f.HIDDENPART
|
||||||
|
|
||||||
left join sys_user zgUser on zgUser.user_id = f.RECTIFICATIONOR
|
|
||||||
|
|
||||||
WHERE f.ISDELETE = '0'
|
WHERE f.ISDELETE = '0'
|
||||||
and f.STATE not in ('0','7','8','100','101','102')
|
and f.STATE not in ('0','7','8','100','101','102')
|
||||||
|
|
Loading…
Reference in New Issue