home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c15 / NameSender.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  6.0 KB  |  173 lines

  1. //: NameSender.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // An applet that sends an email address
  50. // as a datagram, using Java 1.02.
  51. import java.awt.*;
  52. import java.applet.*;
  53. import java.net.*;
  54. import java.io.*;
  55.  
  56. public class NameSender extends Applet 
  57.     implements Runnable {
  58.   private Thread pl = null;
  59.   private Button send = new Button(
  60.     "Add email address to mailing list");
  61.   private TextField t = new TextField(
  62.     "type your email address here", 40);
  63.   private String str = new String();
  64.   private Label 
  65.     l = new Label(), l2 = new Label();
  66.   private DatagramSocket s; 
  67.   private InetAddress hostAddress;
  68.   private byte[] buf = 
  69.     new byte[NameCollector.BUFFER_SIZE];
  70.   private DatagramPacket dp =
  71.     new DatagramPacket(buf, buf.length);
  72.   private int vcount = 0;
  73.   public void init() {
  74.     setLayout(new BorderLayout());
  75.     Panel p = new Panel();
  76.     p.setLayout(new GridLayout(2, 1));
  77.     p.add(t);
  78.     p.add(send);
  79.     add("North", p);
  80.     Panel labels = new Panel();
  81.     labels.setLayout(new GridLayout(2, 1));
  82.     labels.add(l);
  83.     labels.add(l2);
  84.     add("Center", labels);
  85.     try {
  86.       // Auto-assign port number:
  87.       s = new DatagramSocket();
  88.       hostAddress = InetAddress.getByName(
  89.         getCodeBase().getHost());
  90.     } catch(UnknownHostException e) {
  91.       l.setText("Cannot find host");
  92.     } catch(SocketException e) {
  93.       l.setText("Can't open socket");
  94.     } 
  95.     l.setText("Ready to send your email address");
  96.   }
  97.   public boolean action (Event evt, Object arg) {
  98.     if(evt.target.equals(send)) {
  99.       if(pl != null) {
  100.         // pl.stop(); Deprecated in Java 1.2
  101.         Thread remove = pl;
  102.         pl = null;
  103.         remove.interrupt();
  104.       }
  105.       l2.setText("");
  106.       // Check for errors in email name:
  107.       str = t.getText().toLowerCase().trim();
  108.       if(str.indexOf(' ') != -1) {
  109.         l.setText("Spaces not allowed in name");
  110.         return true;
  111.       }
  112.       if(str.indexOf(',') != -1) {
  113.         l.setText("Commas not allowed in name");
  114.         return true;
  115.       }
  116.       if(str.indexOf('@') == -1) {
  117.         l.setText("Name must include '@'");
  118.         l2.setText("");
  119.         return true;
  120.       }
  121.       if(str.indexOf('@') == 0) {
  122.         l.setText("Name must preceed '@'");
  123.         l2.setText("");
  124.         return true;
  125.       }
  126.       String end = 
  127.         str.substring(str.indexOf('@'));
  128.       if(end.indexOf('.') == -1) {
  129.         l.setText("Portion after '@' must " +
  130.           "have an extension, such as '.com'");
  131.         l2.setText("");
  132.         return true;
  133.       }
  134.       // Everything's OK, so send the name. Get a
  135.       // fresh buffer, so it's zeroed. For some 
  136.       // reason you must use a fixed size rather
  137.       // than calculating the size dynamically:
  138.       byte[] sbuf = 
  139.         new byte[NameCollector.BUFFER_SIZE];
  140.       str.getBytes(0, str.length(), sbuf, 0);
  141.       DatagramPacket toSend =
  142.         new DatagramPacket(
  143.           sbuf, 100, hostAddress,
  144.           NameCollector.COLLECTOR_PORT);
  145.       try {
  146.         s.send(toSend);
  147.       } catch(Exception e) {
  148.         l.setText("Couldn't send datagram");
  149.         return true;
  150.       }
  151.       l.setText("Sent: " + str);
  152.       send.setLabel("Re-send");
  153.       pl = new Thread(this);
  154.       pl.start();
  155.       l2.setText(
  156.         "Waiting for verification " + ++vcount);
  157.     }
  158.     else return super.action(evt, arg);
  159.     return true;
  160.   }
  161.   // The thread portion of the applet watches for
  162.   // the reply to come back from the server:
  163.   public void run() {
  164.     try {
  165.       s.receive(dp);
  166.     } catch(Exception e) {
  167.       l2.setText("Couldn't receive datagram");
  168.       return;
  169.     }
  170.     l2.setText(new String(dp.getData(),
  171.       0, 0, dp.getLength()));
  172.   }
  173. } ///:~