} catch (JSchException e) {
LOG.info(“get Channel failed!”, e);
}
return session;
}
/**
-
创建文件夹
-
@param sftp
-
@param dir
-
文件夹名称
*/
public void mkdir(ChannelSftp sftp, String dir) {
try {
sftp.mkdir(dir);
System.out.println(“创建文件夹成功!”);
} catch (SftpException e) {
System.out.println(“创建文件夹失败!”);
e.printStackTrace();
}
}
/**
-
@param sftp
-
@param dir
-
上传目录
-
@param file
-
上传文件
-
@return
*/
public Boolean uploadFile(ChannelSftp sftp, String dir, InputStream file,String fileName) {
Boolean flag = false;
try {
sftp.cd(dir);
if (file != null) {
sftp.put(file, fileName);
flag=true;
return flag;
} else {
flag=false;
return flag;
}
} catch (Exception e) {
flag=false;
return flag;
}
}
/**
-
下载文件
-
@param directory
-
下载目录
-
@param downloadFile
-
下载的文件
-
@param saveFile
-
存在本地的路径
-
@param sftp
*/
public String download(String directory, String downloadFile,
String saveFile, ChannelSftp sftp) {
String result = “”;
try {
sftp.cd(directory);
sftp.get(downloadFile, saveFile);
result = “下载成功!”;
} catch (Exception e) {
result = “下载失败!”;
LOG.info(“下载失败!”, e);
;
}
return result;
}
/**
-
删除文件
-
@param directory
-
要删除文件所在目录
-
@param deleteFile
-
要删除的文件
-
@param sftp
*/
public String delete(String directory, String deleteFile, ChannelSftp sftp) {
String result = “”;
try {
sftp.cd(directory);
sftp.rm(deleteFile);
result = “删除成功!”;
} catch (Exception e) {
result = “删除失败!”;
LOG.info(“删除失败!”, e);
}
return result;
}
private void closeChannel(Channel channel) {
if (channel != null) {
if (channel.isConnected()) {
channel.disconnect();
}
}
}
private void closeSession(Session session) {
if (session != null) {
if (session.isConnected()) {
session.disconnect();
}
}
}
public void closeAll(ChannelSftp sftp, Channel channel, Session session) {
try {
closeChannel(sftp);
closeChannel(channel);
closeSession(session);
} catch (Exception e) {
LOG.info(“closeAll”, e);
}
}
}
工具类不需要修改直接使用即可。
还有一个随机生成文件名称的工具类也发给大家
import java.util.Random;
public class IDUtils {
/**
- 生成随机图片名
*/
public static String genImageName() {
//取当前时间的长整形值包含毫秒
long millis = System.currentTimeMillis();
//加上三位随机数
Random random = new Random();
int end3 = random.nextInt(999);
//如果不足三位前面补0
String str = millis + String.format(“%03d”, end3);
return str;
}
}
六,后台请求方法看看
============
博主这里用了 Clipboard 上传,参数不支持序列化所以就一个个接受了,很多@RequestParam(“file”) MultipartFile file,加其他参数加上是post请求方式有的会报错把post请求方法找不到,这个问题不影响。
@Log(“网站案例上传信息”)
@ResponseBody
@PostMapping(“/upload”)
@RequiresPermissions(“common:cases:upload”)
R upload(@RequestParam(“file”) MultipartFile file,@RequestParam(“ctitle”) String ctitle, @RequestParam(“cmessage”) String cmessage,
@RequestParam(“casetroduction”) String casetroduction,@RequestParam(“strdate”) Date strdate,@RequestParam(“stpdate”) Date stpdate,
@RequestParam(“credate”) Date credate,HttpServletRequest request) throws ParseException, IOException {
String oldName = file.getOriginalFilename();
//使用IDUtils工具类生成新的文件名,新文件名 = newName + 文件后缀
String newName = IDUtils.genImageName();
newName = newName + oldName.substring(oldName.lastIndexOf(“.”));
SftpUtils ft = new SftpUtils();
//通过SFtoInfo 参数连接传入参数即可
Session s = ft.getSession(SFTPInfo.SFTP_REQ_HOST,SFTPInfo.SFTP_DEFAULT_PORT, SFTPInfo.SFTP_REQ_USERNAME,SFTPInfo.SFTP_REQ_PASSWORD);
Channel channel = ft.getChannel(s);
ChannelSftp sftp = (ChannelSftp)channel;
Boolean upload = ft.uploadFile(sftp,SFTPInfo.basePath, file.getInputStream(),newName);
if(upload){
//上传成功关闭信息
ft.closeAll(sftp, channel, s); //关闭连接
CasesDO cases=new CasesDO();
cases.setCtitle(ctitle);
// 这里很重要 这是访问路径写入到数据库的路径加线上域名访问图片的路径,博主这里加了ssl证书
// https://..com/images newName=文件名图片
cases.setCaseimg(SFTPInfo.baseUrl + “/” + newName);
cases.setCasetroduction(casetroduction);
cases.setStpdate(stpdate);
cases.setCredate(credate);
cases.setStrdate(strdate);
cases.setCmessage(cmessage);
if (casesService.save(cases) > 0) {
return R.ok(“上传成功”);
}
}else {
return R.error(“上传error”);
}
return R.error();
}
看看前台js------请求参数大家可以换成HashMap但是后台会用Object转其他类型转俩次
var clipboard = new Clipboard(‘button.copy’, {
text: function (trigger) {
layer.msg(‘文件路径已复制到粘贴板’);
return $(trigger).attr(‘url’);
}
});
layui.use(‘upload’, function () {
var upload = layui.upload;
//执行实例
upload.render({
elem: ‘#test1’, //绑定元素
url: ‘/common/cases/upload’, //上传接口
size: 100000,
// auto: false,
accept: ‘file’,
//bindAction: ‘#submits’,
before: function (obj) {
//obj参数包含的信息,跟 choose回调完全一致。其中输入向后台传输的参数
layer.load();
this.data = {
ctitle: $(‘#ctitle’).val(),
cmessage: $(‘#cmessage’).val() ,
casetroduction: $(‘#casetroduction’).val()
size: 100000,
// auto: false,
accept: ‘file’,
//bindAction: ‘#submits’,
before: function (obj) {
//obj参数包含的信息,跟 choose回调完全一致。其中输入向后台传输的参数
layer.load();
this.data = {
ctitle: $(‘#ctitle’).val(),
cmessage: $(‘#cmessage’).val() ,
casetroduction: $(‘#casetroduction’).val()
[外链图片转存中…(img-c90IfVAV-1725908464277)]
[外链图片转存中…(img-Lr3WVS2P-1725908464278)]
[外链图片转存中…(img-niWwUHwN-1725908464279)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!