HTTP 403 при попытке выполнить действие
У меня есть действие на форме
<form action="LoginAction.do" method="POST">
<div id="table"
class="ui-widget-header ui-corner-all ui-widget-content">
<table align="center" style="width: 100%">
<tr>
<td align="center"><span
style="color: white; font-size: 20px;"><fmt:message
key="lg" /></span></td>
<td align="right"><input type="text" id="login" name="login" />
<td>
</tr>
<tr>
<td align="center"><span
style="color: white; font-size: 20px;"><fmt:message
key="paswd" /></span></td>
<td align="right"><input type="text" id="password"
name="password" /></td>
</tr>
<tr>
<td align="right" colspan="2"><input type="submit"
id="approve" style="font-size: 10px;"
value="<fmt:message key='enter'/>" /></td>
</tr>
</table>
</div>
</form>
Когда я нажимаю кнопку, он должен выполнить LoginAction
HttpSession session = req.getSession();
log.debug("attempt to checkuser");
String page = req.getRequestURI();
String login = req.getParameter("login");
String password = req.getParameter("password");
loginService = new LoginServiceImpl();
if (loginService.checkExists(login, password)) {
session.setAttribute("enterAttr", true);
session.setAttribute("loginame", login);
return page;
}
session.setAttribute("enterAttr", false);
return "redirect:" + page;
В ActionServet он должен проверить результат действия, а затем перенаправить на определенную страницу.
String name = getActionName(req);
Action action = (Action) factory.getAction(name, getClass()
.getClassLoader());
String view = action.exec(req, resp);
//router
if (view.startsWith("redirect:")) {
resp.sendRedirect(view.substring("redirect:".length(),
view.length()));
} else {
getServletContext().getRequestDispatcher(
"/WEB-INF/jsp/" + view + ".jsp").forward(req, resp);
}
Но вместо этого у меня есть HTTP Status 403 - Access to the requested resource has been denied
когда я пытаюсь нажать кнопку.
В чем проблема? Что-то с пользователями tomcat?
Вот web.xml
<?xml version="1.0" encoding="Cp1251"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">
<context-param>
<param-name>javax.servlet.jsp.jstl.fmt.localizationContext</param-name>
<param-value>messages</param-value>
</context-param>
<servlet>
<servlet-name>ActionServlet</servlet-name>
<servlet-class>com.project.reservation.web.ActionServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ActionServlet</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<security-role>
<description>Role for administrator's actions</description>
<role-name>admin</role-name>
</security-role>
<welcome-file-list>
<welcome-file>/main.jsp</welcome-file>
</welcome-file-list>
<security-constraint>
<web-resource-collection>
<web-resource-name>reservation</web-resource-name>
<url-pattern>*.do</url-pattern>
</web-resource-collection>
<auth-constraint>
<role-name>admin</role-name>
</auth-constraint>
<user-data-constraint>
<transport-guarantee>NONE</transport-guarantee>
</user-data-constraint>
</security-constraint>
1 ответ
Решение
Вы реализуете свой собственный механизм аутентификации, но используете файл Containers Web.xml для определения ограничений безопасности. На вашем месте я мог бы попытаться переместить свой код аутентификации в фильтр и удалить ограничение безопасности из файла web.xml.