servlet異なるログイン用権限の異なるページへのジャンプを簡単に実現
多くの友人がjavawebとservletに最初に触れて、管理システムの異なるユーザーロールが対応する権限のページに入って対応する権限の操作機能を実現したいと思っています.総じて多くの方法があります.最も簡単に考えられるのは、ユーザーデータベースに権限のあるフィールド(permission number)を直接挿入し、クエリーするときに、対応するserlvetページ(LoginService.java)に値を返します.簡単なifで判断すればいい.具体的なコードは次のとおりです.
LoginServlet.java:
userManagerにおけるisValid(User ueser)の方法://permissionをコールバックする方法、判断に用いる
これにより,機能は基本的に実現される.
LoginServlet.java:
package com.cola.controller;
import java.io.IOException;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.cola.entity.Userjia;
import com.cola.manager.impl.UserManagerOracleImpl;
public class LoginServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request,response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
Userjia user = new Userjia();
user.setUsername(request.getParameter("userName"));
user.setUserpasswd(request.getParameter("passwd"));
//
System.out.println(user.getUsername());
request.setAttribute("haha", user);
UserManagerOracleImpl userManager = new UserManagerOracleImpl();
int permission = userManager.isValid(user);
// permssion = 1 =0
//
if(permission==1){
request.getRequestDispatcher("/index.html").forward(request, response);
System.out.println("userName------------>"+user.getUsername());
}else if(permission==0){
request.getRequestDispatcher("/index2.html").forward(request,response);
System.out.println("userName------------>"+user.getUsername());
}else if(permission==-1){
request.getRequestDispatcher("/failed.html").forward(request,response);
}
}
}
userManagerにおけるisValid(User ueser)の方法://permissionをコールバックする方法、判断に用いる
/***************************************************************
*
*
*
* *************************************************************/
public int isValid(Userjia user){
int permission = -1;
Connection conn = null;
ResultSet rs = null;
Statement stmt = null;
conn=ConnectionFactory.getConnection();
try {
stmt = conn.createStatement();
rs = stmt.executeQuery
("select * from login_user where name ='"
+user.getUsername()+"' and passwd= '"+user.getUserpasswd()+"' ");
if(rs.next()){
permission = rs.getInt("permission");
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
CloseResource.release(rs, stmt, conn);
}
return permission;
}
これにより,機能は基本的に実現される.