亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cachefilehandler.java

?? iiitAccessServer是一個用Java編寫的基于規則的企業鑒別系統。它作為一個服務器工作
?? JAVA
字號:
/******************************************************************************* * Copyright (C) 2002, 2003 * ingenieurbuero fuer innovative informationstechnik (iiit) * Dipl.-Ing. Joerg Beckmann, Dortmund, Germany * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. *  * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. *  * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. * * version $Id: CacheFileHandler.java,v 1.20 2003/04/14 20:40:48 joerg Exp $ ******************************************************************************/package de.iiit.access.server.plugins.cachemanager;import de.iiit.access.server.*;import de.iiit.access.server.api.*;import de.iiit.access.server.util.*;import de.iiit.access.server.util.db.*;import de.iiit.access.server.util.db.admindb.*;import de.iiit.jdbc.*;import org.apache.log4j.Logger;import java.io.*;import java.util.*;import java.util.regex.*;import java.nio.channels.*;import javax.naming.*;/** This class checks whether there are new LDAP replication records to transfer to * the cache. All records found are written into the todolist in the admin * database. */public class CacheFileHandler extends Thread{    /** CVS Version Tag */    private static final String vcid = "$Id: CacheFileHandler.java,v 1.20 2003/04/14 20:40:48 joerg Exp $";        private static final int sleepTime1 = 10000;    private static final int sleepTime2 = 5000;        private Logger logger = Logger.getLogger(this.getClass());    private JdbcConnectionPool adminPool = null;    private String ldapPersonClass  = null;    private String ldapGroupClass   = null;     private String ldapFormulaClass = null;    private String ldapPersonBase   = null;    private String ldapGroupBase    = null;     private String ldapFormulaBase  = null;    private String replicationFile  = null;        private LdapUtil ldapUtil = null;    private int refreshIntervall;    private CacheManager manager;        private boolean running = true;        /** Creates a new instance of CacheFileHandler     * @param manager The parent CacheManager holding the configuration data etc.     */    public CacheFileHandler(CacheManager manager)    {        setName("CacheFileHandler");        this.manager = manager;        ldapUtil = manager.getLdapUtil();                ldapPersonClass  = ldapUtil.getLdapPersonClass();        ldapGroupClass   = ldapUtil.getLdapGroupClass();         ldapFormulaClass = ldapUtil.getLdapFormulaClass();        ldapPersonBase   = ldapUtil.getLdapPersonBase();        ldapGroupBase    = ldapUtil.getLdapGroupBase();         ldapFormulaBase  = ldapUtil.getLdapFormulaBase();                replicationFile  = manager.replicationFile();        refreshIntervall = manager.refreshIntervall();    }    /** This method is called by the AccessServer when the background threads should     * stop because of a shutdown of the AccessServer itself.     */    public void shutdown()    {        running = false;        interrupt();                if (ldapUtil != null)            ldapUtil.shutdown();    }        private void readReplicationFile(File rft) throws Exception    {        BufferedReader br = new BufferedReader(new FileReader(rft));        if (adminPool == null)        {            adminPool = manager.getAdminPool();        }                    Pattern regex = Pattern.compile(": ");        Hashtable ldapObject = new Hashtable();        Vector v = null;                                    String line = br.readLine();                                    while (line != null)        {                                            // Split on ': '            String parts[] = regex.split(line, 2);            if (parts.length > 1)            {                v = (Vector) ldapObject.get(parts[0]);                                                    if (v == null)                {                    v = new Vector();                    ldapObject.put(parts[0], v);                }                                                    v.add(parts[1]);            }            else if (line.equals("")) // Every block is finished with an empty line             {                String changetype = (String) ((Vector) ldapObject.get("changetype")).get(0);                String dn         = (String) ((Vector) ldapObject.get("dn")).get(0);                                    if (changetype.equals("add"))                                            {                    Vector objectClass = (Vector) ldapObject.get("objectClass");                    if (objectClass.contains(ldapGroupClass) || objectClass.contains(ldapFormulaClass))                    {                        // There must be exactly one cn attribute, otherwise the result is undefined!                        String cn = (String) ((Vector) ldapObject.get("cn")).get(0);                        ToDoList todo = new ToDoList(cn, System.currentTimeMillis(), false);                        todo.insertToDo(adminPool);                    }                }                else if (changetype.equals("modify"))                {                    if (dn.endsWith(ldapGroupBase) || dn.endsWith(ldapFormulaBase))                    {                        String s1[] = dn.split("cn=", 2);                        String s2[] = s1[1].split(",", 2);                        ToDoList todo = new ToDoList(s2[0], System.currentTimeMillis(), false);                        todo.insertToDo(adminPool);                    }                                    }                else if (changetype.equals("delete"))                {                    if (dn.endsWith(ldapGroupBase) || dn.endsWith(ldapFormulaBase))                    {                        String s1[] = dn.split("cn=", 2);                        String s2[] = s1[1].split(",", 2);                        ToDoList todo = new ToDoList(s2[0], System.currentTimeMillis(), false);                        todo.insertToDo(adminPool);                    }                }                else                {                    logger.warn("Unknown changetype <" + changetype + ">");                }                ldapObject = new Hashtable();            }                                            line = br.readLine();        }                    br.close();        rft.delete();    }            /** The main method of the CacheFileHandler thread. */        public void run()    {        String replicationLockFile = replicationFile + ".lock";        String replicationTmpFile  = replicationFile + ".tmp";        File rf  = new File(replicationFile);        File rfl = new File(replicationLockFile);        File rft = new File(replicationTmpFile);        File rfp = rf.getParentFile();                    while(running)        {            try             {                if (rft.exists())                {                    if (! (rft.canRead() && rft.canWrite()))                        logger.error("Can't read and write temporary LDAP replication file <" + replicationTmpFile + ">");                    else                    {                        readReplicationFile(rft);                    }                }                                    try                {                    if (running)                        sleep(refreshIntervall);                }                catch(InterruptedException ie)                {                    // do nothing                }                int sleepTime = sleepTime1;                                                        if (!rfp.exists())                    logger.error("LDAP replication file directory <" + rfp.getAbsolutePath() + "> does not exist");                else if (! (rfp.canRead() && rfp.canWrite()))                    logger.error("Can't read and write LDAP replication file directory <" + rfp.getAbsolutePath() + ">");                else if (!rf.exists())                {                    // Do nothing                    // logger.warn("LDAP replication file <" + replicationFile + "> does not exist");                }                else if (! (rf.canRead() && rf.canWrite()))                    logger.error("Can't read and write LDAP replication file <" + replicationFile + ">");                else if (!rfl.exists())                    logger.warn("LDAP replication lock file <" + replicationLockFile + "> does not exist");                else if (! rf.canWrite())                    logger.error("Can't write LDAP replication lock file <" + replicationLockFile + ">");                else                 {                    sleepTime = 0;                                            if (rf.length() > 0)                    {                        FileOutputStream rfls = new FileOutputStream(rfl);                        FileChannel      rflc = rfls.getChannel();                                            FileLock lock = rflc.lock();                                            if (lock != null)                        {                            rf.renameTo(rft);                                                            lock.release();                        }                        else                            logger.warn("Could not get lock on LDAP replication lock file");                                            rflc.close();                        rfls.close();                    }                }                                    try                {                    if (running && sleepTime > 0)                        sleep(sleepTime);                }                catch(InterruptedException ie)                {                    // do nothing                }            }            catch(JdbcException se)            {                logger.error("Cought SQL error while trying to process replication file <" + replicationFile + ">", se);                try                {                    if (running)                        sleep(sleepTime1);                }                catch(InterruptedException ie)                {                    // do nothing                }            }            catch(Exception e)            {                logger.error("Cought error while trying to process replication file <" + replicationFile + ">", e);                try                {                    if (running)                        sleep(sleepTime1);                }                catch(InterruptedException ie)                {                    // do nothing                }            }        }        running = false;    }}/** * $Log: CacheFileHandler.java,v $ * Revision 1.20  2003/04/14 20:40:48  joerg * Setting name for thread. * * Revision 1.19  2003/04/13 20:28:01  joerg * Package structure modified * * Revision 1.18  2003/04/13 20:16:41  joerg * Package structure modified * * Revision 1.17  2003/02/01 19:29:58  joerg * *** empty log message *** * * Revision 1.16  2003/01/01 21:04:17  joerg * Copyright-Statement aktualisiert * * Revision 1.15  2002/12/27 21:26:20  joerg * Fehlermeldungen geaendert * * Revision 1.14  2002/12/24 21:04:33  joerg * Umbau der Paketstruktur * iiitLdapPlugin integriert * JavaDoc-Kommentare weiter vervollstaendigt. * * Revision 1.13  2002/12/23 11:24:58  joerg * shutdown()-Methode hinzugefuegt. * * Revision 1.12  2002/12/21 19:55:03  joerg * Nicht mehr benoetigte Methoden entfernt, interne Methoden auf * private oder protected geaendert. * JavaDoc Kommentare ergaenzt. * * Revision 1.11  2002/12/19 15:54:33  joerg * Paket umbenannt in iiitLdapPlugin * * Revision 1.10  2002/12/08 19:34:11  joerg * Auskommentierten Code entfernt * * Revision 1.9  2002/12/08 16:37:32  joerg * Aufraeumungsarbeiten nach dem grossen Umbau * * Revision 1.8  2002/12/08 16:09:46  joerg * Paket-Struktur ueberarbeitet * * Revision 1.7  2002/12/08 13:55:31  joerg * Der Zugriff auf das LdapPlugin erfolgt jetzt ueber den CacheManager * und nicht mehr ueber den AccessServer * * Revision 1.6  2002/11/21 21:49:45  joerg * Umstellung auf JdbcConnectionPool * * Revision 1.5  2002/11/20 20:41:29  joerg * Klassen fuer das HAndling der DB-Tabellen in Packages * de.iiit.AccessServer.db.* verschoben * * Revision 1.4  2002/11/20 20:25:49  joerg * Bezuege auf UserList und Kontrollausgaben entfernt * * Revision 1.3  2002/11/18 22:09:00  joerg * CacheManager ausgelagert als PlugIn * * Revision 1.2  2002/11/18 21:21:52  joerg * LDAP-Anbindung auf LdapPlugin umgestellt. * * Revision 1.1  2002/11/18 10:17:49  joerg * Klassen des CacheManagers in eigenes Package verschoben * * Revision 1.2  2002/11/18 10:13:18  joerg * CacheManager ist jetzt vollstaendig implementiert * * Revision 1.1  2002/11/17 22:03:26  joerg * Neue Klassen fuer 2nd-level Cache * */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜激情久久久| 亚洲va韩国va欧美va精品| 中文字幕一区二区在线观看| 丝袜美腿亚洲色图| voyeur盗摄精品| 日韩一级高清毛片| 亚洲精品乱码久久久久久黑人| 日韩高清不卡一区二区| 色综合天天天天做夜夜夜夜做| 日韩区在线观看| 五月天婷婷综合| 972aa.com艺术欧美| 国产午夜精品久久| 久久狠狠亚洲综合| 在线91免费看| 亚洲第四色夜色| 日本高清视频一区二区| 中文字幕一区二| 成人高清伦理免费影院在线观看| 欧美大黄免费观看| 免费看欧美女人艹b| 欧美三级三级三级| 一区二区三区精品在线| 91丝袜美腿高跟国产极品老师| 国产欧美一区二区三区网站| 黑人精品欧美一区二区蜜桃| 欧美大片一区二区| 另类专区欧美蜜桃臀第一页| 日韩一级大片在线| 蜜臀久久99精品久久久久宅男| 91热门视频在线观看| 免费看欧美女人艹b| 欧美专区亚洲专区| 一区二区高清视频在线观看| 色天使色偷偷av一区二区| 亚洲乱码一区二区三区在线观看| 99精品视频在线播放观看| 久久久久久久久久看片| 亚洲精选在线视频| 波波电影院一区二区三区| 国产欧美日韩不卡免费| 成人不卡免费av| 亚洲女爱视频在线| 欧美日韩综合不卡| 美腿丝袜在线亚洲一区| 久久综合色综合88| 成人午夜电影网站| 精品一区二区三区蜜桃| 欧美一区二区在线视频| 久久超碰97中文字幕| 久久久电影一区二区三区| 成人性生交大片免费看视频在线| 中文字幕亚洲不卡| 欧美最猛性xxxxx直播| 天天av天天翘天天综合网色鬼国产| 欧美日韩国产首页| 九九视频精品免费| 亚洲视频狠狠干| 在线成人免费观看| 久久精品国产精品亚洲红杏| 国产午夜精品久久| 欧洲人成人精品| 理论电影国产精品| 国产精品久久久久久户外露出 | 久久这里都是精品| 成+人+亚洲+综合天堂| 亚洲影视在线观看| 亚洲成人自拍网| 欧美日韩国产a| 韩国精品一区二区| 亚洲视频一区二区在线观看| 在线欧美日韩国产| 麻豆91在线看| 亚洲精品日产精品乱码不卡| 日韩免费观看2025年上映的电影| 成熟亚洲日本毛茸茸凸凹| 亚洲va天堂va国产va久| 国产日韩精品久久久| 欧美日韩国产精选| 大胆亚洲人体视频| 毛片不卡一区二区| 亚洲综合色噜噜狠狠| 国产拍欧美日韩视频二区| 欧美三级电影一区| 99精品黄色片免费大全| 国产中文字幕精品| 午夜av区久久| 一区二区在线观看视频 | 午夜精品一区二区三区电影天堂 | 欧美日韩不卡一区二区| 国内精品久久久久影院薰衣草| 国产精品成人免费| 日韩欧美一区二区久久婷婷| 91福利视频久久久久| 高清av一区二区| 国产综合色在线视频区| 日本一不卡视频| 洋洋成人永久网站入口| 国产精品久久久久影院亚瑟| 久久人人超碰精品| 欧美一级在线观看| 欧美日韩黄色影视| 欧洲一区在线观看| av成人老司机| 成人黄色综合网站| 国产sm精品调教视频网站| 精品亚洲国产成人av制服丝袜| 日韩成人午夜电影| 精久久久久久久久久久| 欧美视频日韩视频| 97久久精品人人爽人人爽蜜臀| 国产另类ts人妖一区二区| 国产精品综合av一区二区国产馆| 午夜精品视频在线观看| 亚洲国产日韩一区二区| 亚洲精品成人a在线观看| 亚洲人成网站在线| 一区二区三区中文免费| 亚洲精品免费看| 一区二区三区久久| 亚洲va欧美va国产va天堂影院| 亚洲国产视频直播| 婷婷国产v国产偷v亚洲高清| 日韩中文字幕av电影| 麻豆精品一区二区| 国内外精品视频| 国产98色在线|日韩| 成人av中文字幕| 色94色欧美sute亚洲线路一ni | 91性感美女视频| 日本韩国欧美一区| 7777女厕盗摄久久久| 日韩一区二区不卡| 久久久久久**毛片大全| 国产情人综合久久777777| 国产精品电影一区二区| 亚洲精品成a人| 日本午夜精品视频在线观看| 久久不见久久见免费视频7| 成人综合在线网站| 色噜噜狠狠色综合欧洲selulu| 欧美日本国产一区| 亚洲精品一区二区三区影院| 国产精品私人自拍| 亚洲成人精品一区二区| 国产一区二区三区四区五区美女| 成人伦理片在线| 欧美日韩亚洲高清一区二区| 欧美精品一区男女天堂| 国产在线不卡一卡二卡三卡四卡| 日韩av不卡在线观看| 精品在线观看视频| a美女胸又www黄视频久久| 欧美巨大另类极品videosbest | 五月综合激情日本mⅴ| 久久不见久久见免费视频7| av电影一区二区| 欧美成人女星排行榜| 成人欧美一区二区三区在线播放| 亚洲成人动漫在线免费观看| 国产精品99精品久久免费| 欧美日韩一区高清| 亚洲国产成人自拍| 美女视频网站久久| 在线观看91精品国产入口| 久久久夜色精品亚洲| 亚洲二区视频在线| 不卡大黄网站免费看| 欧美一区二区三级| 亚洲精品一卡二卡| 国产成人在线观看| 日韩欧美中文一区| 亚洲午夜精品在线| 99国内精品久久| 久久一区二区三区四区| 偷拍亚洲欧洲综合| 在线观看免费亚洲| 亚洲欧洲成人自拍| 成人在线视频首页| 久久综合九色欧美综合狠狠| 丝袜美腿亚洲综合| 欧美日韩免费观看一区三区| 亚洲人妖av一区二区| 成人性生交大合| 久久久噜噜噜久久中文字幕色伊伊 | 7777精品伊人久久久大香线蕉超级流畅| 国产亚洲污的网站| 麻豆精品国产传媒mv男同| 欧美影院精品一区| 亚洲美女在线一区| 99国产精品一区| 美国毛片一区二区三区| 欧美日韩中文国产| 亚洲一区二区三区三| 91亚洲国产成人精品一区二区三 | 日韩一区二区影院| 午夜精品久久久久久久99樱桃| 日本丶国产丶欧美色综合| 亚洲人成网站在线| 在线观看成人小视频|