Заявление putObject не может загрузить файл в aliyun OSS - PullRequest
0 голосов
/ 19 октября 2019

Я пишу функцию для загрузки видео файла в 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";
    }
}
...