Web アプリで問題が発生しています。コードを投稿し、コード部分で何をしているかを定義しています...
これは、ユーザータイプ(管理者、マネージャー、ユーザー)をチェックする私のフィルターです..そして、マークされた行でエラーが発生しています...
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest) request;
HttpSession session = req.getSession();
RequestDispatcher rd=null;
Person user = (Person) session.getAttribute("usertype"); <------ **IM GETTING EXCEPTION HERE!**
if (user != null && user.getType().equals(UserType.MANAGER.toString())) {
String nextJSP = "/ManagerHome.jsp";
rd = request.getRequestDispatcher(nextJSP);
rd.forward(request, response);
}
else if (user != null && user.getType().equals(UserType.ADMIN.toString())) {
String nextJSP = "/AdminHome.jsp";
rd = request.getRequestDispatcher(nextJSP);
rd.forward(request, response);
}
else if (user != null && user.getType().equals(UserType.USER.toString())) {
String nextJSP = "/UserHome.jsp";
rd = request.getRequestDispatcher(nextJSP);
rd.forward(request, response);
}
else {
String nextJSP = "/Login.jsp";
rd = request.getRequestDispatcher(nextJSP);
rd.forward(request, response);
}
chain.doFilter(request, response);
}
そして、これは人のレコードを持つ私の Person クラスです
@Table(name="\"Person\"")
public class Person implements Serializable {
/**
*
*/
private static final long serialVersionUID = 2532993385565282772L;
@Id
@Column(name="id",nullable=false,updatable=false)
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
private String username;
private String name;
private String surname;
private String sskno;
private String address;
private String telno;
private String type;
@OneToMany
private List<Leave> leaves;
public Person() {
}
getters & setters....
そして、これは私の LoginServlet です... ここで、一時的に Pusername、Pname、Pusertype、および Pusername は、セッションの属性を設定するためのものです。そして、JSPであるこのページによると、ユーザータイプに依存します...(ユーザーがユーザーホームに移動した場合、マネージャーマネージャーがホームに移動した場合)...なぜこのエラーが発生するのかはわかりますが、それを回避する方法はわかりません。私は調査を行いましたが、何もうまくいきませんでした...ここで私を助けてください私のログインサーブレットです
public class LoginServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
public LoginServlet() {
super();
}
protected void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
try {
String pName;
String pSurname;
String pUserName;
String pUserType;
String query;
String home="/Login.jsp";
String username = request.getParameter("username");
String password = request.getParameter("password");
RequestDispatcher rd = request.getRequestDispatcher(home);
mysqlCon con = new mysqlCon();
//HttpSession session = request.getSession();
LoginService ls = new LoginService();
Statement stmt = con.getConnection().createStatement();
query = "SELECT name, surname, usertype, username FROM employee WHERE username='"
+ username + "' AND password='" + password + "';";
stmt.executeQuery(query);
ResultSet rs = stmt.getResultSet();
if(rs.next()){
pName = rs.getString(1);
pSurname = rs.getString(2);
pUserType = rs.getString(3);
pUserName = rs.getString(4);
if (ls.loginCheck(username, password) != false) {
Person tmp = new Person();
tmp.setName(pName);
tmp.setSurname(pSurname);
tmp.setType(pUserType);
tmp.setUsername(pUserName);
HttpSession session = request.getSession();
session.setAttribute("name", tmp.getName());
session.setAttribute("surname", tmp.getSurname());
session.setAttribute("usertype", tmp.getType());
session.setAttribute("username", tmp.getUsername());
if (pUserType.equals(UserType.MANAGER.toString())) {
String nextJSP = "home/ManagerHome.jsp";
rd = request.getRequestDispatcher(nextJSP);
rd.forward(request, response);
}
else if (pUserType.equals(UserType.ADMIN.toString())) {
String nextJSP = "home/AdminHome.jsp";
rd = request.getRequestDispatcher(nextJSP);
rd.forward(request, response);
}
else if (pUserType.equals(UserType.USER.toString())) {
String nextJSP = "home/UserHome.jsp";
rd = request.getRequestDispatcher(nextJSP);
rd.forward(request, response);
}
else {
String nextJSP = "/Login.jsp";
rd = request.getRequestDispatcher(nextJSP);
rd.forward(request, response);
}
}
}
else {
rd.forward(request, response);
}
さらに情報を追加してほしい場合は、それを行うことができます。私の質問は、これを回避して機能させるにはどうすればよいかということです。