diff --git a/nbproject/build-impl.xml b/nbproject/build-impl.xml index 4abce43..f071bc4 100644 --- a/nbproject/build-impl.xml +++ b/nbproject/build-impl.xml @@ -46,8 +46,8 @@ is divided into following sections: - - + + @@ -76,7 +76,7 @@ is divided into following sections: - + @@ -156,6 +156,7 @@ is divided into following sections: + @@ -840,7 +841,7 @@ is divided into following sections: - + @@ -852,7 +853,7 @@ is divided into following sections: - + @@ -975,15 +976,15 @@ is divided into following sections: - + - + - + @@ -991,7 +992,7 @@ is divided into following sections: - + @@ -1186,7 +1187,7 @@ is divided into following sections: Must select one file in the IDE or set run.class - + Must select one file in the IDE or set applet.url diff --git a/nbproject/genfiles.properties b/nbproject/genfiles.properties index cb2d623..a1e02d5 100644 --- a/nbproject/genfiles.properties +++ b/nbproject/genfiles.properties @@ -4,5 +4,5 @@ build.xml.stylesheet.CRC32=8064a381@1.75.1.48 # This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml. # Do not edit this file. You may delete it but then the IDE will never regenerate such files for you. nbproject/build-impl.xml.data.CRC32=6d39ee20 -nbproject/build-impl.xml.script.CRC32=681df6e3 -nbproject/build-impl.xml.stylesheet.CRC32=05530350@1.79.1.48 +nbproject/build-impl.xml.script.CRC32=5c486f47 +nbproject/build-impl.xml.stylesheet.CRC32=830a3534@1.80.1.48 diff --git a/nbproject/private/private.properties b/nbproject/private/private.properties index 1b6c36a..09a86e2 100644 --- a/nbproject/private/private.properties +++ b/nbproject/private/private.properties @@ -1,2 +1,2 @@ compile.on.save=true -user.properties.file=C:\\Users\\ANDITYAARIFIANTO\\AppData\\Roaming\\NetBeans\\8.1\\build.properties +user.properties.file=C:\\Users\\praanggi\\AppData\\Roaming\\NetBeans\\8.2\\build.properties diff --git a/nbproject/private/private.xml b/nbproject/private/private.xml index 52e3867..6807a2b 100644 --- a/nbproject/private/private.xml +++ b/nbproject/private/private.xml @@ -2,10 +2,6 @@ - - file:/C:/Users/ANDITYAARIFIANTO/Documents/GitHub/Task_4/src/javaChat/ClientConnection.java - file:/C:/Users/ANDITYAARIFIANTO/Documents/GitHub/Task_4/src/javaChat/ServerConnection.java - file:/C:/Users/ANDITYAARIFIANTO/Documents/GitHub/Task_4/src/javaChat/Connection.java - + diff --git a/src/ConsoleApp/ConnectionThread.java b/src/ConsoleApp/ConnectionThread.java new file mode 100644 index 0000000..0bd6c0b --- /dev/null +++ b/src/ConsoleApp/ConnectionThread.java @@ -0,0 +1,50 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package ConsoleApp; + +import java.io.IOException; +import java.net.Socket; +import javaChat.Connection; + +/** + * + * @author praanggi + */ +public class ConnectionThread extends Thread { + + private Socket client; + private Connection connection; + + public ConnectionThread(Socket newClient) throws IOException{ + this.client = newClient; + connection = new Connection(client); + } + + public void run(){ + try { + connection.startChat(" Start The Chat "); + System.out.println(" ------------- "); + System.out.println(" new cilent connected "); + System.out.println(" client information "); + System.out.println(connection.getClientInformation()); + + String inputan; + String message; + while((inputan = connection.readStream()) != null && inputan.equals("Quit")){ + message = "Client " + connection.getIpClient() + "Said : " + inputan; + System.out.println(message); + connection.sendToAll(message); + } + + message = "Client from IP : " + connection.getIpClient() + "Quit the chat room"; + System.out.println(message); + connection.sendToAll(message); + connection.disconnect(); + } catch (Exception e) { + System.out.println("Error"); + } + } +} diff --git a/src/ConsoleApp/ConsoleApplication.java b/src/ConsoleApp/ConsoleApplication.java new file mode 100644 index 0000000..4a95224 --- /dev/null +++ b/src/ConsoleApp/ConsoleApplication.java @@ -0,0 +1,66 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package ConsoleApp; + +import javaChat.ClientConnection; + +/** + * + * @author praanggi + */ +public class ConsoleApplication { + + private ClientConnection client; + + public class ReadInput extends Thread{ + + public void run(){ + + try { + String inputKeyboard; + do { + System.out.println(">> "); + inputKeyboard = client.inputString(); + client.writeStream(inputKeyboard); + } while(!inputKeyboard.equals("Quit")); + client.disconnect(); + } catch (Exception e) { + System.out.println("Error"); + } + } + } + + public class WriteInput extends Thread{ + + public void run(){ + + try { + String inputan; + while ((inputan = client.readStream()) != null){ + System.out.println(inputan); + System.out.println(">>"); + } + } catch (Exception e) { + System.out.println("Error"); + } + } + } + + public void startChat(){ + try { + client = new ClientConnection(); + System.out.println("Input server IP : "); + String ip = client.inputString(); + client.connect(ip); + ReadInput in = new ReadInput(); + WriteInput out = new WriteInput(); + in.start(); + out.start(); + } catch (Exception e) { + System.out.println("Error"); + } + } +} \ No newline at end of file diff --git a/src/Driver/DriveClientConsole.java b/src/Driver/DriveClientConsole.java new file mode 100644 index 0000000..e0a78f3 --- /dev/null +++ b/src/Driver/DriveClientConsole.java @@ -0,0 +1,21 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package Driver; + +import ConsoleApp.ConsoleApplication; + +/** + * + * @author praanggi + */ +public class DriveClientConsole { + + public static void main(String[] args) { + + ConsoleApplication ca = new ConsoleApplication(); + ca.startChat(); + } +} diff --git a/src/Driver/DriverClientGui.java b/src/Driver/DriverClientGui.java new file mode 100644 index 0000000..dbc96c4 --- /dev/null +++ b/src/Driver/DriverClientGui.java @@ -0,0 +1,20 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package Driver; + +import chatGUI.JChatController; + +/** + * + * @author praanggi + */ +public class DriverClientGui { + + public static void main(String[] args) { + + JChatController jcc = new JChatController(); + } +} diff --git a/src/Driver/DriverServer.java b/src/Driver/DriverServer.java new file mode 100644 index 0000000..3656c9c --- /dev/null +++ b/src/Driver/DriverServer.java @@ -0,0 +1,31 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package Driver; + +import ConsoleApp.ConnectionThread; +import javaChat.ServerConnection; + +/** + * + * @author praanggi + */ +public class DriverServer { + + public static void main(String[] args) { + + try { + ServerConnection server = new ServerConnection(); + System.out.println("Server Information"); + System.out.println(server.getServerInformation()); + while (true) { + ConnectionThread connection = new ConnectionThread(server.getClient()); + connection.start(); + } + } catch (Exception e) { + System.out.println("Error"); + } + } +} diff --git a/src/chatGUI/ChatView.form b/src/chatGUI/ChatView.form new file mode 100644 index 0000000..0e90112 --- /dev/null +++ b/src/chatGUI/ChatView.form @@ -0,0 +1,72 @@ + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
diff --git a/src/chatGUI/ChatView.java b/src/chatGUI/ChatView.java new file mode 100644 index 0000000..d7ecd94 --- /dev/null +++ b/src/chatGUI/ChatView.java @@ -0,0 +1,134 @@ +package chatGUI; + +import java.awt.event.ActionListener; + +/** + * + * @author praanggi + */ +public class ChatView extends javax.swing.JFrame { + + /** + * Creates new form JFrameChatView + */ + public ChatView() { + initComponents(); + } + + /** + * This method is called from within the constructor to initialize the form. + * WARNING: Do NOT modify this code. The content of this method is always + * regenerated by the Form Editor. + */ + @SuppressWarnings("unchecked") + // //GEN-BEGIN:initComponents + private void initComponents() { + + jScrollPane1 = new javax.swing.JScrollPane(); + txAreaChat = new javax.swing.JTextArea(); + txFieldChat = new javax.swing.JTextField(); + + setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE); + + txAreaChat.setEditable(false); + txAreaChat.setColumns(20); + txAreaChat.setRows(5); + txAreaChat.setText("Input Server IP Address :"); + jScrollPane1.setViewportView(txAreaChat); + + txFieldChat.addActionListener(new java.awt.event.ActionListener() { + public void actionPerformed(java.awt.event.ActionEvent evt) { + txFieldChatActionPerformed(evt); + } + }); + + javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane()); + getContentPane().setLayout(layout); + layout.setHorizontalGroup( + layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) + .addGroup(layout.createSequentialGroup() + .addContainerGap() + .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) + .addComponent(txFieldChat, javax.swing.GroupLayout.Alignment.TRAILING) + .addComponent(jScrollPane1, javax.swing.GroupLayout.DEFAULT_SIZE, 380, Short.MAX_VALUE)) + .addContainerGap()) + ); + layout.setVerticalGroup( + layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) + .addGroup(layout.createSequentialGroup() + .addGap(16, 16, 16) + .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 207, javax.swing.GroupLayout.PREFERRED_SIZE) + .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED) + .addComponent(txFieldChat, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE) + .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) + ); + + pack(); + }// //GEN-END:initComponents + + private void txFieldChatActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_txFieldChatActionPerformed + // TODO add your handling code here: + }//GEN-LAST:event_txFieldChatActionPerformed + + /** + * @param args the command line arguments + */ + public static void main(String args[]) { + /* Set the Nimbus look and feel */ + // + /* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel. + * For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html + */ + try { + for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) { + if ("Nimbus".equals(info.getName())) { + javax.swing.UIManager.setLookAndFeel(info.getClassName()); + break; + } + } + } catch (ClassNotFoundException ex) { + java.util.logging.Logger.getLogger(ChatView.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); + } catch (InstantiationException ex) { + java.util.logging.Logger.getLogger(ChatView.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); + } catch (IllegalAccessException ex) { + java.util.logging.Logger.getLogger(ChatView.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); + } catch (javax.swing.UnsupportedLookAndFeelException ex) { + java.util.logging.Logger.getLogger(ChatView.class.getName()).log(java.util.logging.Level.SEVERE, null, ex); + } + // + // + + /* Create and display the form */ + java.awt.EventQueue.invokeLater(new Runnable() { + public void run() { + new ChatView().setVisible(true); + } + }); + } + + // Variables declaration - do not modify//GEN-BEGIN:variables + private javax.swing.JScrollPane jScrollPane1; + private javax.swing.JTextArea txAreaChat; + private javax.swing.JTextField txFieldChat; + // End of variables declaration//GEN-END:variables + + public void setTxAreaChat(String message) { + txAreaChat.append(message + "\n"); + } + + public Object getTxFieldChat() { + return txFieldChat; + } + + public String getStringChat() { + return txFieldChat.getText(); + } + + public void setTxFieldChat(String message) { + this.txFieldChat.setText(message); + } + + public void addListener(ActionListener e) { + txFieldChat.addActionListener(e); + } +} diff --git a/src/chatGUI/JChatController.java b/src/chatGUI/JChatController.java new file mode 100644 index 0000000..d3896a8 --- /dev/null +++ b/src/chatGUI/JChatController.java @@ -0,0 +1,59 @@ +package chatGUI; + +import java.awt.event.ActionEvent; +import java.awt.event.ActionListener; +import javaChat.ClientConnection; + +/** + * + * @author praanggi + */ +public class JChatController implements ActionListener{ + + private ChatView view; + private ClientConnection client; + + public JChatController() { + view = new ChatView(); + view.setVisible(true); + view.addListener(this); + client = null; + } + + public class WriteOutput extends Thread{ + + public void run(){ + String inputan; + try { + while((inputan = client.readStream()) != null){ + view.setTxAreaChat(inputan); + } + } catch (Exception e) { + System.out.println("Error"); + } + } + } + + public void actionPerformed(ActionEvent ae){ + + Object source = ae.getSource(); + + if (source.equals(view.getTxFieldChat())){ + if (client == null){ + try { + client = new ClientConnection(); + String ip = view.getStringChat(); + client.connect(ip); + WriteOutput w = new WriteOutput(); + w.start(); + } catch (Exception e) { + System.out.println("Error"); + } + }else{ + String input = view.getStringChat(); + client.writeStream(input); + view.setTxFieldChat(""); + } + } + } +} diff --git a/src/javaChat/Connection.java b/src/javaChat/Connection.java index b049aaa..e2e3690 100644 --- a/src/javaChat/Connection.java +++ b/src/javaChat/Connection.java @@ -12,8 +12,6 @@ import java.net.InetAddress; import java.net.Socket; import java.util.ArrayList; -import java.util.HashMap; -import java.util.Map; /** * @@ -27,21 +25,7 @@ public class Connection { private DataOutputStream outputStream; private InetAddress destAddress; private static ArrayList list = new ArrayList<>(); -// private static Map users = new HashMap<>(); - -// public Connection(Socket client, String username) throws IOException { -// this.client = client; -// inputStream = new BufferedReader(new InputStreamReader(client.getInputStream())); -//// outputStream = new DataOutputStream(client.getOutputStream()); -// users.put(username, new DataOutputStream(client.getOutputStream())); -// -// destAddress = this.client.getInetAddress(); -// byte ipAddress[] = destAddress.getAddress(); -// for (int i = 0; i < ipAddress.length; ++i) { -// ipClient += String.valueOf((ipAddress[i] + 256) % 256) + "."; -// } -// } - + public Connection(Socket client) throws IOException { this.client = client; list.add(client);