예제 #1
0
  public static void main(String args[]) {
    ConsoleHandler ch = new ConsoleHandler();
    ch.setLevel(Level.FINEST);

    JavaLN l = new JavaLN();
    l.setLevel(Level.FINEST);
    l.addHandler(ch);
    l.setUseParentHandlers(false);

    l.info(l.toString());
    l.severe("this is a test");
    l.entering("not", "needed"); // check for call to base class
    l.entering();
    l.entering(new Integer(10));
    l.entering(args);
    l.entering(new Object[] {new Integer(1), "one"});
    l.exiting();
    l.exiting("exiting");
    l.throwing(new Throwable("Throwable message"));

    JavaLN m = new JavaLN("one");
    m.severe(m.toString());
    m.severe("this is another test");

    JavaLN n = new JavaLN("two", null);
    n.severe(n.toString());
    n.severe("this is a third test");
    n.warning(new Throwable("this is a test"));
  }
예제 #2
0
  /*
   ** create a valid URL, paying attenting to a base if there is one.
   */
  private URL makeURL(String baseURL, String s) {
    logger.entering(baseURL);
    logger.entering(s);

    URL u = null;

    try {
      if (baseURL != null) u = new URL(new URL(baseURL), s);
      else u = new URL(s);
    } catch (MalformedURLException e) {
      logger.throwing(e);
    }

    logger.exiting(u);
    return (u);
  }
예제 #3
0
  /*
   ** Use the array pairs as pattern and replacement pairs.  E.g.:
   ** pairs[0] == "\\.wmv.*" and pairs[1] == ".wmv"
   */
  static String replaceAll(String s, String pairs[]) {
    logger.entering(s);
    logger.entering(pairs);

    if (pairs == null) return (s);

    if ((pairs.length % 2) != 0) {
      logger.severe("pairs not even");
    }

    for (int i = 0; i < pairs.length; i += 2) {
      s = s.replaceAll(pairs[i], pairs[i + 1]);
    }

    logger.exiting(s);
    return (s);
  }
예제 #4
0
  /*
   ** In the given string s, look for pattern.  If found, return the
   ** concatenation of the capturing groups.
   */
  private String match(String pattern, String s) {
    logger.entering(pattern);
    logger.entering(s);

    String ret = null;

    Matcher matcher = Pattern.compile(pattern).matcher(s);
    if (matcher.find()) {
      ret = "";
      for (int i = 1; i <= matcher.groupCount(); i++) {
        ret += (matcher.group(i));
      }
    }

    logger.exiting(ret);
    return (ret);
  }
예제 #5
0
  /*
   ** add a URL to the list of those to be processed
   */
  private void addOne(String total) {
    logger.entering(total);

    urls.put(total, new Boolean(false));

    URLcount++;

    int checkpointEvery = args.CheckpointEvery;
    if (checkpointEvery != 0 && URLcount % checkpointEvery == 0) checkpoint();
  }
예제 #6
0
  /*
   ** http://www.w3schools.com/tags/tag_base.asp
   ** "The <base> tag specifies the base URL/target for all relative URLs
   ** in a document.
   ** The <base> tag goes inside the <head> element."
   */
  private String newBase(String base) {
    logger.entering(base);

    if (base == null) return (null);

    String b = "<[bB][aA][sS][eE].*[hH][rR][eE][fF]=[\"']?([^\"'# ]*)";
    String ret = match(b, base);

    logger.exiting(ret);
    return (ret);
  }
예제 #7
0
  private void fetchOne(boolean examine, boolean save, YouAreEll yrl, InputStream is) {
    logger.entering(examine);
    logger.entering(save);
    logger.entering(yrl);

    if (examine) is = new DelimitedBufferedInputStream(is, '<', '>');

    BufferedOutputStream bos = null;
    WebFile wf = null;
    if (save) {
      wf = new WebFile(yrl, args);
      bos = wf.getBOS();

      if (bos == null) save = false;
    }

    if (save || examine) {
      if (!examineORsave(yrl, is, bos, examine, save, yrl.getURL())) {
        logger.severe("examineORsave failed");
      }
    }

    if (bos != null) {
      try {
        bos.close();
        if (args.SetLastModified) wf.getFile().setLastModified(yrl.getLastModified());
      } catch (IOException e) {
        logger.throwing(e);
      }
    }

    if (examine) {
      try {
        is.close();
      } catch (IOException e) {
        logger.throwing(e);
      }
    }
  }
