问题是当我点击登录按钮时,我在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(""); 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(""); 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");
}
}
我尝试从控制器中删除方法类型但是徒劳无功。拜托,欢迎任何帮助!
答案 0 :(得分:0)
嗯,这很遗憾:(
解决方案是使用@而不是$并将扩展th添加到操作中,如下所示:
<form class="omb_loginForm" th:action="@{/login}" method="POST" autocomplete="off">