Tema: Chat en java
Ver Mensaje Individual
  #5 (permalink)  
Antiguo 08/05/2011, 07:30
Avatar de HackmanC
HackmanC
 
Fecha de Ingreso: enero-2008
Ubicación: Guatemala
Mensajes: 1.817
Antigüedad: 17 años
Puntos: 260
Sonrisa Respuesta: Chat en java

Cita:
Iniciado por MjRoxas Ver Mensaje
... Necesito llevar una lista de los conectados: he pensado en la clase DefaultListModel, pero no entiendo muy bien como esta clase mantiene informados al resto de los conectados mediando los metodos de fire..
¿Por qué no usas tu propia implementación? Esta implementación es bastante antigua, así que use un HashSet, pero actualmente podrías usar una implementación como LinkedList. Cada usuario es un JUser y es un Thread, e implementa una función para enviarle mensajes.

Código Java:
Ver original
  1. public class JUser extends JObject implements JPingerListener, JConnectionHandler {
  2. ...
  3.     public void notice(String message) {
  4.         socket.print(JMessage.message(JMessage.JM_NOTICE, nickname, message));
  5.     }
  6.    
  7.     public void noticeWithMode(String message, char mode) {
  8.         if(modes.indexOf(mode) != -1)
  9.             notice(message);
  10.     }
  11. ...    
  12. }

La lista de usuarios, que es un HashSet de JUser se mantiene sincronizada y pasa por cada uno enviandole los mensajes correspondientes a uno y cada uno de los participantes, (cuando escribí esta aplicación no existía los Generics, pero puedes adaptar el método con Generics para no tener la necesidad de hacer el cast a JUser).

Código Java:
Ver original
  1. public class JUsers extends JObject {
  2. ...
  3.     private HashSet users;
  4. ...
  5.     public synchronized void handleConnection(Socket socket) throws IOException {
  6.         JUser user = new JUser(this, socket);
  7.         user.start();
  8.         users.add(user);
  9.     }
  10.    
  11.     public synchronized void remove(JUser user, String message) {
  12.         users.remove(user);
  13.     }
  14. ...
  15.     public synchronized void fireNoticeAll(String message) {
  16.         for(Iterator e = users.iterator(); e.hasNext(); )
  17.             ((JUser)e.next()).notice(message);
  18.     }
  19.    
  20.     public synchronized void fireNoticeAllWithMode(String message, char mode) {
  21.         for(Iterator e = users.iterator(); e.hasNext(); )
  22.             ((JUser)e.next()).noticeWithMode(message, mode);
  23.     }
  24. ...    
  25. }

El servidor cuando necesita avisarle a todos solamente hace uso del método de la clase donde le avisa a todos los usuarios conectados,

Código Java:
Ver original
  1. public class JServer extends JThread {
  2. ...
  3.     public JServer(int port) {
  4.         this.users = new JUsers(this);
  5.     }
  6. ...
  7.     private synchronized void handleConnection(Socket socket) throws IOException {
  8. ...
  9.                     if(!bannedConnection(socket, hostname, hostaddr))
  10. ...
  11.         }
  12.     }
  13. ...
  14.     private boolean bannedConnection(Socket socket, String hostname, String hostaddr) {
  15. ...
  16.         if(banned) {
  17.             JSocket.print(socket, JMessage.message(JMessage.JM_KLINED, kl.reason));
  18.             users.fireNoticeAllWithMode(JMessage.message(JMessage.JM_KLINEDALL, hostname), 'K');
  19. ...
  20.         }
  21.        
  22.         return banned;
  23.     }
  24. }

De esa forma cuando el servidor quiere enviar un mensaje a todos los usuarios, o un usuario quiere enviar un mensaje a todos los demás usuarios, pasa por cada uno de los conectados y les envía el mensaje.

Cita:
Iniciado por MjRoxas Ver Mensaje
... Estoy en proceso de depuracion, y ahora mismo los problemas que tengo son con los avisos y mensajes del servidor a el/los clientes. ...
La programación en Java está orientada a objetos, aunque la aplicación que mostró endgel ha de ser funcional parece programación estructurada, como Pascal o C.

Para hacer este servidor y lograr que todos los componentes se comuniquen correctamente necesitas por lo menos 10 clases distintas, por ejemplo .. JServer, JSocket, JUser, JUsers, JConnection, JConnectionHandler, JChannel, JChannels, etc. Cada uno tiene una ocupación diferente y de esta forma logras dividir la funcionalidad de cada componente para que sea mas fácil de sincronizar al mismo tiempo de mantener la lógica simple.

Saludos,

ps:

El codigo fue escrito en el año 2002, así que evidentemente es muy antiguo, y eliminé muchas partes de control de errores, etc., pero es rápido y eficiente, en lo que cabe con cien usuarios conectados.

Última edición por HackmanC; 08/05/2011 a las 07:49 Razón: año