Загрузите содержимое файла Excel в MySQL, используя Spring boot и UI - PullRequest
0 голосов
/ 23 октября 2019

Я пытаюсь загрузить содержимое файла Excel в mysql с помощью Spring boot с помощью пользовательского интерфейса загрузки файла. Нужна помощь с этим.

Но я сталкиваюсь с ошибочной страницей Whitelabel. Я попробовал пару вещей, но пока не повезло. Представление проекта

ReadFileApplication.java

package com.springboot.file.parsefiles;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Component;

@Configuration
@EnableAutoConfiguration
@ComponentScan(basePackages= {"com.springboot.file.parsefiles.controller"})
@SpringBootApplication
@Component

public class ReadFileApplication {

    public static void main(String[] args) {
        SpringApplication.run(ReadFileApplication.class, args);

    }
}

ReadFileConrtroller.java

package com.springboot.file.parsefiles.controller;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import com.springboot.file.parsefiles.service.ReadFileService;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;

import com.springboot.file.parsefiles.model.User;

@RestController
public class ReadFileController 
{
    @Autowired private ReadFileService readFileService;

    @GetMapping(value="/ ")
    public String home(Model model)
    {
        model.addAttribute("user", new User());
        List<User> users = ReadFileService.findAll();
        model.addAttribute("users", users);
        return "view/users";
    }


    @PostMapping(value="/fileupload")
    public String uploadFile(@ModelAttribute User user, RedirectAttributes redirectAttributes)
    {
        @SuppressWarnings("unused")
        boolean isFlag = readFileService.saveDataFromUploadFile(user.getFile());
        return "redirect:/";
    }
}

ReadFileRepository.java

package com.springboot.file.parsefiles.repository;

import org.springframework.data.repository.CrudRepository;
import org.springframework.stereotype.Repository;

import com.springboot.file.parsefiles.model.User;

@Repository
public interface ReadFileRepository extends CrudRepository<User, Long>
{

}

ReadFileService.java

package com.springboot.file.parsefiles.service;

import java.util.List;
import org.springframework.web.multipart.MultipartFile;
import com.springboot.file.parsefiles.model.User;

public interface ReadFileService 
{
    List<User> findAll = null;
    static List<User> findAll() 
    {
        return null;
    }
    boolean saveDataFromUploadFile(MultipartFile file);

}

ReadFileServiceImpl.java

package com.springboot.file.parsefiles.service;

import java.util.List;

import com.springboot.file.parsefiles.service.ReadFileService;
import org.apache.commons.io.FilenameUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.multipart.MultipartFile;

import com.springboot.file.parsefiles.model.User;
import com.springboot.file.parsefiles.repository.ReadFileRepository;

@Service
@Transactional
public class ReadFileServiceImpl implements ReadFileService
{
    @Autowired private ReadFileRepository readFileRepository;


    public List<User> findAll()
    {
        return (List<User>) readFileRepository.findAll();
    }


    @Override
    public boolean saveDataFromUploadFile(MultipartFile file) {
        @SuppressWarnings("unused")
        boolean isFlag = false;
        String extension = FilenameUtils.getExtension(file.getOriginalFilename());
        if(extension.equalsIgnoreCase("json"))
        {
            isFlag = realDataFromJson(file);
        }else if(extension.equalsIgnoreCase("csv"))
        {
            isFlag = realDataFromCsv(file);
        }
        return false;
    }


    private boolean realDataFromCsv(MultipartFile file) 
    {
        return false;
    }


    private boolean realDataFromJson(MultipartFile file) 
    {
        return false;
    }

}

Applicatiopn.properties

spring.datasource.url = jdbc:mysql://localhost:3306/sampledatabase
spring.datasource.username = root
spring.datasource.password = root
spring.datasource.testWhileIdle = true
spring.datasource.validationQuery = SELECT 1

spring.jpa.show-sql = true

spring.jpa.hibernate.ddl-auto = update

spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy

spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect

spring.servlet.multipart.max-file-size=100MB
spring.servlet.multipart.max-request-size=500MB

Редактировать:


Приложение не удалось запустить


Описание:

Поле readFileService в com.springboot.file.parsefiles.controller.ReadFileController требуется компонент типа com.springboot.file. parsefiles.service.ReadFileService ', который не может быть найден.

Точка внедрения имеет следующие аннотации: - @ org.springframework.beans.factory.annotation.Autowired (required = true)

Действие:

Рассмотрите возможность определения bean-компонента типа 'com.springboot.file.parsefiles.service.ReadFileService' в вашей конфигурации.

1 Ответ

0 голосов
/ 04 ноября 2019

Обновите свой контроллер, как показано ниже

@PostMapping(value="/fileupload")
    public String uploadFile(@RequestParam MultipartFile file, RedirectAttributes redirectAttributes)
    {
        @SuppressWarnings("unused")
        boolean isFlag = readFileService.saveDataFromUploadFile(file);
        return "redirect:/";
    }

Далее я использовал библиотеку apache-poi для преобразования файла Excel в список объектов модели в классе обслуживания. Так что мой метод обслуживания, как показано ниже

@Autowired
private IPoiji poijiImpl;

@Override
    public boolean saveDataFromUploadFile(MultipartFile file) {
        List<UserDTO> uploadedUserList = = poijiImpl.fromExcel(file.getOriginalFilename(), file.getInputStream(),UserDTO.class);
        // here i can call repository methods to save data in database
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...