19

嗨,我在重定向期间收到下一个错误:

客户端发送的请求语法错误

浏览器显示的 URL 是:localhost:8080/Project/menu/main/home/0这里我的类首先重定向 - “from”,第二个“to”:

 /*
 * Get all possible values of menu and generate correct url to pages controllers
 * 
 */

@Controller
@SessionAttributes("menu")
public class MainMenuController {


    @ModelAttribute
    public Menu createMenu() {
        return new Menu();
    }

    @RequestMapping(value = "/menu", method = RequestMethod.GET)
    public String mainMenuResolver(@ModelAttribute Menu menu) {
        menu.setMainMenu("first");
        return "forward:/menu/first";
    }

    @RequestMapping(value = "/menu/{mainMenu}", method = RequestMethod.GET)
    public String subMenuResolver(@PathVariable String mainMenu, @ModelAttribute Menu menu) {
        menu.setMainMenu(mainMenu);
        menu.setSubMenu("home");
        return "forward:/menu/first/home";
    }

    @RequestMapping(value = "/menu/{mainMenu}/{subMenu}", method = RequestMethod.GET)
    public String secMenuResolver(@PathVariable String mainMenu, @PathVariable String subMenu, @ModelAttribute Menu menu) {
        menu.setMainMenu(mainMenu);
        menu.setSubMenu(subMenu);
        menu.setSecMenu("0");

        if (menu.getMainMenu().equals("first")){
            return "redirect:/menu/main/"+menu.getSubMenu()+"/"+menu.getSecMenu();
        }

        if (menu.getMainMenu().equals("second")){
            return "redirect:/menu/religion/"+menu.getSubMenu()+"/"+menu.getSecMenu();
        }

        return "redirect:/menu/main/"+menu.getSubMenu()+"/"+menu.getSecMenu();
    }
}

二等:

@Controller
@SessionAttributes("menu")
public class FirstPageController {

    @ModelAttribute
    public Menu createMenu() {
        return new Menu();
    }

    @RequestMapping(value = "/menu/main/{subMenu}/{secMenu}", method = RequestMethod.GET)
    public ModelAndView menuResolver(@PathVariable String mainMenu, @PathVariable String subMenu,@PathVariable String secMenu, @ModelAttribute("menu") Menu menu) {
        menu.setMainMenu(mainMenu);
        menu.setSubMenu(subMenu);
        menu.setSecMenu(secMenu);       

        if (menu.getSubMenu().equals("home")){
            String title = "Project - Home Page";
            return new ModelAndView("MainPage", "title", title);
        }

        String title = "Project - Home Page";
        return new ModelAndView("MainPage", "title", title);
    }
}

已解决:我解决了,第二类的方法有多余的参数。

4

4 回答 4

36

在这种情况下,将org.springframework.web登录级别设置DEBUGlog4j configuration

<logger name="org.springframework.web">
    <level value="DEBUG" />
    ...
</logger>

例如,当参数丢失或无法转换为所需类型时,日志中会出现异常详细信息。

于 2013-03-15T12:38:06.097 回答
2

在我的情况下,这个错误的原因是浏览器(Chrome,在我的特殊情况下)以错误的格式date从服务器发送<input type="date" ... />到服务器,所以服务器不知道如何解析它。

于 2014-05-23T14:54:37.130 回答
0

正如ike3所说,使用详细的日志帮助我找到了解决方案。在我的情况下,没有指定名称的@PathVariable 与变量本身不匹配。

像这样的东西:

@RequestMapping("/user/{uname}")
public String doSomething(@PathVariable String username) { ...

注意“uname”和“username”之间的区别!内部有一个异常没有引发,直到我将日志设置为 INFO 级别我才能看到它。

于 2014-08-31T01:54:29.763 回答
0

就我而言,这也是一个转换问题,Spring 期待一个整数,但我输入的是一个字符串。尝试检查您作为参数传递给控制器​​的内容

于 2017-01-30T22:01:34.410 回答