Sponsored By
















MySQL로 DB를 만들고 자바로 연결하는 법 까지 보겠다.

 

 

※. 이미 MySQL이 설치되어있으면 아래 주소를 참조.

 

 

※. 간단한 테이블 만드는 방법은 아래 주소 참고. 주소에 나와있는 테이블을 쓸것이다.

 

 

 

 

 

00. 'mysql.com' 으로 접속해서 'Downloads' 를 클릭







01. 'Windows' 클릭







02. 'MySQL Connectors' 클릭







03. 'Connector / J' 클릭







04. Win 버전은 아래(ZIP버전), Linux 버전은 위에 (tar 버전) 클릭.







05. 'No Thanks, Just start my download' 클릭







06. 다운받아지면 아래 파일 을 복사 한다.







07. 'C:\Program Files\Java\jre1.8.0_101\lib\ext' 에 붙여넣기 를 한다.







08. 설명은 주석참고.







09. 정상적으로 연결된 것을 확인할 수 있다.

 

 

 

 

 

 

※. MyDB.java Class 코드 ----------------------------------------------------------------------------------

 

package com.kpmg.dbtest;

 

import java.sql.Connection;

import java.sql.DriverManager;

 

public class MyDB {

 

public MyDB(){

 

String url = "jdbc:mysql://localhost/mydb?characterEncoding=utf8";

String user = "myuser1";

String pass = "mypass1";

 

Connection conn;

 

try{

Class.forName("com.mysql.jdbc.Driver");

System.out.println("Driver Loading OK");

 

conn = DriverManager.getConnection(url, user, pass);

System.out.println("DB Connect OK");

 

 

}catch(Exception e){

System.out.println("ERROR : " + e.getMessage());

 

}

 

}// MyDB Constructor

 

 

}// MyDB 

 

 

GUI창에서 돌아가게 하는 정규식(RegularExpression) 사용방법.

 

꼭 굳이 GUI로 안해도 되지만 만들어놓은 포맷이 있으니 GUI를 사용하겠다.

 

 

00. '^01[016789]-\\d{4}-\\d{4}' 

-> ^ ; 시작/ 01뒤에 016789만 올수있다/ int 타입 4개/ int 타입 4개







01. 0은 패턴에 맞지않는다.






02. 01 다음에 6789 만 와야하므로 패턴에 맞지 않다.






03. 맞는 패턴.!! 확인.!!

 

 

 

 

 

※. 코드

import java.awt.BorderLayout;

import java.awt.FlowLayout;

import java.awt.Font;

import java.awt.event.ActionEvent;

import java.awt.event.ActionListener;

import java.util.regex.Pattern;

 

import javax.swing.JFrame;

import javax.swing.JPanel;

import javax.swing.JScrollPane;

import javax.swing.JTextArea;

import javax.swing.JTextField;

 

class MyFrame extends JFrame implements ActionListener{

private JPanel displayPanel; 

private JPanel inputPanel;

 

private JTextArea display;

private JTextField input;

 

public MyFrame()

{

this.setTitle("My GUI");

this.setSize(500, 400);

this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

 

/*

 * panel 생성하고, 필요한 컴포넌트를 만들기

 */

 

displayPanel = new JPanel();

displayPanel.setLayout(new FlowLayout());

display = new JTextArea(11, 30);

Font displayFont = new Font("Serif", Font.BOLD, 20);

display.setFont(displayFont);

display.setEditable(false);

 

// textarea를 스크롤이 되도록 변경

JScrollPane scroll = new JScrollPane(display);

displayPanel.add(scroll);

 

inputPanel = new JPanel();

inputPanel.setLayout(new FlowLayout());

input = new JTextField(30);

Font inputFont = new Font("Serif", Font.BOLD, 20);

input.setFont(inputFont);

input.addActionListener(this);

 

inputPanel.add(input);

 

/*

 * Frame에 두개의 panel을 붙이기

 */

this.setLayout(new BorderLayout());

this.add(displayPanel, BorderLayout.CENTER);

this.add(inputPanel, BorderLayout.SOUTH);

 

 

this.setVisible(true);

}

 

@Override

public void actionPerformed(ActionEvent e) {

 

if(e.getSource() == input)

{

display.append( input.getText() + "\n");

 

String regex = "^01[016789]-\\d{4}-\\d{4}";  // \가 특수기호이므로 두번해줘야 정상작동 in JAVA

 

if (Pattern.matches(regex, input.getText()) == false)  // input에 있는 텍스트 값과 regex 값 비교

{

display.append("휴대전화 패턴이 잘못되었습니다."+"\n");

}else

{

display.append("OK Mobile Pattern" + "\n");

}

 

input.selectAll();

}

 

}// actionPerformed

 

}// MyFrame Class

 

 

