Не найдено сопоставление для HTTP-запроса с ошибкой URI, когда задан контекстный путь - PullRequest
0 голосов
/ 27 ноября 2018

Перед тем, как все пишут, что это дурак, я прочитал другие вопросы и ответы об этой ошибке, и все, что я пробовал, сработало.Это работало, по крайней мере, время от времени на прошлой неделе.Сегодня я получаю эту ошибку.Ниже приведены мои файлы:

pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
                         http://maven.apache.org/xsd/maven-4.0.0.xsd">

 <modelVersion>4.0.0</modelVersion>
 <groupId>security</groupId>
 <artifactId>password-strength</artifactId>
 <version>1.0.0-SNAPSHOT</version>
 <url>http://www.xxxx.com</url>
 <name>Spring Security - ${project.artifactId}</name>

 <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.17.RELEASE</version>
 </parent>

 <properties>
    <java.version>1.8</java.version>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 </properties>

 <dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    <dependency>
        <groupId>commons-beanutils</groupId>
        <artifactId>commons-beanutils</artifactId>
        <version>1.6.1</version>
    </dependency>
    <dependency>
        <groupId>org.passay</groupId>
        <artifactId>passay</artifactId>
        <version>1.2.0</version>
    </dependency>
    <dependency>
        <groupId>org.webjars</groupId>
        <artifactId>bootstrap</artifactId>
        <version>4.0.0</version>
    </dependency>
    <dependency>
        <groupId>org.webjars</groupId>
        <artifactId>jquery</artifactId>
        <version>3.0.0</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-tomcat</artifactId>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aspects</artifactId>
        <version>3.1.2.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjrt</artifactId>
        <version>1.9.2</version>
    </dependency>

    <!-- testing -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>

 </dependencies>

 <build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
        <plugin>
            <groupId>org.eclipse.jetty</groupId>
            <artifactId>jetty-maven-plugin</artifactId>
            <version>9.2.2.v20140723</version>
            <configuration>
                <jvmArgs>-Xmx2048m -Xms512m -XX:MaxPermSize=512m</jvmArgs>
                <httpConnector>
                    <port>9086</port>
                </httpConnector>
                <stopPort>9968</stopPort>
                <stopKey>jetty-stop</stopKey>
                <stopWait>10</stopWait>
                <useTestScope>true</useTestScope>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-war-plugin</artifactId>
            <version>2.4</version>
            <configuration>
                <webResources>
                    <resource>
                        <directory>src/main/resources/</directory>
                        <filtering>true</filtering>
                        <include>index.html</include>
                        <targetPath>docs/</targetPath>
                    </resource>
                </webResources>
            </configuration>
        </plugin>
    </plugins>
  </build>

</project>

src \ main \ resources \ META-INF \ spring \gration \ applicationContext.xml:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">

 <context:property-placeholder />
 <context:spring-configured/>
 <context:annotation-config/>
 <context:component-scan base-package="security"/>

</beans>

src \ main \ security \ web \ Run.java:

package security;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Run {

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

}

src \ main \ webapp \ WEB-INF \ config \ web-application-config.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="
       http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd">
  <import resource="classpath:META-INF/spring/integration/applicationContext.xml"/>
</beans>

src \ main \ webapp \ WEB-INF \ web.xml:

<?xml version="1.0" encoding="ISO-8859-1" standalone="no"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4"
     xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:META-INF/spring/integration/applicationContext.xml</param-value>
