最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

Spring Boot Upgrade (1.5 → 3.4) Issue: AJAX Call to set-preferences Routes Incorrectly - Stack Overflow

programmeradmin1浏览0评论

I recently upgraded my Spring Boot application from 1.5 to 3.4 and Java from 8 to 21. After the upgrade, an AJAX POST request to /set-preferences no longer reaches the controller. Instead, it seems to be handled as a static resource or is being ignored. No changes were made to this method during the upgrade.

Error Log:

.springframework.web.servlet.resource.NoResourceFoundException: No static resource set-preferences. : [.springframework.web.servlet.resource.ResourceHttpRequestHandler.handleRequest(ResourceHttpRequestHandler.java:585), .springframework.web.servlet.mvc.HttpRequestHandlerAdapter.handle(HttpRequestHandlerAdapter.java:52), .springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1088), .springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:978), .springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1014), .springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:914), jakarta.servlet.http.HttpServlet.service(HttpServlet.java:547), .springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:885), jakarta.servlet.http.HttpServlet.service(HttpServlet.java:614),

Controller Definition (Unchanged from SB 1.5)

@Controller public class HomeController {
    @RequestMapping(value = "/set-preferences", method = RequestMethod.POST)public String LoginHome(@RequestBody Request request, Model model) {
        UserPreference preference = userPreferenceJsonUtils.convertToObject(
                request.getStrUserPreference(), UserPreference.class);
        setAdditionalUserPreference(preference);
        setResponseMessage(preference, model);
        model.addAttribute("userPreferences", gfeJsonUtils.convertToJson(preference));
        model.addAttribute("User", getUsername());
        return "homePage";
    }
}

AJAX Call (Unchanged from SB 1.5)

var fnAjaxCallToSaveUserPreference = function(Request) {
    $.ajax({
        type: "POST",
        url: "set-preferences/",
        contentType: "application/json",
        async: false,
        data: JSON.stringify(Request),
        cache: false,
        beforeSend: function() {
            $('.loadingImageOpacBg').show();
        },
        success: function(data) {
            if (data !== "") {
                $("#" + "headerId").html(data);
            }
        },
        error: function(xhr, status, error) {
            console.error("AJAX Error:", error);
        }
    });
}

Debugging Steps Taken

Checked Network Tab Shows request sent to /set-preferences/ No 404 error

Questions Why is this AJAX request no longer reaching the controller after upgrading to Spring Boot 3.4? Could this be related to Spring MVC changes in Spring Boot 3.x? What additional debugging steps can I take? Any help would be greatly appreciated!

I recently upgraded my Spring Boot application from 1.5 to 3.4 and Java from 8 to 21. After the upgrade, an AJAX POST request to /set-preferences no longer reaches the controller. Instead, it seems to be handled as a static resource or is being ignored. No changes were made to this method during the upgrade.

Error Log:

.springframework.web.servlet.resource.NoResourceFoundException: No static resource set-preferences. : [.springframework.web.servlet.resource.ResourceHttpRequestHandler.handleRequest(ResourceHttpRequestHandler.java:585), .springframework.web.servlet.mvc.HttpRequestHandlerAdapter.handle(HttpRequestHandlerAdapter.java:52), .springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1088), .springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:978), .springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1014), .springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:914), jakarta.servlet.http.HttpServlet.service(HttpServlet.java:547), .springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:885), jakarta.servlet.http.HttpServlet.service(HttpServlet.java:614),

Controller Definition (Unchanged from SB 1.5)

@Controller public class HomeController {
    @RequestMapping(value = "/set-preferences", method = RequestMethod.POST)public String LoginHome(@RequestBody Request request, Model model) {
        UserPreference preference = userPreferenceJsonUtils.convertToObject(
                request.getStrUserPreference(), UserPreference.class);
        setAdditionalUserPreference(preference);
        setResponseMessage(preference, model);
        model.addAttribute("userPreferences", gfeJsonUtils.convertToJson(preference));
        model.addAttribute("User", getUsername());
        return "homePage";
    }
}

AJAX Call (Unchanged from SB 1.5)

var fnAjaxCallToSaveUserPreference = function(Request) {
    $.ajax({
        type: "POST",
        url: "set-preferences/",
        contentType: "application/json",
        async: false,
        data: JSON.stringify(Request),
        cache: false,
        beforeSend: function() {
            $('.loadingImageOpacBg').show();
        },
        success: function(data) {
            if (data !== "") {
                $("#" + "headerId").html(data);
            }
        },
        error: function(xhr, status, error) {
            console.error("AJAX Error:", error);
        }
    });
}

Debugging Steps Taken

Checked Network Tab Shows request sent to /set-preferences/ No 404 error

Questions Why is this AJAX request no longer reaching the controller after upgrading to Spring Boot 3.4? Could this be related to Spring MVC changes in Spring Boot 3.x? What additional debugging steps can I take? Any help would be greatly appreciated!

Share Improve this question asked Mar 28 at 5:55 user30002040user30002040 11 bronze badge
Add a comment  | 

1 Answer 1

Reset to default 0

Since Spring Boot 3 URLs with and without trailing / are treated as different endpoints.

Change

url: "set-preferences/",

in your AJAX call to

url: "set-preferences",

See https://github/spring-projects/spring-boot/wiki/Spring-Boot-3.0-Migration-Guide#spring-mvc-and-webflux-url-matching-changes for details

发布评论

评论列表(0)

  1. 暂无评论