public class Test3 {

 

public static void main(String[] args) {

 

MyFrame frame = new MyFrame();

}// main

 

}// Main Class

 

 

 

GUI창에서 네트워킹(통신)을 이용 하여 조금더 개선된 채팅창 을 만들어 보겠다.

 

 

먼저, 네트워크에 대해 조금 보겠다.

ㅁ. Internet ?? internet??

; Internet= web browser  // internet = inter networking

 

ㅁ. 네트워크는 쌍방작동되야함. 만약 그렇지않으면 싱크 싱크아크 아크를 확인해야한다.

 

ㅁ. 한 PC에서 개발해서 디버깅 할때에는 포트번호를 다르게주고, 

    실질적으로 사용할때는 같은 번호로 할당하고 아이피주소를 상대방주소로 바꾼다.

 

 

ㅁ. IP 기초

형태 : 0000.0000.0000.0000

1. 0~127 까지가 앞이 0번임 -> 0xxx.255.255.255 -> A클래스 (우리나라에 없다)

// 127.0.0.0 => loopback IP  랜카드까지 나가지 않고 내부적으로 작동. 따라서 잠시 확인할때 사용가능

// C:\Windows\System32\drivers\etc

 

2. 127~191 1로시작 -> 1xxx.xxxx.255.255 -> B클래스 

( 돈주고 사오는것임. 우리나라에 몇군대없다. 전자통신연구원, 서울대,연세대, 카이스트, 충남대 등 )

// 예, 172.16.X.X B클래스 사설IP

 

3. 192~223 세번째 자리까지 할당해줌. 예, 200.100. 1~10 .255-> C클래스

// 공유기를 써서 확장시킴. 10.x.x.x 는 사설아이피. 라우터밖으로 나오면 죽기때문에 내부적으로 사용

// ex, 192.168.x.x 는 사설IP

 

 

00. 자세한 설명은 각 주석 참고.






01. 포트값을 다음과 같이 입력하고 실행시켜서 나온 GUI창을 a 라고 생각하자.







02. 통신하기위해 포트값을 서로 바꿔서 실행시킨다음 내이름과 님이름을 수기로 바꾸고 그것을 b 라고 생각하자.







03. a 창에서 먼저 hi 라고 적어보자







04. 내창과 님창에 둘다 뜨는 것을 확인할 수 있다. b 창에서도 똑같이 시도해본다.







05. 정상작동함을 볼 수 있다.

 

 

 

 

 

 

 

 

 

 

※. 코드

import java.awt.BorderLayout;

import java.awt.FlowLayout;

import java.awt.Font;

import java.awt.event.ActionEvent;

import java.awt.event.ActionListener;

import java.net.DatagramPacket;

import java.net.DatagramSocket;

import java.net.InetAddress;

 

import javax.swing.JFrame;

import javax.swing.JLabel;

import javax.swing.JPanel;

import javax.swing.JScrollPane;

import javax.swing.JTextArea;

import javax.swing.JTextField;

 

