CODE(5)
-
[Web] 에러 페이지 처리하기 (게시판 구현)
HTTP 오류 코드에 대해 처리할 수 있도록 설정, JSP를 작성해보자 웹 개발을 하면서 브라우저로 출력된 에러 페이지를 자주 봤을 것이다. 이러한 에러 페이지는 웹 컨테이너가 제공하는 기본 에러 페이지로, 오류뿐만 아니라 디렉토리의 구조, 톰캣의 버전 등이 노출되므로 웹 보안이 취약해진다(참고1). HTTP 상태 코드(Status Code)에는 200(성공), 404(찾을 수 없음), 500(내부 서버 오류) 등 클라이언트 요청에 대한 응답 코드가 많으니 확인해보도록 하자. 브라우저의 개발자모드 > Network 에서 확인 가능하다. web.xml에 404, 500오류에 대한 처리를 설정하는 '에러 페이지 처리' 주석 아래의 코드를 삽입한다. bbs index.html index.htm index.js..
2017.04.10 -
[Java 예제] 채팅(chatting)
자바로 서버-클라이언트 채팅 프로그램을 구현해보자 클라이언트 측에서는 AWT와 Swing을 적절히 섞어 UI를 구현하였다. 웹 프로그래밍만 하다보니 자바 GUI에 대해 무지한데, 채용공고를 보니 Swing 개발자도 구하고 있었다. 지금으로서는 API를 읽는 습관을 들이기 위해 사용한다고 생각하자. 소켓, 스레드뿐만 아니라 오버라이딩과 지네릭스까지 한 번쯤은 생각해보고 구현해보면 좋을 것 같은 예제다. /** * ChatClientMain.java * 채팅 클라이언트 Main 클래스 * @Date 2017. 2. 22. */ package com.multichat.client; import java.util.Random; public class ChatClientMain { public static voi..
2017.02.22 -
[Java 예제] 로또(a lottery)
자바로 콘솔에 로또 번호를 출력해보자import java.util.Random; import java.util.TreeSet; public class Lotto { int[] lotto; int length; Random random = new Random(); public void makeLotto() { lotto = new int[length]; lotto[0] = random.nextInt(45) + 1; int num = 0; while(num < length) { int temp = random.nextInt(45) + 1; lotto[num] = temp; for(int j = 0; j < num; j++) { if(lotto[j] == temp) { num--; break; } } num+..
2017.02.13 -
[Java 예제] 홀수 마방진(a magic square of odd order)
자바로 콘솔에 홀수 마방진을 출력해보자 마방진 원리, 마방진 만드는 법, 마방진 푸는 법 간단하게 구현하기 위해 조건이 많은 홀수 마방진 소스다. 시작(1)은 첫 번째 줄 중앙부터 시작하도록 하였다. 1부터 시작해 10시 방향(↖)으로 2차원 배열을 채워나간다. 향상된 for문과 2차원 배열을 익히기 좋은 예제다. 마방진은 짝수와 홀수의 풀이법이 다르므로 짝수 마방진은 다음 기회에... public class MagicSquare { public void drawMagicSquare(int size) {// Parameter: 마방진의 크기 int[][] ms = new int[size][size]; int center = size / 2; int x = 0; int y = center; ms[x][y]..
2017.02.11 -
[Java 예제] 다이아몬드(a diamond)
자바로 콘솔에 다이아몬드를 출력해보자 다이아몬드를 한 변씩 4가지 조건을 이용해 출력하는 소스다.3x3, 4x4 다이아몬드를 그리고, 좌표를 적어가며 규칙을 찾아낸다.무작정 코딩부터 하려는 습관에서 벗어나도록 노력해보자. 간단하지만 초보자들에겐 for문과 if문을 익히기 좋은 예제다. public class Diamond { public void drawDiamond(int length) {// Parameter: 변의 길이 int size = (length * 2) + 1; int center = size / 2; for (int i = 0; i < size; i++) { for (int j = 0; j < size; j++) { if((i + j == center) || (center + i == j..
2017.02.11