예제 #8
0
  private void snooze(int milliseconds) {
    logger.entering(milliseconds);

    if (milliseconds == 0) return;

    logger.info("Sleeping for " + milliseconds + " milliseconds");

    try {
      Thread.sleep(milliseconds);
    } catch (InterruptedException ie) {
      logger.throwing(ie);
    }
  }
예제 #9
0
  /*
   ** @param        s        the string to rewrite
   ** @param        r        a pattern and replacement ("\\.wmv.* .wmv")
   ** @return                the interesting part if any, and null if none
   */
  static String rewrite(String s, String r) {
    logger.entering(s);
    logger.entering(r);

    if (s != null && r != null) {
      String rewrites[] = r.split("\\s");

      return (replaceAll(s, rewrites));
    }

    logger.exiting(s);
    return (s);
  }
예제 #10
0
  /**
   * look for "interesting" parts of a HTML string. interesting thus far means href's, src's, img's
   * etc.
   *
   * @param s the string to examine
   * @return the interesting part if any, and null if none
   */
  private String[] interesting(String s) {
    logger.entering(s);

    if (s == null) return (null);

    String m[] = new String[args.Interesting.length];

    for (int i = 0; i < args.Interesting.length; i++) {
      m[i] = match(args.Interesting[i], s);
    }

    return (m);
  }
예제 #11
0
  private String escapeURL(String URL) {
    logger.entering(URL);

    String ret = URL;

    String meta = "^.[]$()|*+?{";

    for (int i = 0; i < meta.length(); i++) {
      char c = meta.charAt(i);
      ret = ret.replaceAll("\\" + c, "\\\\" + c);
    }

    logger.exiting(ret);
    return (ret);
  }
예제 #12
0
  private void addToURLs(String baseURL, String strings[]) {
    logger.entering(baseURL);
    logger.entering(strings);

    for (int i = 0; i < strings.length; i++) {
      String next = replaceAll(strings[i], args.URLFixUp);

      String newBase = newBase(next);
      if (newBase != null) {
        logger.fine("Setting base to " + baseURL);
        baseURL = newBase;
      }

      String possible[] = interesting(next);

      for (int j = 0; j < args.Interesting.length; j++) {
        if (possible[j] != null) {
          URL u = makeURL(baseURL, possible[j]);

          if (u == null) continue;

          String total = u.toString();

          String PathAccept[] = args.PathAccept;
          String PathReject[] = args.PathReject;

          boolean accept = Utils.blurf(PathAccept, PathReject, total, true);

          if (args.PrintAccept && accept) logger.info("Accepting path: " + total);
          if (args.PrintReject && !accept) logger.info("Rejecting path: " + total);

          if (accept) {
            if (args.URLRewrite != null) total = REplican.replaceAll(total, args.URLRewrite);

            // if we don't already have it
            if (urls.get(total) == null) {
              if (args.PrintAdd) logger.info("Adding: " + total);
              addOne(total);
            }
          }
        }
      }
    }
  }
예제 #13
0
 /**
  * Log entering a method without having to pass the class and method names.
  *
  * @param o the array of Objects logged along with the class and method.
  */
 public void entering(Object[] o) {
   StackTraceElement ste = new Throwable().getStackTrace()[1];
   entering(ste.getClassName(), ste.getMethodName(), o);
 }
예제 #14
0
 private void doEnter(String s) {
   StackTraceElement ste = new Throwable().getStackTrace()[2];
   entering(ste.getClassName(), ste.getMethodName(), s);
 }
