Как решить "noHandlerFound" в Spring MVC с конфигурацией на основе Java? - PullRequest
0 голосов
/ 31 мая 2019

Я разрабатываю приложение Spring MVC с конфигурацией на основе Java.Я сталкиваюсь с этой ошибкой org.springframework.web.servlet.DispatcherServlet noHandlerFound и WARNING: No mapping found for HTTP request with URI [/solution/clients/css/form.css] in DispatcherServlet with name 'dispatcher'

AppConfig.java

@Configuration
@EnableWebMvc
@EnableTransactionManagement
@ComponentScan(basePackages = "solution")
@PropertySource("classpath:persistence-mysql.properties")
public class AppConfig {
    @Autowired
    private Environment env;

    private Logger logger = Logger.getLogger(getClass().getName());

    @Bean
    public ViewResolver viewResolver() {

        InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();

        viewResolver.setPrefix("/WEB-INF/view/");
        viewResolver.setSuffix(".jsp");

        return viewResolver;
    }
}

SolutionDispatcherServletInitializer.java

public class SolutionDispatcherServletInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {

    @Override
    protected Class<?>[] getRootConfigClasses() {
        return null;
    }

    @Override
    protected Class<?>[] getServletConfigClasses() {
        return new Class[] { AppConfig.class };
    }

    @Override
    protected String[] getServletMappings() {
        return new String[] { "/" };
    }
}

Класс контроллера:

@Controller
@RequestMapping("/clients")
public class ClientsController {

    // Injection of Service Class
    @Autowired
    private ClientService clientService;

    @GetMapping("/list")
    public String listClients(Model theModel) {

        // Getting Clients From SERVICE Class
        List<Clients> theClients = clientService.getClients();

        // Adding Clients to Model(Entity Class) 
        theModel.addAttribute("clientsModel", theClients);

        return "list-clients";
    }   
}

Просмотр:

<h3>ALL CLIENTS</h3>
  <div class="addnew-form">

  <table>
     <tr>
        <th class="trtd">First Name</th>
        <th class="trtd">Last Name</th>
        <th class="trtd">Email</th>
        <th class="trtd">Mobile Number</th>
        <th class="trtd">City</th>
        <th class="trtd">Country</th>
        <th class="trtd">Domain</th>
        <th class="trtd">View</th>
        <th class="trtd">Action</th>
     </tr>

     <!-- LOOP -->

     <c:forEach var="tempClients" items="${clientsModel}">
     <tr>
       <td class="trtd">${tempClients.firstName}</td>
       <td class="trtd">${tempClients.lastName}</td>
       <td class="trtd">${tempClients.email}</td>
       <td class="trtd">${tempClients.mobileNumber}</td>
       <td class="trtd">${tempClients.city}</td>
       <td class="trtd">${tempClients.country}</td>
       <td class="trtd">${tempClients.domain}</td>
     </tr>
     </c:forEach>
  </table>

Сообщения об ошибках:

May 31, 2019 12:40:22 PM org.springframework.web.servlet.DispatcherServlet noHandlerFound
WARNING: No mapping found for HTTP request with URI [/solution/clients/css/form.css] in DispatcherServlet with name 'dispatcher'
WARNING: No mapping found for HTTP request with URI [/solution/$%7BpageContext.request.contextPath%7D/clients/list] in DispatcherServlet with name 'dispatcher'

Вывод в веб-браузере выглядит примерно так.Моя база данных имеет связь с приложением.Но все еще не получать данные из MySql.Вывод отображает некоторый код JSP.${tempClients.firstName}

Изображение: Нажмите сюда для изображения

Заранее спасибо

1 Ответ

0 голосов
/ 01 июня 2019

Я думаю, вам нужно изменить аннотацию @Controller на @RestController.

То есть ваш контроллер будет выглядеть как

@RestController
@RequestMapping("/clients")
public class ClientsController {

    // Injection of Service Class
    @Autowired
    private ClientService clientService;

    @GetMapping("/list")
    public String listClients(Model theModel) {

        // Getting Clients From SERVICE Class
        List<Clients> theClients = clientService.getClients();

        // Adding Clients to Model(Entity Class) 
        theModel.addAttribute("clientsModel", theClients);

        return "list-clients";
    }   
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...