Я пишу функцию для загрузки видео файла в aliyun OSS. функция отлично работает в весенней загрузке, но не может работать в автономном tomcat. Проблема вызвана утверждением ossClient.putObject(bucket,Objectname,file.getInputStream());
Может кто-нибудь сказать мне, что не так?
При весенней загрузке я запускаю эту функцию и успешно загружаю файлы в aliyun OSS. затем я экспортирую код в файл war и развернул в tomcat, после чего не могу работать. выдает 500 внутреннюю ошибку сервера, когда без исключений.
@Controller
public class UploadVideoController {
private final static org.slf4j.Logger log = LoggerFactory.getLogger(UploadVideoController.class);
@Autowired
private VideoFileRepository videoFileRepository;
@Autowired
private ApplicationUserRepository applicationUserRepository;
@Autowired
private VideoFileInSolrRepository videoSolrRepo;
String endpoint = "http://oss-cn-zhangjiakou.aliyuncs.com";
String accessKeyId = "my id";
String accessKeySecret = "my secret";
String bucket = "studytech";
String aliyunURL = "https://studytech.oss-cn-zhangjiakou.aliyuncs.com/";
@RequestMapping("/videoUpload")
public String UploadPage(Model model) {
return "uploadVideoPage";
}
@RequestMapping("/doVideoUpload")
public String doupload(Model model, @RequestParam("files") MultipartFile[] files) throws IOException {
Authentication authentication = SecurityContextHolder.getContext().getAuthentication();
ApplicationUser au = applicationUserRepository.findByUsername(authentication.getName());
StringBuilder fileNames = new StringBuilder();
StringBuilder fileNotUpload = new StringBuilder();
Path path;
log.info("realPathtoUploads = {}", endpoint);
for (MultipartFile file : files) {
OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
String Objectname = file.getOriginalFilename();
path = Paths.get(Objectname);
String filetype = Files.probeContentType(path);
VideoFile vf = videoFileRepository.findByFileName(Objectname);
if (filetype.equals("video/mp4") && vf == null) {
try {
ossClient.putObject(bucket, Objectname, file.getInputStream());
VideoFile document = new VideoFile(file.getOriginalFilename(), file.getContentType(),
aliyunURL + file.getOriginalFilename(), "test");
document.setAppuser(au);
au.getVideoFilelist().add(document);
videoFileRepository.save(document);
VideoFileInSolr solrdocument = new VideoFileInSolr(file.getOriginalFilename(),
aliyunURL + file.getOriginalFilename());
videoSolrRepo.save(solrdocument);
fileNames.append(file.getOriginalFilename() + " ");
} catch (Exception ex) {
ex.printStackTrace();
System.out.println("user or file not found");
} catch (Throwable e) {
e.printStackTrace();
} finally {
ossClient.shutdown();
}
} else {
fileNotUpload.append(file.getOriginalFilename() + " ");
}
}
if (fileNames != null) {
model.addAttribute("msg1", "Successfully uploaded files: " + fileNames.toString());
}
if (fileNotUpload != null) {
model.addAttribute("msg2", "Files alread exist or file extension is not .mp4: " + fileNotUpload.toString());
}
return "uploadVideoPage";
}
}