예제 #15
0
  private void fetch(String url) {
    logger.entering(url);

    boolean Path =
        args.PathExamine != null
            || args.PathIgnore != null
            || args.PathSave != null
            || args.PathRefuse != null;
    boolean MIME =
        args.MIMEExamine != null
            || args.MIMEIgnore != null
            || args.MIMESave != null
            || args.MIMERefuse != null;

    logger.fine("Path = " + Path);
    logger.fine("MIME = " + MIME);

    boolean tb[] =
        EISR(url, "path", args.PathExamine, args.PathIgnore, args.PathSave, args.PathRefuse);

    boolean Pexamine = tb[0];
    boolean Psave = tb[1];

    /*
     * if there is no MIME, and the Path doesn't say to examine or save,
     * we're done.
     */
    if (!MIME && !Pexamine && !Psave) return;

    /*
     * otherwise, we need to Path examine or save, or we need the MIME
     * header.  in either case, we need an InputStream.
     */
    InputStream is = null;
    YouAreEll yrl = null;
    for (int t = 0; t < args.Tries; t++) {
      yrl = new YouAreEll(url, urls, cookies, args);
      is = yrl.getInputStream();
      if (is != null) break;
      if (args.Tries > 1) logger.warning("Trying again");
    }

    if (is == null) return;

    boolean Mexamine = false;
    boolean Msave = false;

    if (MIME && yrl.getContentType() != null) {
      tb =
          EISR(
              yrl.getContentType(),
              "MIME",
              args.MIMEExamine,
              args.MIMEIgnore,
              args.MIMESave,
              args.MIMERefuse);
      Mexamine = tb[0];
      Msave = tb[1];
    }

    // we've looked at both Path and now MIME and there's nothing to do
    if (!Pexamine && !Psave && !Mexamine && !Msave) return;

    fetchOne(Pexamine || Mexamine, Psave || Msave, yrl, is);

    try {
      is.close();
    } catch (IOException IOE) {
      logger.throwing(IOE);
    }
  }
예제 #16
0
  /*
   ** read from an input stream, optionally write to an output stream, and
   ** optionally look at all the URL's found in the input stream.
   */
  private boolean examineORsave(
      YouAreEll yrl,
      InputStream is,
      BufferedOutputStream bos,
      boolean examine,
      boolean save,
      String url) {
    logger.entering(is);
    logger.entering(bos);
    logger.entering(new Boolean(examine));
    logger.entering(new Boolean(save));
    logger.entering(url);

    try {
      int c;
      int read = 0;
      int written = 0;
      int content_length = yrl.getContentLength();
      int ten_percent = content_length > 0 ? content_length / 10 : 0;
      int count = 1;
      boolean percent = args.SaveProgress && save && ten_percent > 0;
      boolean spin = args.SaveProgress && save && ten_percent == 0;
      long start = new java.util.Date().getTime();

      if (percent) System.out.print("0..");
      if (spin) System.out.print("|");

      while ((c = is.read()) != -1) {
        if (save) {
          bos.write((char) c);
          written++;

          if (percent && count < 10 && written > count * ten_percent) {
            System.out.print(count * 10 + "..");
            count++;
          } else if (spin && written % 1000 == 0) {
            // System.out.println (count);
            // System.out.println (count % 4);
            System.out.print("\b" + "|/-\\".charAt(count % 4));
            count++;
          }
        }
        read++;
      }

      long stop = new java.util.Date().getTime();

      if (percent) System.out.println("100");
      if (spin) System.out.println("");
      if (spin || percent) {
        long seconds = (stop - start) / 1000;
        long BPS = read / (seconds == 0 ? 1 : seconds);

        if (BPS > 1000000000000000L) System.out.println(BPS / 1000000000000000L + " EBps");
        else if (BPS > 1000000000000L) System.out.println(BPS / 1000000000000L + " TBps");
        else if (BPS > 1000000000) System.out.println(BPS / 1000000000 + " GBps");
        else if (BPS > 1000000) System.out.println(BPS / 1000000 + " MBps");
        else if (BPS > 1000) System.out.println(BPS / 1000 + " KBps");
        else System.out.println(BPS + " Bps");
      }

      if (save) snooze(args.PauseAfterSave);

      // logger.finest ("bytes read: " + read);
      // logger.finest ("bytes written: " + written);

      if (examine) addToURLs(url, ((DelimitedBufferedInputStream) is).getStrings());
    } catch (IOException e) {
      logger.throwing(e);
      return (false);
    }

    return (true);
  }