系統(tǒng)安全一直是在系統(tǒng)開(kāi)發(fā)中不可規(guī)避的問(wèn)題,而權(quán)限控制又跟系統(tǒng)安全密不可分,那java權(quán)限管理怎么實(shí)現(xiàn)?接下來(lái)我們就來(lái)給大家講解一下java實(shí)現(xiàn)權(quán)限管理的方法。
利用filter、xml文件和用戶信息表配合使用來(lái)實(shí)現(xiàn)權(quán)限管理。第二種方式是利用專(zhuān)門(mén)的權(quán)限表來(lái)維護(hù)用戶權(quán)限,根據(jù)登錄的用戶的權(quán)限信息判斷謀個(gè)功能是否顯示在頁(yè)面上,來(lái)實(shí)現(xiàn)權(quán)限的控制。
第一種方式:利用filter、xml文件和用戶信息表配合使用來(lái)實(shí)現(xiàn)權(quán)限管理。
1.過(guò)濾器filter
package cn.com.aaa.bbb.filter; import java.io.IOException; import java.io.InputStream; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletContext; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.dom4j.document; import org.dom4j.Element; import org.dom4j.io.SAXReader; import cn.com.aaa.bbb.domain.User; import cn.com.aaa.bbb.util.HttpUtils; public class ManagerAuthFilter implements Filter { protected static final Log logger = LogFactory.getLog(ManagerAuthFilter.class); public static final String MAPPING_FILE = "/WEB-INF/managerauthmapping.xml"; private ServletContext context = null; private Map actions = new HashMap(); public void init(FilterConfig filterConfig) throws ServletException { context = filterConfig.getServletContext(); if (context == null) { logger.error("unable to init as servlet context is null"); return; } loadConf(); logger.info("ManagerAuthFilter configure success."); } private void loadConf() { InputStream inputStream = context.getResourceAsStream(MAPPING_FILE); if (inputStream == null) { logger.info("unable find auth mapping file " + MAPPING_FILE); } else { actions = parseConf(inputStream); } } private Map parseConf(InputStream inputStream) { try { SAXReader reader = new SAXReader(); document document = reader.read(inputStream); return createActionMap(document); } catch (Exception e) { logger.info(e.getMessage()); e.printStackTrace(); } return new HashMap(); } private Map createActionMap(document document) { Map map = new HashMap(); Element root = document.getRootElement(); //處理XML,讀入JAVA Object對(duì)象中。 List actionList = root.elements(); for (Iterator it = actionList.iterator(); it.hasNext();) { Element e = (Element) it.next(); String actionName = e.attributevalue("name"); String auth_value = e.element("auth-value") .getTextTrim(); map.put(actionName, auth_value); logger.info(actionName + " is " + auth_value); } return map; } public void doFilter(ServletRequest request, ServletResponse response , FilterChain chain) throws IOException, ServletException { //處理某次提交的Action,是否在權(quán)限定義范圍內(nèi) //權(quán)限共有:1:站長(zhǎng);2:編輯;0:Admin ; all 代表所有人都可以。(均需要登錄) HttpServletRequest req = (HttpServletRequest) request; HttpServletResponse resp = (HttpServletResponse) response; //(1)得到此次用戶的提交請(qǐng)求 String url = req.getServletPath(); //(2)只有在配置文件中存在的 action 才進(jìn)行處理 String method = req.getParameter("method"); if (method != null) { url = url + "?method=" + method; } String auth_value = (String) actions.get(url); if (auth_value == null) { logger.info("action is not in Manager Auth xml."); chain.doFilter(request, response); return; } /,必須要登錄 // 取得當(dāng)前用戶; User manager = (User) HttpUtils.getAdminUserSession(req); // 檢查管理用戶是否登錄 if (manager == null) { resp.sendRedirect(req.getContextPath() + "/sessionLost.do"); return; } //第二,必須在權(quán)限定義范圍內(nèi) if (auth_value.indexOf("all") >= 0) { chain.doFilter(request, response); //必須返回給上一層。 return; } else { // String currUserAuth = ","+Integer.toString( manager.getLever())+","; String currUserAuth = Integer.toString(manager.getLever()); if (auth_value.indexOf(currUserAuth) >= 0) { chain.doFilter(request, response); //必須返回給上一層。 return; } else { resp.sendRedirect(req.getContextPath() + "/accessdenied.do"); return; } } } public void destroy() { logger.info("in authfilter destroy"); } }
2.xml文件
xml只給出了部分內(nèi)容,不過(guò)所有的內(nèi)容都包括了。
<? xml version = "1.0" encoding = "UTF-8" ? > <!-- 權(quán)限共有:0:Admin 具有所有權(quán)限包括增刪改用戶; 1:站長(zhǎng) ;2:編輯; --> <mapping> <!--xxxx管理模塊xx列表,報(bào)名選手和歷史比賽查詢(xún)部分--> <action name="/listallmatch.do"><auth-value>0,1</auth-value></action> <action name="/matchManager.do"><auth-value>0,</auth-value></action> <action name="/rewrite.do"><auth-value>0,1</auth-value></action> <action name="/leftHome.do"><auth-value>all,</auth-value></action> <action name="/login.do"><auth-value>all,</auth-value></action> </mapping>
3.用戶表里面有一個(gè)用來(lái)保存用戶級(jí)別的字段level,具體用戶表的信息有以下內(nèi)容,我用實(shí)體類(lèi)來(lái)表示用戶表的信息,因?yàn)闆](méi)有表結(jié)構(gòu)了。
private String id; private String userId; private String username; private String password; private int lever = 1; private Date createDate;
所有的操作都顯示在頁(yè)面上,當(dāng)點(diǎn)擊該操作時(shí),才進(jìn)行權(quán)限控制,拋出是否該用戶有沒(méi)有該功能的權(quán)限。
第二種方式:利用專(zhuān)門(mén)的權(quán)限表來(lái)維護(hù)用戶權(quán)限,根據(jù)登錄的用戶的權(quán)限信息判斷謀個(gè)功能是否顯示在頁(yè)面上,來(lái)實(shí)現(xiàn)權(quán)限的控制。
1.不用數(shù)據(jù)庫(kù)表了,我用實(shí)體類(lèi)的屬性來(lái)表示。
private String id; private String employeeid; private String urlid; private String urlname;
超級(jí)管理員給每一個(gè)用戶分配權(quán)限,然后添加到該張表中。登錄用戶根據(jù)自己的權(quán)限可以判斷是否顯示該功能。
java實(shí)現(xiàn)權(quán)限管理的方法就是以上兩種方法,大家可以參考任意一種,根據(jù)自己的具體需求去選擇方法哦!最后大家如果想要了解更多java初識(shí)知識(shí),敬請(qǐng)關(guān)注賦能網(wǎng)。
本文鏈接:
本文章“java權(quán)限管理怎么實(shí)現(xiàn)?具體操作”已幫助 68 人
免責(zé)聲明:本信息由用戶發(fā)布,本站不承擔(dān)本信息引起的任何交易及知識(shí)產(chǎn)權(quán)侵權(quán)的法律責(zé)任!
本文由賦能網(wǎng) 整理發(fā)布。了解更多培訓(xùn)機(jī)構(gòu)》培訓(xùn)課程》學(xué)習(xí)資訊》課程優(yōu)惠》課程開(kāi)班》學(xué)校地址等機(jī)構(gòu)信息,可以留下您的聯(lián)系方式,讓課程老師跟你詳細(xì)解答:
咨詢(xún)熱線:4008-569-579