Spring Security 4:请求方法' POST'不支持

时间:2015-12-26 21:56:48

标签: spring spring-security

问题是当我点击登录按钮时,我在tomcat上收到Request method 'POST' not supported错误。

这是我的代码:

<form class="omb_loginForm" action="${/login}" method="POST" autocomplete="off">
                            <div th:if="${param.error}" class="alert alert-error">Invalid username and password.</div>
                            <div th:if="${param.logout}" class="alert alert-success">You have been logged out.</div>
                            <div class="input-group">
                                <span class="input-group-addon"><i class="fa fa-user"></i></span>
                                <input type="text" class="form-control" id="username" name="ssoId"
                                    placeholder="email address" autocomplete="off" required="required"
                                    style="cursor: auto; background-image: url(&quot;&quot;); background-attachment: scroll; background-position: 100% 50%; background-repeat: no-repeat;" />
                            </div>
                            <span class="help-block"></span>

                            <div class="input-group">
                                <span class="input-group-addon"><i class="fa fa-lock"></i></span>
                                <input type="password" class="form-control" id="password" name="password"
                                    placeholder="Password" autocomplete="off" required="required"
                                    style="cursor: auto; background-image: url(&quot;&quot;); background-attachment: scroll; background-position: 100% 50%; background-repeat: no-repeat;" />
                            </div>
                            <input type="hidden" name="${_csrf.parameterName}" value="${_csrf.token}" />
                            <button class="btn btn-lg btn-primary btn-block" type="submit">Login</button>
                        </form>

我的控制器:

@RequestMapping(value = "/login", method = RequestMethod.GET)
    public ModelAndView login(@RequestParam(value = "error", required = false) String error,
            @RequestParam(value = "logout", required = false) String logout) {

        System.out.println("login page");
        ModelAndView model = new ModelAndView();
        if (error != null) {
            model.addObject("error", "Invalid username and password!");
        }

        if (logout != null) {
            model.addObject("msg", "You've been logged out successfully.");
        }
        model.setViewName("login");

        return model;

    }

我的春季安全配置:

package com.mintad.spring.security;

import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;

@Configuration
@EnableWebSecurity
public class SecurityConfiguration extends WebSecurityConfigurerAdapter {

    @Autowired
    DataSource dataSource;

    @Autowired
    public void configureGlobalSecurity(AuthenticationManagerBuilder auth) throws Exception {
        // auth.inMemoryAuthentication().withUser("bill").password("abc123").roles("USER");
        // auth.inMemoryAuthentication().withUser("admin").password("root123").roles("ADMIN");
        // auth.inMemoryAuthentication().withUser("dba").password("root123").roles("ADMIN","DBA");
        auth.jdbcAuthentication().dataSource(dataSource)
                .usersByUsernameQuery("select username,password, enabled from users where username=?")
                .authoritiesByUsernameQuery("select username, role from userroles where username=?");
    }

    @Override
    protected void configure(HttpSecurity http) throws Exception {

        http.authorizeRequests().antMatchers("/", "/index").permitAll()
                // .antMatchers("/admin/**").access("hasRole('ADMIN')")
                // .antMatchers("/db/**").access("hasRole('ADMIN') and
                // hasRole('DBA')")
                .and().formLogin().loginPage("/login").defaultSuccessUrl("/welcome").usernameParameter("ssoId")
                .passwordParameter("password").and().csrf().and().exceptionHandling().accessDeniedPage("/Access_Denied");
    }
}

我尝试从控制器中删除方法类型但是徒劳无功。拜托,欢迎任何帮助!

1 个答案:

答案 0 :(得分:0)

嗯,这很遗憾:(

解决方案是使用@而不是$并将扩展th添加到操作中,如下所示:

<form class="omb_loginForm" th:action="@{/login}" method="POST" autocomplete="off">