</context-param>
 <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
 </listener>

 <servlet>
    <servlet-name>SpringServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/config/web-application-config.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
 </servlet>
 <servlet-mapping>
    <servlet-name>SpringServlet</servlet-name>
    <url-pattern>/*</url-pattern>
 </servlet-mapping>
</web-app>

src / main / security / web / UserRegistrationController.java:

package security.web;

import security.web.dto.UserRegistrationDto;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
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.RequestMapping;
import javax.validation.Valid;

@Controller
@RequestMapping("/registration")
public class UserRegistrationController {

 @ModelAttribute("user")
 public UserRegistrationDto userRegistrationDto() {
    return new UserRegistrationDto();
 }

 @GetMapping
 public String showRegistrationForm(Model model) {
    return "registration";
 }

 @PostMapping
 public String registerUserAccount(@ModelAttribute("user") @Valid UserRegistrationDto userDto,
        BindingResult result) {

    if (result.hasErrors()) {
        return "registration";
    }

    return "redirect:/registration?success";
 }

}

src \ main \ resources\ templates \ registration.html:

<!DOCTYPE html>
 <html xmlns:th="http://www.thymeleaf.org">
 <head>
  <meta charset="utf-8"/>
  <meta http-equiv="X-UA-Compatible" content="IE=edge"/>
  <meta name="viewport" content="width=device-width, initial-scale=1"/>

  <link rel="stylesheet" type="text/css" th:href="@{/webjars/bootstrap/3.3.7/css/bootstrap.min.css}"/>
  <link rel="stylesheet" type="text/css" th:href="@{/css/main.css}"/>

  <title>Registration</title>
 </head>
 <body>
 <div class="container">
  <div class="row">
    <div class="col-md-6 col-md-offset-3">
        <div class="panel panel-default">
            <div class="panel-body">
                <div class="text-center">
                    <h3><i class="glyphicon glyphicon-user" style="font-size:2em;"></i></h3>
                    <h2 class="text-center">Register</h2>
                    <div class="panel-body">

                        <div th:if="${param.success}">
                            <div class="alert alert-info">
                                You've successfully registered with our awesome app!
                            </div>
                        </div>

                        <form th:action="@{/registration}" th:object="${user}" method="post">

                            <p class="error-message"
                               th:if="${#fields.hasGlobalErrors()}"
                               th:each="error : ${#fields.errors('global')}"
                               th:text="${error}">Validation error</p>


                            <div class="form-group"
                                 th:classappend="${#fields.hasErrors('firstName')}? 'has-error':''">
                                <div class="input-group">
                                    <span class="input-group-addon">
                                        <i class="glyphicon glyphicon-user color-blue"></i>
                                    </span>
                                    <input id="firstName"
                                           class="form-control"
                                           placeholder="First name"
                                           th:field="*{firstName}"/>
                                </div>
                                <p class="error-message"
                                   th:each="error: ${#fields.errors('firstName')}"
                                   th:text="${error}">Validation error</p>
                            </div>
                            <div class="form-group"
                                 th:classappend="${#fields.hasErrors('lastName')}? 'has-error':''">
                                <div class="input-group">
                                    <span class="input-group-addon">
                                        <i class="glyphicon glyphicon-user color-blue"></i>
                                    </span>
                                    <input id="lastName"
                                           class="form-control"
                                           placeholder="Last name"
                                           th:field="*{lastName}"/>
                                </div>
                                <p class="error-message"
                                   th:each="error: ${#fields.errors('lastName')}"
                                   th:text="${error}">Validation error</p>
                            </div>
                            <div class="form-group"
                                 th:classappend="${#fields.hasErrors('email')}? 'has-error':''">
                                <div class="input-group">
                                    <span class="input-group-addon">@</span>
                                    <input id="email"
                                           class="form-control"
                                           placeholder="E-mail"
                                           th:field="*{email}"/>
                                </div>
                                <p class="error-message"
                                   th:each="error: ${#fields.errors('email')}"
                                   th:text="${error}">Validation error</p>
                            </div>
                            <div class="form-group"
                                 th:classappend="${#fields.hasErrors('confirmEmail')}? 'has-error':''">
                                <div class="input-group">
                                    <span class="input-group-addon">@</span>
                                    <input id="confirmEmail"
                                           class="form-control"
                                           placeholder="Confirm e-mail"
                                           th:field="*{confirmEmail}"/>
                                </div>
                                <p class="error-message"
                                   th:each="error: ${#fields.errors('confirmEmail')}"
                                   th:text="${error}">Validation error</p>
                            </div>
                            <div class="form-group"
                                 th:classappend="${#fields.hasErrors('password')}? 'has-error':''">
                                <div class="input-group">
                                    <span class="input-group-addon">
                                        <i class="glyphicon glyphicon-lock"></i>
                                    </span>
                                    <input id="password"
                                           class="form-control"
                                           placeholder="password"
                                           type="password"
                                           th:field="*{password}"/>
                                </div>
                                <ul class="text-left"
                                    th:each="error: ${#fields.errors('password')}">
                                    <li th:each="message : ${error.split(',')}">
                                        <p class="error-message"
                                           th:text="${message}"></p>
                                    </li>
                                </ul>
                            </div>
                            <div class="form-group"
                                 th:classappend="${#fields.hasErrors('confirmPassword')}? 'has-error':''">
                                <div class="input-group">
                                    <span class="input-group-addon">
                                        <i class="glyphicon glyphicon-lock"></i>
                                    </span>
                                    <input id="confirmPassword"
                                           class="form-control"
                                           type="password"
                                           placeholder="Confirm password"
                                           th:field="*{confirmPassword}"/>
                                </div>
                                <ul class="text-left"
                                    th:each="error: ${#fields.errors('confirmPassword')}">
                                    <li th:each="message : ${error.split(',')}">
                                        <p class="error-message"
                                           th:text="${message}"></p>
                                    </li>
                                </ul>
                            </div>
                            <div class="form-group"
                                 th:classappend="${#fields.hasErrors('terms')}? 'has-error':''">
                                <input id="terms"
                                       type="checkbox"
                                       th:field="*{terms}"/>
                                <label class="control-label" for="terms">
                                    I agree with the <a href="#">terms and conditions</a> for Registration.
                                </label>
                                <p class="error-message"
                                   th:each="error : ${#fields.errors('terms')}"
                                   th:text="${error}">Validation error</p>
                            </div>
                            <div class="form-group">
                                <button type="submit" class="btn btn-success btn-block">Register</button>
                            </div>
                        </form>

                    </div>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-md-12">
                Already registered? <a href="/" th:href="@{/login}">Login</a>
            </div>
            <div class="col-md-12">
                Forgot password? <a href="/" th:href="@{/forgot-password}">Reset password</a>
            </div>
        </div>
    </div>
 </div>
</div>

<script type="text/javascript" th:src="@{/webjars/jquery/3.2.1/jquery.min.js/}"></script>
<script type="text/javascript" th:src="@{/webjars/bootstrap/3.3.7/js/bootstrap.min.js}"></script>

</body>
</html>

Я загружаю:

http://localhost:9086/registration/

и получаю:

HTTP ERROR 404
Problem accessing /registration/. Reason:

   Not Found
   Powered by Jetty://

Есть идеи?Я пробовал разные вещи, читал несколько уроков, пробовал разные вещи на разных сайтах.пока не повезло.Мне кажется, должно работать, но ...

ОБНОВЛЕНИЕ:

Я вернулся в предыдущее состояние в некоторых из моихфайлы (обновленные файлы выше).Я обнаружил, что происходит следующее: Кстати, я использую версию IntelliJ IDEA Community.Когда я выполняю локальную сборку и запускаю

mvn clean compile

, страница не загружается (сопоставление не найдено, исключение указано выше).
Однако, когда я запускаю Lifecycle \ compile напрямую из-под Maven Projects и запускаю Jettyчерез плагины \ jetty: запустить, страница загружается успешно.Кроме того, мне также может понадобиться отметить root \ src \ main как корень источника в IntelliJ или снять его, затем снова пометить как таковой, снова запустить Lifecycle \ compile, затем при запуске Jetty страница загружается успешно.В противном случае я получаю ошибку сопоставления.

Это говорит мне о том, что успех или неудача каким-то образом зависят от того, как проект построен, то есть с помощью какого инструмента.Также кажется, что это подразумевает зависимость состояния инструмента от проблемы сборки как таковой.Это расстраивает и делает это своего рода Heisenbug.Это плохо.

Я также добавляю страницу, о которой я говорю о загрузке (registration.html), в список файлов в моем OP.

1 Ответ

0 голосов
/ 27 ноября 2018

Где вы устанавливаете context-path?например, application.properties?

server.servlet.context-path=/my-context-path

На практике, говоря о Spring Boot, после того как вы задали context-path, чтобы получить доступ к приложению через HTTP-запрос, вы должны добавить URL-адрес к context-path:

* 1005.*
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...