class Chatting {

/* 화면구성을 위한 변수들 */

private JPanel displayPanel; 

private JPanel inputPanel;

private JPanel setupPanel;

private JTextArea display;

private JTextField input;

 

/* setupPanel의 components*/

private JTextField myName;

private JTextField yourName;

private JTextField yourIP;

 

/* 통신을 위한 변수들 */

private DatagramSocket socket;  // User Datagram Protocol 

// <-> ServerSocket serverSocket ; TCP 통신

private DatagramPacket packet;  // 수신할 데이터 패킷을 위함

private InetAddress address;  // 상대방주소

 

private int myPort = 10002;

private int yourPort = 10001;

 

public Chatting() {

new MyFrame();  

/* socket 설정 */

try {

address = InetAddress.getByName( yourIP.getText() );  

// ; loopback address ; Testing in local  // 상대방의 IP

socket = new DatagramSocket(myPort);  // 수신할 포트설정

} catch (Exception e) {

display.append("ERROR : " + e.getMessage() + "\n");

}

}// Chatting Constructor

 

public void receive()

{

while(true)  // 무한정 돌면서 수신대기

{

try {  // 수신하다보면 에러가 생길 수 있기 때문에 예외처리로 

byte[] rcvBuffer = new byte[1024];  // 2승수로 바이트단위 잡아줘야함.

packet = new DatagramPacket(rcvBuffer, rcvBuffer.length);

socket.receive(packet);  // 소켓에서 수신하면

 

display.append(yourName.getText() + "<< " + new String(rcvBuffer)  + "\n");  

// ; 수신데이터는 byte[] 이므로 String으로 변환

 

} catch (Exception e) {

display.append("ERROR (receive) : " + e.getMessage());

}

}// while

 

}// receive Method

 

class MyFrame extends JFrame implements ActionListener{

 

public MyFrame()

{

this.setTitle("My GUI");

this.setSize(500, 400);

this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

 

/* displayPanel 처리 */

displayPanel = new JPanel();

displayPanel.setLayout(new FlowLayout());

display = new JTextArea(11, 30);

Font displayFont = new Font("Serif", Font.BOLD, 20);

display.setFont(displayFont);

display.setEditable(false);

 

// textarea를 스크롤이 되도록 변경

JScrollPane scroll = new JScrollPane(display);

displayPanel.add(scroll);

 

 

/* input 처리 */

inputPanel = new JPanel();

inputPanel.setLayout(new FlowLayout());

input = new JTextField(30);

Font inputFont = new Font("Serif", Font.BOLD, 20);

input.setFont(inputFont);

input.addActionListener(this);

inputPanel.add(input);

 

 

/* setupPanel 처리 */

setupPanel = new JPanel();

setupPanel.setLayout( new FlowLayout() );

setupPanel.add( new JLabel("MyName") );

myName = new JTextField(5);  //5 칸

setupPanel.add(myName);

myName.setText("홍길동");

 

setupPanel.add( new JLabel("YourName") );

yourName = new JTextField(5);  //5 칸

setupPanel.add(yourName);

yourName.setText("이순신");

 

setupPanel.add( new JLabel("YourIP") );

yourIP = new JTextField(6);  //6 칸

setupPanel.add(yourIP);

yourIP.setText("127.0.0.1");

 

 

/* Frame에 두개의 panel을 붙이기 */

this.setLayout(new BorderLayout());

this.add(setupPanel, BorderLayout.NORTH);

this.add(displayPanel, BorderLayout.CENTER);

this.add(inputPanel, BorderLayout.SOUTH);

 

this.setVisible(true);

 

}// myFrame Method

 

@Override

public void actionPerformed(ActionEvent e) {

 

if(e.getSource() == input)

{

display.append(myName.getText() + " >>  "+ input.getText() + "\n");  // 나가는 데이터를 나타내기 위해 >>

 

/* network로 데이터 전송 */  

// 데이터 전송시 바이트 단위로 전송

//

byte [] sendBuffer = input.getText().getBytes();  // input에서 getText를 바이트 단위로 변환해서 배열

 

// 전송할 데이터 패킷을 만듬

DatagramPacket sendPacket = new DatagramPacket(sendBuffer,sendBuffer.length, address, yourPort);  

// ; sendBuffer를 보낼거고, sendBuffer길이만큼 보내줄거고, 상대방주소에, 상대방포트 로 보내줄거임.  

 

try {

socket.send(sendPacket);  // send 시 에러가 생길수 있기 때문에 예외처리해줘야 함.

} catch (Exception e2) {

display.append("ERROR (send) : " + e2.getMessage() + "\n" );

}// tryCatch

 

//input.selectAll();

input.setText("");

 

}// if

 

}// actionPerformed

 

}// MyFrame Class

 

}// Chatting Class

 

 

public class Test {

 

public static void main(String[] args) {

 

Chatting chat = new Chatting();  // MyFrame Class 가 Chatting 클래스 안으로 들어갔기 때문에 

chat.receive();

 

}// main

 

}// Main Class

 

 

미국과 거의 같은 맛이라고 하는 IFC 지하 - 판다익스프레스


'ETC > 먹방' 카테고리의 다른 글

2019. 10. 13. 일. 점심.  (0) 2019.10.14
2019. 10. 05. 토. 저녁.  (0) 2019.10.09
2019. 09. 18. 수. 점심.  (0) 2019.09.18
2019. 09. 15. 일. 저녁.  (0) 2019.09.16
2019. 09. 06. 금. 저녁.  (0) 2019.09.08
양재 - PUB9595 / 몽골리안 덮밥
>


'ETC > 먹방' 카테고리의 다른 글

2019. 10. 05. 토. 저녁.  (0) 2019.10.09
2019. 09. 24. 화. 저녁.  (0) 2019.09.25
2019. 09. 15. 일. 저녁.  (0) 2019.09.16
2019. 09. 06. 금. 저녁.  (0) 2019.09.08
2019. 09. 06. 금. 점심.  (0) 2019.09.07


Sponsored By















+ Recent posts