监听_监听网卡 - CSDN
精华内容
参与话题
  • JAVA监听

    万次阅读 2018-08-15 00:45:49
    作为JAVA开发人员,我们应对javaweb的三个技术要点之一的Listener进行学习,楼主查阅相关资料并学习相关视频,总结如下JAVA监听器内容,供大家参考学习。完整代码内容我已放到我的github中,请自行下载:...

    作为JAVA开发人员,我们应对javaweb的三个技术要点之一的Listener进行学习,楼主查阅相关资料并学习相关视频,总结如下JAVA监听器内容,供大家参考学习。完整代码内容我已放到我的github中,请自行下载:https://github.com/Mr-WangZhe/Java-Listener“>JAVA Listener学习

    一.监听器Listener

    1.什么是监听器

    • 监听器就是监听某个域对象的的状态变化的组件
    • 监听器的相关概念:
      • 事件源:被监听的对象(三个域对象 request、session、servletContext)
      • 监听器:监听事件源对象事件源对象的状态的变化都会触发监听器(6+2)
      • 注册监听器:将监听器与事件源进行绑定
      • 响应行为:监听器监听到事件源的状态变化时所涉及的功能代码(程序员编写代码)

    2.监听器有哪些

    • 第一维度按照被监听的对象划分:ServletRequest域、HttpSession域、ServletContext域
    • 第二维度按照监听的内容分:监听域对象的创建与销毁的、监听域对象的属性变化的

    这里写图片描述

    3.监听三大域对象的创建与销毁的监听器

    • 监听器的编写步骤(重点):

      • 编写一个监听器类去实现监听器接口
      • 覆盖监听器的方法
      • 需要在web.xml中进行配置—注册
    • 监听ServletContext域的创建与销毁的监听器ServletContextListener

      • Servlet域的生命周期

        • 何时创建:服务器启动创建
        • 何时销毁:服务器关闭销毁
      • ServletContextListener监听器的主要作用

        • 初始化的工作:初始化对象、初始化数据(加载数据库驱动、连接池的初始化)
        • 加载一些初始化的配置文件(spring的配置文件)
        • 任务调度(定时器—Timer/TimerTask)
      • 实例应用:

      • 整体流程:create包下创建MyServletContextListener类实现ServletContextListener接口并覆盖方法public void contextInitialized(ServletContextEvent arg0)监听context域对象的创建;覆盖方法public void contextDestroyed(ServletContextEvent arg0)监听context域对象的销毁。并在web.xml中通过<listener>中的<listener-class>书写监听器全类名配置。

      • 实现任务调度(即定时器)的思路:使用Timer类对象的scheduleAtFixedRate(task,firstTime,period)方法第一个参数书写TimerTask()的匿名内部类重写run方法从而实现调度任务内容;firstTime是Date类型对象,我们可以设置成当前晚上12点;period是间隔执行时间(单位毫秒),我们可以设置成24小时。从而实现从当前晚上12点开始,每24小时都执行对应的调度任务。

      • 实例代码:

        //web.xml
        <?xml version="1.0" encoding="UTF-8"?>
        <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
        <!-- 注册监听器 -->
        <listener>
            <listener-class>create.MyServletContextListener</listener-class>
        </listener>
        <display-name>WEB23_LISTENER</display-name>
        <welcome-file-list>
          <welcome-file>index.jsp</welcome-file>
        </welcome-file-list>
        </web-app>
        
        //MyServletContextListener.java
        package create;
        import java.text.ParseException;
        import java.text.SimpleDateFormat;
        import java.util.Date;
        import java.util.Timer;
        import java.util.TimerTask;
        import javax.servlet.ServletContext;
        import javax.servlet.ServletContextEvent;
        import javax.servlet.ServletContextListener;
        public class MyServletContextListener implements ServletContextListener{
        //监听context域对象的创建
        @Override
        public void contextInitialized(ServletContextEvent arg0) {//参数可以获得被监听的对象
        //        ServletContext servletContext1 = arg0.getServletContext();//返回值是被监听的对象
        //        Object servletContext2 = arg0.getSource();//等同于arg0.getServletContext(),获得的是Object类型,但实际上也是获得被监听的对象
        //        System.out.println("context创建了...");
            //开启一个计息任务调度——每天晚上12点计息一次
            Timer timer = new Timer();
            //task任务,firstTime第一次执行的时间,period间隔执行的时间(单位毫秒)
            //timer.scheduleAtFixedRate(task, firstTime, period);
            //测试demo:从服务器启动开始每隔5秒打印“银行计息了”
        //        timer.scheduleAtFixedRate(new TimerTask() {
        //            @Override
        //            public void run() {
        //                System.out.println("银行计息了...");
        //            }
        //        }, new Date(), 5000);
            //实际银行计息业务
            //1.起始时间,定义成晚上12点
            //2.间隔时间:24小时
            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
            String currentTime = "2018-08-15 00:00:00";
            Date date = null;
            try {
                date = format.parse(currentTime);
            } catch (ParseException e) {
                e.printStackTrace();
            }
            timer.scheduleAtFixedRate(new TimerTask() {
                @Override
                public void run() {
                    System.out.println("银行计息了...");
                }
            }, date, 24*60*60*1000);
        }
        //监听context域对象的销毁
        @Override
        public void contextDestroyed(ServletContextEvent arg0) {
            System.out.println("context销毁了...");
        }
        }
    • 监听Httpsession域的创建于销毁的监听器HttpSessionListener

      • HttpSession对象的生命周期

        • 何时创建:第一次调用request.getSession时创建
        • 何时销毁:服务器关闭销毁、session过期(默认30分钟,修改默认的30分钟是在Tomcat的web.xml,修改当前项目的过期时间是在自己项目的web.xml中)、手动销毁
      • HttpSessionListener监听器的主要作用:

        • 由于每次访问网站都会默认创建session对象(jsp页面中page指令中的session属性默认为true,即被访问时创建session),可以用于计数网站访问过的人
      • 实例应用:

        • 整体流程:创建MyHttpSessionListener类实现HttpSessionListener接口并覆盖public void sessionCreated(HttpSessionEvent arg0)public void sessionDestroyed(HttpSessionEvent arg0)方法。并在web.xml中注册该listener,和index.jsp页面。每当访问一次index页面,即会调用一次sessionCreated方法。

        • 实例代码:

        //web.xml
        <?xml version="1.0" encoding="UTF-8"?>
        <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
        <!-- 注册监听器 -->
        <listener>
            <listener-class>create.MyHttpSessionListener</listener-class>
        </listener>
        <display-name>WEB23_LISTENER</display-name>
        <welcome-file-list>
          <welcome-file>index.jsp</welcome-file>
        </welcome-file-list>
        </web-app>
        
        //MyHttpSessionListener.java
        package create;
        import javax.servlet.http.HttpSessionEvent;
        import javax.servlet.http.HttpSessionListener;
        public class MyHttpSessionListener implements HttpSessionListener{
        @Override
        public void sessionCreated(HttpSessionEvent arg0) {
            //获得Session对象的方法arg0.getSession()
            String id = arg0.getSession().getId();
            System.out.println("session创建"+id);
        
        }
        @Override
        public void sessionDestroyed(HttpSessionEvent arg0) {
            System.out.println("session销毁");
        
        }
        }
        
        //index.jsp
        <%@ page language="java" contentType="text/html; charset=UTF-8"
          pageEncoding="UTF-8"%>
        <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
        <html>
        <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>Insert title here</title>
        </head>
        <body>
        index.jsp
        </body>
        </html>
    • 监听ServletRequest域创建与销毁的监听器ServletRequestListener

      • ServletRequest的生命周期
        • 创建:每一次请求都会创建request
        • 销毁:请求结束
      • 用法同上,用处不是很大,此处省略。

    4.监听三大域对象的属性变化的

    • 域对象的通用的方法:

      • setAttribute(name,value)
        • 触发添加属性的监听器的方法
        • 触发修改属性的监听器的方法
      • getAttribute(name)
      • removeAttribute(name)
        • 触发删除属性的监听器的方法
    • ServletContextAttibuteListener监听器

      • 整体使用流程:定义类MyServeltContextAttributeListener实现ServeltContextAttributeListener接口并覆盖public void attributeAdded(ServletContextAttributeEvent arg0) ;public void attributeRemoved(ServletContextAttributeEvent arg0);public void attributeReplaced(ServletContextAttributeEvent arg0)三个方法。在attributeAdded方法中的参数传递的ServletContextAttributeEvent实例对象中,调用getName方法获取放到域中的name,调用getValue方法获取放到域中的value;在attributeRemoved方法中的参数传递的ServletContextAttributeEvent实例对象中,调用getName方法获取被删除的域中的name,调用getValue方法获取被删除的域中的value;在attributeReplaced 方法中的参数传递的ServletContextAttributeEvent实例对象中,调用getName方法获取修改前的域中的name,调用getValue方法获取修改前的域中的value。并在web.xml中注册监听器。

      • 实例代码:

      //MyServletContextAttributeLister.java
      package attribute;
      import javax.servlet.ServletContextAttributeEvent;
      import javax.servlet.ServletContextAttributeListener;
      public class MyServletContextAttributeListener implements ServletContextAttributeListener{
          @Override
          public void attributeAdded(ServletContextAttributeEvent arg0) {
              //添加属性时的监听方法
              System.out.println(arg0.getName());//获得放到域中的name
              System.out.println(arg0.getValue());//获得放到域中的value
          }
          @Override
          public void attributeRemoved(ServletContextAttributeEvent arg0) {
              //移除属性时的监听方法
              System.out.println(arg0.getName());//删除的域中的name
              System.out.println(arg0.getValue());//删除的域中的value
          }
          @Override
          public void attributeReplaced(ServletContextAttributeEvent arg0) {
              //修改属性时的监听方法
              System.out.println(arg0.getName());//获得修改前的域中的name
              System.out.println(arg0.getValue());//获得修改前的域中的value
          }
      }
      
      //web.xml
      <?xml version="1.0" encoding="UTF-8"?>
      <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
        <listener>
          <listener-class>attribute.MyServletContextAttributeListener</listener-class>
        </listener>
        <display-name>WEB23_LISTENER</display-name>
        <welcome-file-list>
          <welcome-file>index.jsp</welcome-file>
        </welcome-file-list>
        <servlet>
          <description></description>
          <display-name>TestMyServletContextAttributeListener</display-name>
          <servlet-name>TestMyServletContextAttributeListener</servlet-name>
          <servlet-class>attribute.TestMyServletContextAttributeListener</servlet-class>
        </servlet>
        <servlet-mapping>
          <servlet-name>TestMyServletContextAttributeListener</servlet-name>
          <url-pattern>/test1</url-pattern>
        </servlet-mapping>
      </web-app>
      
      //用于测试的接口TestMyServletContextAttributeListener.java
      package attribute;
      import java.io.IOException;
      import javax.servlet.ServletContext;
      import javax.servlet.ServletException;
      import javax.servlet.http.HttpServlet;
      import javax.servlet.http.HttpServletRequest;
      import javax.servlet.http.HttpServletResponse;
      public class TestMyServletContextAttributeListener extends HttpServlet {
          public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
              ServletContext context = this.getServletContext();
              //向context域中存数据
              context.setAttribute("name", "tom");
              //改context数据
              context.setAttribute("name", "lucy");
              //删context数据
              context.removeAttribute("name");
          }
          public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
              doGet(request, response);
          }
      }

      当调用context.setAttribute(“name”, “tom”)时打印name tom;当调用context.setAttribute(“name”, “lucy”)时打印name tom;当调用context.removeAttribute(“name”)时打印name lucy。

    • HttpSessionAttributeListener监听器(同上)

    • ServletRequestAriibuteListenr监听器(同上)

    5.与session中的绑定的对象相关的监听器(对象感知监听器)

    • 即将要被绑定到session中的对象有几种状态

      • 绑定状态:就一个对象被放到session域中(setAttribute)

      • 解绑状态:就是这个对象从session域中移除了(removeAttribute)

      • 钝化状态:是将session内存中的对象持久化(序列化)到磁盘

      • 活化状态:就是将磁盘上的对象再次恢复到session内存中(注意对象必须实现Serializable

      接口)

    • 绑定与解绑的监听器HttpSessionBindingListener(绑在对象上的,且不用在web.xml配置

      • 流程:创建对象实现HttpSessionBindingListener 接口中的public void valueBound(HttpSessionBindingEvent arg0)(绑定的方法,将对象放到session时触发)和public void valueUnbound(HttpSessionBindingEvent arg0)(解绑的方法,将对象从session中移除时触发)。

      • 实例代码:

      //Person.java创建Person类
      package domian;
      import javax.servlet.http.HttpSessionBindingEvent;
      import javax.servlet.http.HttpSessionBindingListener;
      public class Person implements HttpSessionBindingListener{
          private String id;
          private String name;
          public String getId() {
              return id;
          }
          public void setId(String id) {
              this.id = id;
          }
          public String getName() {
              return name;
          }
          public void setName(String name) {
              this.name = name;
          }
          @Override
          public String toString() {
              return "Person [id=" + id + ", name=" + name + "]";
          }
          public Person(String id, String name) {
              super();
              this.id = id;
              this.name = name;
          }
          public Person() {
              super();
          }
          @Override
          public void valueBound(HttpSessionBindingEvent arg0) {
              // 绑定的方法,将person对象放到session时触发
              System.out.println("Person被绑定");
          }
          @Override
          public void valueUnbound(HttpSessionBindingEvent arg0) {
              // 解绑的方法,将person对象从session移除时触发
              System.out.println("Person被解绑");
          }
      }
      
      //TestPersonBindingServlet.java
      package domian;
      import java.io.IOException;
      import javax.servlet.ServletException;
      import javax.servlet.http.HttpServlet;
      import javax.servlet.http.HttpServletRequest;
      import javax.servlet.http.HttpServletResponse;
      import javax.servlet.http.HttpSession;
      public class TestPersonBindingServlet extends HttpServlet {
          public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
              HttpSession session = request.getSession();
              //将person对象绑定到session中
              Person p = new Person("100","jack");
              session.setAttribute("person",p);
              //将person对象从session中解绑
              session.removeAttribute("person");
          }
          public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
              doGet(request, response);
          }
      }

      当访问接口时,代码执行到session.setAttribute("person",p);时输出Person被绑定;代码执行到session.removeAttribute("person");时输出Person被解绑。

    • 钝化与活化的监听器HttpSessionActivationListener 【重要:用于服务器优化】

      • 默认:实现了HttpSessionActivationListener(覆盖其中的public void sessionDidActivate(HttpSessionEvent arg0)public void sessionWillPassivate(HttpSessionEvent arg0)方法)和Serializable接口(注意必须实现Serializable接口)的对象,被放入到session后,当服务器stop时,session会被钝化到work/catalina/localhost中命名为SESSIONS.ser;当服务器start时,session会被活化到session域中。

      • 手动设置钝化时间和存储位置(通过配置文件指定对象钝化时间—对象多长时间不用被钝化):

        • 在META-INF下创建一个context.xml

        • context.xml中的代码:

        <?xml version="1.0" encoding="UTF-8"?>
        <Context>
        <!-- maxIdleSwap:session中的对象多长时间不使用就钝化(单位:分钟),注意钝化和销毁的概念完全不同 -->
        <!-- directory:钝化后的对象的文件写到磁盘的哪个目录下配置钝化的对象文件在 work/catalina/localhost/钝化文件 -->
        <Manager className="org.apache.catalina.session.PersistentManager" maxIdleSwap="1"><!-- Manager是处理内容的对象 -->
            <Store className="org.apache.catalina.session.FileStore" directory="storeFile" /><!-- Store是做存储的对象 -->
        </Manager>
        </Context>
      • 实例代码:

      //Customer.java
      package domian;
      import java.io.Serializable;
      import javax.servlet.http.HttpSessionActivationListener;
      import javax.servlet.http.HttpSessionEvent;
      public class Customer implements HttpSessionActivationListener,Serializable{
          private String id;
          private String name;
          public String getId() {
              return id;
          }
          public void setId(String id) {
              this.id = id;
          }
          public String getName() {
              return name;
          }
          public void setName(String name) {
              this.name = name;
          }
          @Override
          public String toString() {
              return "Customer [id=" + id + ", name=" + name + "]";
          }
          public Customer(String id, String name) {
              super();
              this.id = id;
              this.name = name;
          }
          public Customer() {
              super();
          }
          @Override
          public void sessionDidActivate(HttpSessionEvent arg0) {
              //活化
              System.out.println("customer被活化了");
          }
          @Override
          public void sessionWillPassivate(HttpSessionEvent arg0) {
              //钝化
              System.out.println("customer被钝化了");
          }
      }
      
      //TestCustomerActiveServlet.java 用于将customer对象放至session中
      package domian;
      import java.io.IOException;
      import javax.servlet.ServletException;
      import javax.servlet.http.HttpServlet;
      import javax.servlet.http.HttpServletRequest;
      import javax.servlet.http.HttpServletResponse;
      import javax.servlet.http.HttpSession;
      public class TestCustomerActiveServlet extends HttpServlet {
          public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
              HttpSession session = request.getSession();
              //将customer放到session中
              Customer customer = new Customer("200","lucy");
              session.setAttribute("customer", customer);
              System.out.println("customer被放到session中");
          }
          public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
              doGet(request, response);
          }
      }
      
      //TestCustomerActiveServlet2 用于测试session对象是否被活化
      package domian;
      import java.io.IOException;
      import javax.servlet.ServletException;
      import javax.servlet.http.HttpServlet;
      import javax.servlet.http.HttpServletRequest;
      import javax.servlet.http.HttpServletResponse;
      import javax.servlet.http.HttpSession;
      public class TestCustomerActiveServlet2 extends HttpServlet {
          public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
              HttpSession session = request.getSession();
              //从session域中获取customer
              Customer customer = (Customer)session.getAttribute("customer");
              System.out.println(customer.getName());
          }
          public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
              doGet(request, response);
          }
      }
    • 面试题:当用户很多时,怎样对服务器进行优化?

      通过session的钝化与活化,将长期不操作的session内存中的对象持久化到磁盘,为服务器腾出空间,等到用户再次开始操作时将磁盘上的对象恢复到session内存中。

    二.邮箱服务器

    1.邮箱服务器的基本概念

    • 邮件的客户端:可以只安装在电脑上的也可以是网页形式的

    • 邮件服务器:起到邮件的接受与推送的作用

    • 邮件发送的协议:

      • 协议:就是数据传输的约束
      • 接受邮件的协议:POP3、 IMAP
      • 发送邮件的协议:SMTP
    • 邮箱服务器地址

    这里写图片描述

    2.邮件发送过程

    这里写图片描述

    ​ 过程描述:如果想利用163客户端发送邮件给腾讯邮箱用户,需要先发送给网易邮箱服务器(采用SMTP协议),网易邮箱服务器的SMTP推送给腾讯邮箱服务器的SMTP协议,腾讯邮箱服务器的SMTP将接受到的邮件存储到一个公共区域。当腾讯客户端用户想要接收邮件时,需要发请求给腾讯邮箱服务器(采用POP3协议),该请求会到公共区域取邮件,返回给用户。

    3.邮箱服务器的安装

    • 安装使用易邮邮件服务器
    • 工具 —> 服务器设置 ->设置单域名如jack.com,即用户名为:用户名@jack.com
    • 新账号 —> 输入账号和密码 —> 点击确认即创建用户

    4.邮箱客户端的安装

    • 安装Foxmail
    • 邮箱 —> 新建邮箱账户 —> 写上方的电子邮件及密码并点击next —> 设置接受邮件服务器ip和发送ip均为localhost(本机测试使用)
    • 新建两个用户可以互相发邮件,接受邮件即可
    • 注意:想要接受时需要点击收邮件,因为客户端不是实时刷新的,是固定时间一刷新

    5.使用程序发送邮件

    • 使用mail.jar,内部就有发邮件的API

    • 使用MailUtils.java工具类实现发邮件的功能【开发时直接使用即可,不需要背】

      • 邮件发送流程
        • 创建一个程序与邮件服务器会话对象Session
        • 创建一个Message,它相当于是邮件内容
        • 创建Transport用于将邮件发送
      • 工具代码:
      package mail;
      import java.util.Properties;
      import javax.mail.Authenticator;
      import javax.mail.Message;
      import javax.mail.MessagingException;
      import javax.mail.PasswordAuthentication;
      import javax.mail.Session;
      import javax.mail.Transport;
      import javax.mail.internet.AddressException;
      import javax.mail.internet.InternetAddress;
      import javax.mail.internet.MimeMessage;
      import javax.mail.internet.MimeMessage.RecipientType;
      //邮件工具包
      public class MailUtils {
      //email:邮件发给谁(收件人)  subject:主题  emailMsg:邮件内容
      public static void sendMail(String email,String subject, String emailMsg)
              throws AddressException, MessagingException {
          // 1.创建一个程序与邮件服务器会话对象 Session
          Properties props = new Properties();
          props.setProperty("mail.transport.protocol", "SMTP");//发邮件的协议SMTP
          props.setProperty("mail.host", "192.168.1.109");//发送邮件的服务器地址
          props.setProperty("mail.smtp.auth", "true");// 是否要验证,指定验证为true
          // 创建验证器
          Authenticator auth = new Authenticator() {
              public PasswordAuthentication getPasswordAuthentication() {
                  return new PasswordAuthentication("sam", "111111");//发邮件的账号验证
              }
          };
          //此处的session是会话对象
          Session session = Session.getInstance(props, auth);
          // 2.创建一个Message,它相当于是邮件内容
          Message message = new MimeMessage(session);
          message.setFrom(new InternetAddress("sam@wangzhe.com")); // 设置发送者
          message.setRecipient(RecipientType.TO, new InternetAddress(email)); // 设置发送方式与接收者
          message.setSubject(subject);
          message.setContent(emailMsg, "text/html;charset=utf-8");
          // 3.创建Transport用于将邮件发送
          Transport.send(message);
      }
      }
    • 调用邮件工具类发送邮件

      • 实例代码:
      package mail;
      import javax.mail.MessagingException;
      import javax.mail.internet.AddressException;
      public class SendMailTest {
      public static void main(String[] args) throws AddressException, MessagingException {
          MailUtils.sendMail("jack@wangzhe.com", "测试邮件", "这是一封测试邮件");
      }
      }

    三.案例(定时发送生日祝福)

    • Demo应用jar包

      • c3p0-0.9.1.2.jar
      • commons-dbutils-1.4.jar
      • mail.jar
      • mysql-connector-java-5.0.4-bin.jar
    • 项目思路:

      • 在web应用创建后,当日12点开启任务调度,实现给当天生日的用户发送祝福邮件(本项目作为测试阶段,设置自web应用创建后,每隔10秒钟给当日生日的用户发送祝福邮件)
      • 遍历数据库查看当天过生日的人,借助mail.jar提供的API和MailUtils工具发送邮件
    • 代码编写流程:

      • 创建BirthdayListener类实现ServletContextListener,重写对应方法,主要添加contextInitialized()方法中的内容,利用Timer对象的scheduleAtFixedRate()方法开启任务调度,设置第一个参数为调度任务内容,分别是查询数据库当日过生日的人,发送邮件;设置第二个参数为当前时刻,即项目创建时刻起开启任务调度;设置第三个参数为间隔时长(单位毫秒)
      package birthday;
      import java.sql.SQLException;
      import java.text.SimpleDateFormat;
      import java.util.Date;
      import java.util.List;
      import java.util.Timer;
      import java.util.TimerTask;
      import javax.mail.MessagingException;
      import javax.mail.internet.AddressException;
      import javax.servlet.ServletContextEvent;
      import javax.servlet.ServletContextListener;
      import org.apache.commons.dbutils.QueryRunner;
      import org.apache.commons.dbutils.handlers.BeanListHandler;
      import mail.MailUtils;
      public class BirthdayListener implements ServletContextListener{
      @Override
      public void contextDestroyed(ServletContextEvent arg0) {
          //销毁
      }
      @Override
      public void contextInitialized(ServletContextEvent arg0) {
          //当web应用创建开启任务调度——功能在用户生日当天发送邮件
          Timer timer = new Timer();
          timer.scheduleAtFixedRate(new TimerTask() {
              @Override
              public void run() {
                  // 为当天过生日的用户发送邮件
                  //1.获得今天过生日的人
                  SimpleDateFormat format = new SimpleDateFormat("MM-dd");
                  String currentDate = format.format(new Date());
                  System.out.println(currentDate);
                  //根据当前时间到数据库查今天过生日的人
                  QueryRunner runner = new QueryRunner(DataSourceUtils.getDataSource());
                  String sql = "select * from customer where birthday like ?";
                  List<Customer>customerList = null;
                  try {
                      customerList = runner.query(sql, new BeanListHandler<Customer>(Customer.class), "%"+currentDate+"%");
                  } catch (SQLException e) {
                      // TODO Auto-generated catch block
                      e.printStackTrace();
                  }
                  //2.发邮件
                  if(customerList!=null&&customerList.size()>0) {
                      for(Customer c :customerList) {
                          String emailMsg = "亲爱的:"+c.getRealname()+"生日快乐!";
                          try {
                              MailUtils.sendMail(c.getEmail(), "生日祝福", emailMsg);
                              System.out.println(c.getRealname()+"邮件发送完毕");
                          } catch (AddressException e) {
                              // TODO Auto-generated catch block
                              e.printStackTrace();
                          } catch (MessagingException e) {
                              // TODO Auto-generated catch block
                              e.printStackTrace();
                          }
                      }
                  }
      
              }
          }, new Date(), 1000*10);
          //实际开发中起始时间是一个固定时间
          //实际开发中间隔时间是1天
      }
      }
    • 开发时应用到Customer实体类进行映射,MailUtils工具发送邮件,web.xml配置监听器

      //Customer.java
      package birthday;
      public class Customer {
      private int id;
      private String username;
      private String password;
      private String realname;
      private String birthday;
      private String email;
      public int getId() {
          return id;
      }
      public void setId(int id) {
          this.id = id;
      }
      public String getUsername() {
          return username;
      }
      public void setUsername(String username) {
          this.username = username;
      }
      public String getPassword() {
          return password;
      }
      public void setPassword(String password) {
          this.password = password;
      }
      public String getRealname() {
          return realname;
      }
      public void setRealname(String realname) {
          this.realname = realname;
      }
      public String getBirthday() {
          return birthday;
      }
      public void setBirthday(String birthday) {
          this.birthday = birthday;
      }
      public String getEmail() {
          return email;
      }
      public void setEmail(String email) {
          this.email = email;
      }
      @Override
      public String toString() {
          return "Customer [id=" + id + ", username=" + username + ", password=" + password + ", realname=" + realname
                  + ", birthday=" + birthday + ", email=" + email + "]";
      }
      public Customer(int id, String username, String password, String realname, String birthday, String email) {
          super();
          this.id = id;
          this.username = username;
          this.password = password;
          this.realname = realname;
          this.birthday = birthday;
          this.email = email;
      }
      public Customer() {
          super();
      }
      }
      
      //MailUtils.java
      package mail;
      import java.util.Properties;
      import javax.mail.Authenticator;
      import javax.mail.Message;
      import javax.mail.MessagingException;
      import javax.mail.PasswordAuthentication;
      import javax.mail.Session;
      import javax.mail.Transport;
      import javax.mail.internet.AddressException;
      import javax.mail.internet.InternetAddress;
      import javax.mail.internet.MimeMessage;
      import javax.mail.internet.MimeMessage.RecipientType;
      //邮件工具包
      public class MailUtils {
      //email:邮件发给谁(收件人)  subject:主题  emailMsg:邮件内容
      public static void sendMail(String email,String subject, String emailMsg)
              throws AddressException, MessagingException {
          // 1.创建一个程序与邮件服务器会话对象 Session
          Properties props = new Properties();
          props.setProperty("mail.transport.protocol", "SMTP");//发邮件的协议SMTP
          props.setProperty("mail.host", "192.168.1.109");//发送邮件的服务器地址
          props.setProperty("mail.smtp.auth", "true");// 是否要验证,指定验证为true
          // 创建验证器
          Authenticator auth = new Authenticator() {
              public PasswordAuthentication getPasswordAuthentication() {
                  return new PasswordAuthentication("sam", "111111");//发邮件的账号验证
              }
          };
          //此处的session是会话对象
          Session session = Session.getInstance(props, auth);
          // 2.创建一个Message,它相当于是邮件内容
          Message message = new MimeMessage(session);
          message.setFrom(new InternetAddress("sam@wangzhe.com")); // 设置发送者
          message.setRecipient(RecipientType.TO, new InternetAddress(email)); // 设置发送方式与接收者
          message.setSubject(subject);
          message.setContent(emailMsg, "text/html;charset=utf-8");
          // 3.创建Transport用于将邮件发送
          Transport.send(message);
      }
      }
      
      //web.xml
      <?xml version="1.0" encoding="UTF-8"?>
      <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
      <listener>
        <listener-class>birthday.BirthdayListener</listener-class>
      </listener>
      <display-name>WEB23_LISTENER</display-name>
      <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
      </welcome-file-list>
      </web-app>
    展开全文
  • 监听器原理及使用

    千次阅读 2019-03-17 15:45:39
    一、什么是监听器 web监听器是一种Servlet中的特殊的类,它们能帮助开发者监听web中的特定事件,比如ServletContext,HttpSession,ServletRequest的创建和销毁;变量的创建、销毁和修改等。可以在某些动作前后增加...

    一、什么是监听器
    web监听器是一种Servlet中的特殊的类,它们能帮助开发者监听web中的特定事件,比如ServletContext,HttpSession,ServletRequest的创建和销毁;变量的创建、销毁和修改等。可以在某些动作前后增加处理,实现监控
    监听器包括三部分:事件、事件源和事件监听器
    事件,发生事件的组件,也就是被监听的对象
    事件源,生成事件的对象,事件源提供了用于为事件注册监听器的方法
    事件监听器,监听并负责处理事件的方法

    二、监听器实现原理
    接下来的代码演示中:
    事件Event,事件源People,事件监听器MyListener

    public class Event {
    	private People people;
    
    	public People getPeople() {
    		return people;
    	}
    
    	public void setPeople(People people) {
    		this.people = people;
    	}
    
    	public Event(People people) {
    		this.people = people;
    	}
    }
    
    public class People {
    	String name;
        MyListener myListener;
    
        public void eat(){
    	    System.out.println("吃饭");
    	    myListener.doEat(new Event(this));
        }
    
        public void sleep(){
    	    System.out.println("睡觉");
    	    myListener.doSleep(new Event(this));
        }
    
    	public People(String name, MyListener myListener) {
    		this.name = name;
    		this.myListener = myListener;
    	}
    
    	public People(String name) {
    		this.name = name;
    	}
    
    	public void registerMyListener(MyListener myListener){
        	this.myListener = myListener;
    	}
    }
    
    public interface MyListener {
    	void doEat(Event event);
    	void doSleep(Event event);
    }
    

    使用监听器,这里在两个people中实现了不同的监听器去做指定的事情

    public class Main {
    	public static void main(String[] arg){
    		People people = new People("小红");
    		people.registerMyListener(new MyListener() {
    			@Override
    			public void doEat(Event event) {
    				System.out.println("不让"+event.getPeople().name+"吃饭");
    			}
    
    			@Override
    			public void doSleep(Event event) {
    				System.out.println("不让"+event.getPeople().name+"睡觉");
    			}
    		});
    
    		people.eat();
    		people.sleep();
    
    		People p = new People("大黄");
    		p.registerMyListener(new MyListener() {
    			@Override
    			public void doEat(Event event) {
    				System.out.println("让"+event.getPeople().name+"吃饭");
    			}
    
    			@Override
    			public void doSleep(Event event) {
    				System.out.println("让"+event.getPeople().name+"睡觉");
    			}
    		});
    
    		p.eat();
    		p.sleep();
    	}
    
    }
    

    运行结果如下
    在这里插入图片描述

    在实际的开发中 监听器的三部分都不需要我们自己去写 我们只是会实现监听器提供的接口,然后注册监听器,程序运行后,监听器就会在指定事件发生时进行相应处理。具体使用看下面

    三、监听器常用的用途
    通常使用Web监听器做以下的内容:
    统计在线人数,利用HttpSessionLisener
    加载初始化信息:利用ServletContextListener
    统计网站访问量、实现访问监控等

    在springboot项目中简单实现统计在线人数的监听器如下:
    浏览器首次访问服务会创建session来存放用户相关信息(会在用户退出登录时销毁session 或者设置session过期时间来控制其失效),我们就监听session的创建来实现对在线人数的统计

    1.实现监听器

    public class TestListener implements HttpSessionListener {
    	//HttpSessionListener提供了对session创建和销毁进行监听后的处理的监听器  我们只需要实现这两个方法
    	private int userNumber = 0;
    
    	@Override
    	public void sessionCreated(HttpSessionEvent se) {
    		userNumber++;
    		se.getSession().setAttribute("userNumber", userNumber);
    	}
    
    	@Override
    	public void sessionDestroyed(HttpSessionEvent se) {
    		userNumber--;
    		se.getSession().setAttribute("userNumber", userNumber);
    	}
    }
    

    2.注册监听器

    //注册监听器
    @Configuration
    public class ListenerBeanConfig {
    
    	@Bean
    	public ServletListenerRegistrationBean servletListenerRegistrationBean(){
    		ServletListenerRegistrationBean bean = new ServletListenerRegistrationBean();
    		bean.setListener(new TestListener());
    		return bean;
    	}
    }
    

    3.使用监听器

    @Controller
    public class TestController {
    	@RequestMapping("/test")
    	@ResponseBody
    	public String getResult() {
    		return "在线用户人数:"+SessionUtils.getSessionAttribute("userNumber");
    	}
    }
    

    4.启动项目,访问接口检查运行结果

    第一次 访问浏览器 在线人数为1
    在这里插入图片描述
    换另外一个浏览器访问 在线人数为2
    在这里插入图片描述
    这里我们只是测试了对session创建时的监控
    监听器的分类和其他具体使用后续再继续学习

    展开全文
  • 1、一个监听在一个IP一个端口上监听多个实例  2、一个监听在一个IP不同端口上监听多个实例 3、多个监听监听多个实例  情况1: listener.ora文件: 1 2 3 4 5 6 7 8 9 10 11 12 13 14




    三种情况:  

    1、一个监听在一个IP一个端口上监听多个实例 

    2、一个监听在一个IP不同端口上监听多个实例

    3、多个监听监听多个实例 


    情况1:

    listener.ora文件:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    # listener.ora Network Configuration File: E:\app\product\11.2.0\dbhome_1\NETWORK\ADMIN\listener.ora
    # Generated by Oracle configuration tools.
    SID_LIST_ORCL =
      (SID_LIST =
        (SID_DESC =
          (GLOBAL_DBNAME = ORCL)
          (SID_NAME = ORCL)
        )
        (SID_DESC =
          (GLOBAL_DBNAME = NHL)
          (SID_NAME = NHL)
        )
      )
    ORCL =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1521))
        )
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
        )
      )

    wKioL1Rtmg3B1mfcAAHiMffyG2Y429.jpg

    wKiom1RtmZXQUCh5AAHQps7Bd4Q040.jpg


    tnsnames.ora文件:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    # tnsnames.ora Network Configuration File: E:\app\product\11.2.0\dbhome_1\network\admin\tnsnames.ora
    # Generated by Oracle configuration tools.
    NHL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = NHL)
        )
      )
    ORCL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = orcl)
        )
      )

    wKioL1RtmjuA3gtfAAGmnOLTyJI386.jpg

    wKiom1RtmcPgLo6EAAGmvHq-ocw883.jpg


    情况2:

    listener.ora文件:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    # listener.ora Network Configuration File: E:\app\product\11.2.0\dbhome_1\NETWORK\ADMIN\listener.ora
    # Generated by Oracle configuration tools.
    SID_LIST_ORCL =
      (SID_LIST =
        (SID_DESC =
          (GLOBAL_DBNAME = ORCL)
          (SID_NAME = ORCL)
        )
        (SID_DESC =
          (GLOBAL_DBNAME = NHL)
          (SID_NAME = NHL)
        )
      )
    ORCL =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1521))
        )
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1522))
        )
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
        )
      )

    tnsnames.ora文件:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    # tnsnames.ora Network Configuration File: E:\app\product\11.2.0\dbhome_1\network\admin\tnsnames.ora
    # Generated by Oracle configuration tools.
    NHL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1522))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = NHL)
        )
      )
    ORCL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = orcl)
        )
      )



    情况3:

    listener.ora文件:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    # listener.ora Network Configuration File: E:\app\product\11.2.0\dbhome_1\NETWORK\ADMIN\listener.ora
    # Generated by Oracle configuration tools.
    SID_LIST_ORCL =
      (SID_LIST =
        (SID_DESC =
          (GLOBAL_DBNAME = ORCL)
          (SID_NAME = ORCL)
        )
        (SID_DESC =
          (GLOBAL_DBNAME = NHL)
          (SID_NAME = NHL)
        )
      )
    SID_LIST_TEST =
      (SID_LIST =
        (SID_DESC =
          (GLOBAL_DBNAME = TEST)
          (SID_NAME = TEST)
        )
    ORCL =
      (DESCRIPTION_LIST =
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1521))
        )
        (DESCRIPTION =
          (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
        )
      )
    TEST =
       (DESCRIPTION =
          (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1523))
        )


    tnsnames.ora文件:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    # tnsnames.ora Network Configuration File: E:\app\product\11.2.0\dbhome_1\network\admin\tnsnames.ora
    # Generated by Oracle configuration tools.
    NHL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1522))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = NHL)
        )
      )
    ORCL =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1521))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = orcl)
        )
      )
    TEST =
      (DESCRIPTION =
        (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.152.131)(PORT = 1523))
        (CONNECT_DATA =
          (SERVER = DEDICATED)
          (SERVICE_NAME = test)
        )
      )

    改完配置并启动。



    这个还有个缺陷,listener中的ORACLE_HOME没写,自己配置的时候记得写上 

    展开全文
  • Socket监听

    千次阅读 2019-01-17 14:36:32
    socket应该在每次连接和断开时进行监听处理 这个在后面分发数据包时会用到 而且可以提示客户端是否在线 此博客内容实质上就是类似于qq上下线提醒的功能的实现 代码的注释比较详细 直接看代码 服务器端 class ...

    socket应该在每次连接和断开时进行监听处理 这个在后面分发数据包时会用到 而且可以提示客户端是否在线

    此博客内容实质上就是类似于qq上下线提醒的功能的实现

    代码的注释比较详细 直接看代码

    服务器端

     class Program
        {
            static List<Socket> list = new List<Socket>();
            static void Main(string[] args)
            {
                Console.WriteLine("服务器已开启 ... ");
                //创建心跳包 监听客户端状态 如果客户端断开连接 服务器端同样断开连接 并将连接从列表中移除
                Timer timer = new Timer(1000);
                timer.Elapsed += new ElapsedEventHandler(DisConnectedListen);
                timer.Start();
                IPAddress ip = new IPAddress(new byte[] { 127, 0, 0, 1 });
                TcpListener listener = new TcpListener(ip, 8500);
                // 开始侦听   打开监听就是创建一个门 客户端连接请求就是敲门 只有创建门才会有门可敲
                listener.Start();
                Console.WriteLine("监听已开启 ...");
                while (true)
                {
                    Socket socket = listener.AcceptSocket();
                    // 打印连接到的客户端信息    
                    Console.WriteLine("客户端{0}已连接服务器 {1}", socket.RemoteEndPoint, socket.LocalEndPoint);
                    list.Add(socket);
                }
            }
            /// <summary>
            /// 监听连接状态
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            static void DisConnectedListen(object sender, ElapsedEventArgs e)
            {
                if (list.Count > 0)
                {
                    for (int i = 0; i < list.Count-1; i++)
                    {
                        //判断socket的客户端连接状态
                        if (list[i].Poll(1000, SelectMode.SelectRead))
                        {
                            Console.WriteLine("客户端{0}已与服务器 {1}断开连接", list[i].RemoteEndPoint, list[i].LocalEndPoint);
                            list[i].Close();
                            list.RemoveAt(i);
                        }
                    }
                }
            }
        }

    客户端

      class Program
        {
            static void Main(string[] args)
            {
                Console.WriteLine("客户端正在运行 ...");
                for (int i = 0; i < 5; i++)
                {
                    TcpClient client = new TcpClient();
                    try
                    {
                        // 与服务器连接  这是第一次握手 是一种同步操作 在此操作执行完毕之前会阻塞程序运行
                        //由于本地测试不涉及路由规则 也方便创建连接 所以这里的连接没有指定本地的端口号由系统自动分配 
                        client.Connect("localhost", 8500);
                    }
                    catch (Exception ex)
                    {
                        Console.WriteLine(ex.Message);
                        return;
                    }
                    // 打印连接到的服务端信息   
                    Console.WriteLine("本地节点{0} 已连接服务器 {1}", client.Client.LocalEndPoint, client.Client.RemoteEndPoint);
                }
                // 按 Q 退出   
                Console.WriteLine("\n\n 输入\"Q\"键退出。");
                ConsoleKey key;
                do
                {
                    key = Console.ReadKey(true).Key;
                }
                while (key != ConsoleKey.Q);
            }
        }

    服务器端打开监听

    客户端连接

    客户端退出

    展开全文
  • Android 实时监测(监听)网络连接状态变化

    千次下载 热门讨论 2020-07-29 14:20:28
    android网络监听变化,判断当前是什么网络类型,实时监听。android网络监听变化,判断当前是什么网络类型,实时监听。android网络监听变化,判断当前是什么网络类型,实时监听。android网络监听变化,判断当前是什么...
  • 说事件绑定得先说事件流 事件流 冒泡型事件流:事件的传播是从最特定的事件目标到最不特定的事件目标。即从DOM树的叶子到根。【推荐】 捕获型事件流:事件的传播是从最不特定的事件目标到最特定的事件目标。...
  • 首先还是老套路,先弄明白回调和监听者模式。(回调在我上篇分享已经提到过了,不懂的可以翻阅我写的点击打开链接(一个能让你一辈子不会忘记的例子))。  监听者模式定义(这里实现的是一个简单的监听模式):...
  • jquery中四种事件监听的区别

    万次阅读 2017-08-06 23:35:31
    我们知道jquery提供了四种事件监听方式,分别是bind、live、delegate、on,下面就分别对这四种事件监听方式分析。 已知有4个列表元素:   列表元素1   列表元素2   列表元素3   列表元素4 1.bind bind(type,[data...
  • Java监听模式

    千次阅读 2018-03-02 19:21:45
     生活中,监听无处不在。比如说,手机播放音乐功能,也是一种监听:你不点击播放按钮,手机就不放歌,当你点击时,手机就播放音乐。即触发某种行为,便执行相应的动作。 组成 Java监听模式右三个部分组成:...
  • 过滤器 过滤器的英文名称为 Filter, 是 Servlet 技术中最实用的技术。 如同它的名字一样,过滤器是处于客户端和服务器资源文件之间的一道过滤网,帮助我们过滤掉一些不符合要求的请求,通常用作 Session 校验,判断...
  • vue中事件监听watch

    千次阅读 2019-08-23 17:35:00
    vue中watch实际上是用来监听vue实例中的数据变化 监听String <template> <div @click="stringClick">{{msg}}</div> </template> <script> export default { name: "jianting", ...
  • Oracle监听状态查看

    万次阅读 2017-07-30 16:38:41
    前提:登录用户有dba权限,能够进行查看 查看状态命令:lsnrctl status启动监听:lsnrctl start关闭监听:lsnrctl stop
  • 用JS实现监听URL地址变化

    万次阅读 2020-06-27 22:57:49
    有些项目可能会需要监听URL的变化来做出动作,可以使用下边的代码
  • activiti中监听器的配置和使用详解

    万次阅读 2015-11-30 17:52:10
    在activiti流程引擎中,监听器是非常重要的。 activiti的监听分为两种,一种是任务监听器,另一种执行监听器。 任务监听器:在经理办理请假任务时,自动获取“请假”所在的部门 的经理。 执行监听器:在任务结束...
  • Oracle启动监听服务/重启服务

    万次阅读 2018-06-10 20:25:14
    gt; conn / as sysdbasql&gt; startup (一般不需要加参数,只要设置好环境变量)sql... quit (退出sql模式)$ lsnrctl start (启动监听器)关闭oracle$ lsnrctl stop(关闭监听器,在这之前,应该先关闭应用程序)...
  • textView在TableRow中,TableRow添加的代码: TextView eq = new TextView(fa); eq.setId(40); eq.setText(Student.getEq());... eq.setTextColor(Color....我想知道能不能给textview添加一个监听器。谢谢指教。
  • oracle11G监听日志所在位置

    万次阅读 2013-08-22 18:22:20
    oracle 11g的监听日志和警告日志都是在/u01/oracle/diag/tnslsnr/oracle/listener目录和/u01/oracle/diag/rdbms/db1/db1目录下都有以下分别简称listener目录和db1目录。
  • 微信小程序滚动监听

    万次阅读 2018-05-02 09:22:07
    微信小程序是没有真实DOM节点的,也就是说没有window对象,怎么实现类似web网页的滚动监听事件呢? 在页面Page()函数里,有个onPageScroll方法,可以输出滚动距离: onPageScroll:function(e){ console.log(e);...
  • vue watch监听

    万次阅读 2018-03-14 16:44:11
    最近学习vue.js, 项目中要使用watch 监听一些对象,触发某些事件! 1.最简单的input输入框的监听input的watch监听就是这样子了,深入监听加上参数deep就行,这样写其它的一些写法和参数可以去参照vue官网深入了解2....
  • oracle服务器重启后监听启动

    万次阅读 2017-03-09 16:03:53
    2、检查Oracle DB监听器是否正常:  输入:lsnrctl status检查监听是否启动,如未启动  输入:lsnrctl start启动监听器;  netstat -ntlp 查看1521端口是否启动 3、进入sqlplus界面:sqlplus /nolog; conn
1 2 3 4 5 ... 20
收藏数 1,199,442
精华内容 479,776
关键字:

监听