<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 3, comments - 15, trackbacks - 0, articles - 26
      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
    關(guān)鍵詞 : servlet listener timer 定時(shí)器

    從作用域范圍來說,Servlet的作用域有ServletContext,HttpSession,ServletRequest.

    Context范圍:
        
    ServletContextListener:
    對一個(gè)應(yīng)用進(jìn)行全局監(jiān)聽.隨應(yīng)用啟動(dòng)而啟動(dòng),隨應(yīng)用消失而消失主要有兩個(gè)方法:
    contextDestroyed(ServletContextEvent event) 
     在應(yīng)用關(guān)閉的時(shí)候調(diào)用
    contextInitialized(ServletContextEvent event) 
    在應(yīng)用啟動(dòng)的時(shí)候調(diào)用

    這個(gè)監(jiān)聽器主要用于一些隨著應(yīng)用啟動(dòng)而要完成的工作,也就是很多人說的我想在容器
    啟動(dòng)的時(shí)候干..........
    一般來說對"全局變量"初始化,如
    public void contextInitialized(ServletContextEvent event){
        ServletContex sc = event.getServletContext();
        sc.setAttribute(name,value);
    }
    以后你就可以在任何servlet中g(shù)etServletContext().getAttribute(name);
    我最喜歡用它來做守護(hù)性工作,就是在contextInitialized(ServletContextEvent event) 
    方法中實(shí)現(xiàn)一個(gè)Timer,然后就讓應(yīng)用在每次啟動(dòng)的時(shí)候讓這個(gè)Timer工作:
    public void contextInitialized(ServletContextEvent event){
        timer = new Timer();
        timer.schedule(new TimerTask(){
            public void run(){
                //do any things
            }
        },0,時(shí)間間隔);
    }

        有人說Timer只能規(guī)定從現(xiàn)在開始的多長時(shí)間后,每隔多久做一次事或在什么時(shí)間做
    一次事,那我想在每月1號(hào)或每天12點(diǎn)做一項(xiàng)工作如何做呢?
    你只要設(shè)一個(gè)間隔,然后每次判斷一下當(dāng)時(shí)是不是那個(gè)時(shí)間段就行了啊,比如每月一號(hào)做,那你
    時(shí)間間隔設(shè)為天,即24小時(shí)一個(gè)循環(huán),然后在run方法中判斷當(dāng)時(shí)日期new Date().getDate()==1
    就行了啊.如果是每天的12點(diǎn),那你時(shí)間間隔設(shè)為小時(shí),然后在run中判斷new Date().getHour()
    ==12,再做某事就行了.

    ServletContextAttributeListener:

    這個(gè)監(jiān)聽器主要監(jiān)聽ServletContex對象在setAttribute()和removeAttribute()的事件,注意
    也就是一個(gè)"全局變量"在被Add(第一次set),replace(對已有的變量重新賦值)和remove的時(shí)候.
    分別調(diào)用下面三個(gè)方法:
    public void attributeAdded(ServletContextAttributeEvent scab)這個(gè)方法不僅可以知道
    哪些全局變量被加進(jìn)來,而且可獲取容器在啟動(dòng)時(shí)自動(dòng)設(shè)置了哪些context變量:

    public void attributeAdded(ServletContextAttributeEvent scab){
        System.out.println(scab.getName());
    }
      public void attributeRemoved(ServletContextAttributeEvent scab) 

      public void attributeReplaced(ServletContextAttributeEvent scab) 
      
      








    Session范圍:
    HttpSessionListener:
    這個(gè)監(jiān)聽器主要監(jiān)聽一個(gè)Session對象被生成和銷毀時(shí)發(fā)生的事件.對應(yīng)有兩個(gè)方法:
      public void sessionCreated(HttpSessionEvent se) 

      public void sessionDestroyed(HttpSessionEvent se)

      一般來說,一個(gè)session對象被create時(shí),可以說明有一個(gè)新客端進(jìn)入.可以用來粗略統(tǒng)計(jì)在線人
    數(shù),注意這不是精確的,因?yàn)檫@個(gè)客戶端可能立即就關(guān)閉了,但sessionDestroyed方法卻會(huì)按一定
    的策略很久以后才會(huì)發(fā)生.

    HttpSessionAttributeListener:
    和ServletContextAttributeListener一樣,它監(jiān)聽一個(gè)session對象的Attribut被Add(一個(gè)特定
    名稱的Attribute每一次被設(shè)置),replace(已有名稱的Attribute的值被重設(shè))和remove時(shí)的事件.
    對就的有三個(gè)方法.
      public void attributeAdded(HttpSessionBindingEvent se) 

      public void attributeRemoved(HttpSessionBindingEvent se) 

      public void attributeReplaced(HttpSessionBindingEvent se) 

      上面的幾個(gè)監(jiān)聽器的方法,都是在監(jiān)聽?wèi)?yīng)用邏輯中servlet邏輯中發(fā)生了什么事,一般的來說.
    我們只要完成邏輯功能,比如session.setAttribute("aaa","111");我只要把一個(gè)名為aaa的變量
    放在session中以便以后我能獲取它,我并不關(guān)心當(dāng)session.setAttribute("aaa","111");發(fā)生時(shí)
    我還要干什么.(當(dāng)然有些時(shí)候要利用的),但對于下面這個(gè)監(jiān)聽器,你應(yīng)該好好發(fā)解一下:

    HttpSessionBindingListener:
    上面的監(jiān)聽器都是作為一個(gè)獨(dú)立的Listener在容器中控制事件的.而HttpSessionBindingListener
    對在一對象中監(jiān)聽該對象的狀態(tài),實(shí)現(xiàn)了該接口的對象如果被作為value被add到一個(gè)session中或從
    session中remove,它就會(huì)知道自己已經(jīng)作為一個(gè)session對象或已經(jīng)從session刪除,這對于一些非
    純JAVA對象,生命周期長于session的對象,以及其它需要釋放資源或改變狀態(tài)的對象非常重要.
    比如:
    session.setAttribute("abcd","1111");
    以后session.removeAttribute("abcd");因?yàn)閍bcd是一個(gè)字符中,你從session中remove后,它就會(huì)
    自動(dòng)被垃圾回收器回收,而如果是一個(gè)connection:(只是舉例,你千萬不要加connection往session
    中加入)
    session.setAttribute("abcd",conn);
    以后session.removeAttribute("abcd");這時(shí)這個(gè)conn被從session中remove了,你已經(jīng)無法獲取它
    的句柄,所以你根本沒法關(guān)閉它.而在沒有remove之前你根本不知道什么時(shí)候要被remove,你又無法
    close(),那么這個(gè)connection對象就死了.另外還有一些對象可以在被加入一個(gè)session時(shí)要鎖定
    還要被remove時(shí)要解鎖,應(yīng)因你在程序中無法判斷什么時(shí)候被remove(),add還好操作,我可以先加鎖
    再add,但remove就后你就找不到它的句柄了,根本沒法解鎖,所以這些操作只能在對象自身中實(shí)現(xiàn).
    也就是在對象被add時(shí)或remove時(shí)通知對象自己回調(diào)相應(yīng)的方法:

    MyConn extends Connection implements HttpSessionBindingListener{
      public void valueBound(HttpSessionBindingEvent se){
        this.initXXX();
      }
      public void valueUnbound(HttpSessionBindingEvent se){

        this.close();
      }
    }

    session.setAttribute("aaa",new MyConn());
    這時(shí)如果調(diào)用session.removeAttribute("aaa"),則觸發(fā)valueUnbound方法,就會(huì)自動(dòng)關(guān)閉自己.
    而其它的需要改變狀態(tài)的對象了是一樣.

    另外還有一個(gè)HttpSessionActivationListener監(jiān)聽器是實(shí)現(xiàn)分布式應(yīng)用中session同步的.不作
    多介紹,如果有要實(shí)現(xiàn)該功能的朋友可以和我聯(lián)系.




    在servlet2.4中,對于request范圍已經(jīng)實(shí)現(xiàn)對應(yīng)的監(jiān)聽器:
    ServletRequestListener,ServletRequestAttributeListener


    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 99在线免费观看视频| 亚洲一本综合久久| 性做久久久久久久免费看| 国产久爱免费精品视频| 亚洲日本成本人观看| 久久亚洲熟女cc98cm| 亚洲午夜久久久久久噜噜噜| 日本免费一区尤物| 无码人妻一区二区三区免费手机| 国产真人无码作爱视频免费| 日本精品久久久久久久久免费 | 18禁亚洲深夜福利人口| 亚洲午夜久久久精品电影院| 亚洲男人的天堂在线播放| 国产av无码专区亚洲国产精品| 成年男女免费视频网站| 四虎永久在线观看免费网站网址 | 亚洲国产精品va在线播放| 亚洲女人被黑人巨大进入| 日韩成人免费aa在线看| 暖暖免费高清日本一区二区三区 | 精品亚洲456在线播放| 亚洲精品视频久久| 老色鬼久久亚洲AV综合| 无码专区—VA亚洲V天堂| 亚洲av最新在线网址| 亚洲s色大片在线观看| 亚洲av午夜福利精品一区| 国产亚洲成av片在线观看| 国产亚洲精品自在久久| 国产亚洲精久久久久久无码| 亚洲国产三级在线观看| 亚洲精品国产精品乱码在线观看| 亚洲无码在线播放| 亚洲免费精彩视频在线观看| 亚洲理论精品午夜电影| 亚洲国产成人91精品| 亚洲中文字幕乱码一区| 日韩亚洲综合精品国产| 人妻巨大乳hd免费看| 久久久久久久国产免费看|