반응형
ByteUtil.java

해당 소스에 사용된 ByteUtil 클래스

TestRsa.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;
 
public class TestRsa {
    public static void main(String[] args) 
           throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException, IllegalBlockSizeException, BadPaddingException {
        SecureRandom random = new SecureRandom();
        KeyPairGenerator generator = KeyPairGenerator.getInstance("RSA");
        generator.initialize(2048, random);
 
        KeyPair pair = generator.generateKeyPair();
        Key publicKey = pair.getPublic();
        System.out.println("publicKey = " + publicKey);
 
        Key privateKey = pair.getPrivate();
        System.out.println("privateKey = " + privateKey);
 
        Cipher cipher = Cipher.getInstance("RSA");
        cipher.init(Cipher.ENCRYPT_MODE, publicKey, random);
        
        String text = "RSA 암호화!!";
        System.out.println("원본 : " + text);
 
        // String -> byte 변환
        byte[] t0 = text.getBytes();
        System.out.println("원본 바이트 : " + ByteUtil.toHexString(t0));
        
 
        // 인코딩
        byte[] b0 = cipher.doFinal(t0);
        System.out.println("인코딩 : " + ByteUtil.toHexString(b0));
        
        // 디코딩
        cipher.init(Cipher.DECRYPT_MODE, privateKey);
        byte[] b1 = cipher.doFinal(b0);
        
        System.out.println("디코딩 : " + ByteUtil.toHexString(b1));
        System.out.println("디코딩된 원본:" + new String(b1));
    }
}
cs

########### Console 결과 ###########

1
2
3
4
5
6
7
8
9
publicKey = Sun RSA public key, 2048 bits
  modulus: 24375096591711126055210512185359957069059389332115666685656256009167572767173223522908531449043521360276825613201726594898353846423279278285747007266846094212573914607322409575412719234320181695009686453504284619499201124842375042929556510354483722116550582489225345515352818937465595047638810682064411880791025358297049816845633188104939146545275383717858564379062518328967892129218263037788613461088589973921632894302911326334363077605546489131720190553333874412384419644166222126318457219924457347665925613430947371080765753200018907246728766599325596504477911485731278280070273136297987513034643007577899945186837
  public exponent: 65537
privateKey = sun.security.rsa.RSAPrivateCrtKeyImpl@ffc92d04
원본 : RSA 암호화!!
원본 바이트 : 52534120ec9594ed98b8ed99942121
인코딩 : 1556d68e09e782fd67d3d7413f535ca829526ba33ff7869d4c9a75d4ce5e0cf30333c390f01305041ad86fad071b6e5c935d47edbc2b4acd314f7adc54db6916dbe1bb48708d16adf0927aeb3f8b1a4461d15c34c74ce72dff5125ab66324db15630d9b59ca1bb2e205d656dff38461c282475035fed2095872971bb8f961cce2b2fa797b389d6a18704f2d8204510d819dcc2ccd05597fd5b04536d76698a15cf05f5800cbd86f5016916393b2fd5fbaa935b138f57ebff7825ae6812ebe41f1cc357fb33a62c55d23ad7d3ca3fb8ebeaa651f4842209b0e0128cda6520d1fe9e37af678e2a515eec9e79be6b480e2786c4fc42a23c4846a94d35ff105dd7c7
디코딩 : 52534120ec9594ed98b8ed99942121
디코딩된 원본:RSA 암호화!!
cs


반응형

'IT > 언어' 카테고리의 다른 글

시큐어 코딩 가이드  (0) 2014.05.29
ByteUtil.java  (0) 2014.05.29
Servlet Encoding Filter  (0) 2014.05.21
정규 표현식 예제  (0) 2014.05.21
Servlet 에러 페이지 처리  (0) 2014.05.21
반응형

EncodingFilter.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class CommonEncodingFilter implements Filter {
    private String encoding = null;
    protected FilterConfig filterConfig = null;
    public void init(FilterConfig filterConfig) throws ServletException {
        this.filterConfig = filterConfig;
        this.encoding = filterConfig.getInitParameter("encoding");
    }
 
   public void destroy() {
        this.encoding = null;
        this.filterConfig = null;
   }
 
   public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 
   throws IOException, ServletException {
        if (request.getCharacterEncoding() == null) {
            if (encoding != null) {
                request.setCharacterEncoding(encoding);
            }
        }
        chain.doFilter(request, response);
   }
 
    public FilterConfig getFilterConfig() {
        return filterConfig;
    }
 
    public void setFilterConfig(FilterConfig cfg) {
        filterConfig = cfg;
    }
}
cs

web.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
<filter>
    <filter-name>Encoding Filter</filter-name>
    <filter-class>com.exam.common.CommonEncodingFilter</filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>Encoding Filter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>
 
cs


반응형

'IT > 언어' 카테고리의 다른 글

ByteUtil.java  (0) 2014.05.29
RSA 암호화  (0) 2014.05.29
정규 표현식 예제  (0) 2014.05.21
Servlet 에러 페이지 처리  (0) 2014.05.21
Jquery validation  (0) 2014.05.21
반응형

정규 표현식

1
2
3
4
5
6
Pattern pattern = Pattern.compile("^[가-힣a-zA-Z]+$");
Matcher matcher = pattern.matcher(name);
if(!matcher.matches()){
    errMsg = "이름은 한글이나 영어만 가능합니다.";
    return false;
}
cs


반응형

'IT > 언어' 카테고리의 다른 글

RSA 암호화  (0) 2014.05.29
Servlet Encoding Filter  (0) 2014.05.21
Servlet 에러 페이지 처리  (0) 2014.05.21
Jquery validation  (0) 2014.05.21
tomcat7 SSL 설정  (0) 2014.05.19
반응형

400, 401, 404 ... 에러페이지 매핑


location 부분은 경로에 맞게 jsp 파일 생성해서 입력

web,xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<error-page>
    <error-code>401</error-code>
    <location>/error/error.jsp</location>
</error-page>
<error-page>
    <error-code>403</error-code>
    <location>/error/error.jsp</location>
</error-page>
<error-page>
    <error-code>404</error-code>
    <location>/error/404error.jsp</location>
</error-page>
<error-page>
    <exception-type>java.lang.NullPointerException</exception-type>
    <location>/error/error.jsp</location>
</error-page>
<error-page>
    <exception-type>java.lang.Throwable</exception-type>
    <location>/error/error.jsp</location>
</error-page>
<error-page>
    <exception-type>java.lang.Exception</exception-type>
    <location>/error/error.jsp</location>
</error-page>
cs

error,jsp

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<%
    out.print("status_code : ");
    out.print(request.getAttribute("javax.servlet.error.status_code"));
    out.print("<br />");
    out.print("<br />");
    out.print("exception_type : ");
    out.print(request.getAttribute("javax.servlet.error.exception_type"));
    out.print("<br />");
    out.print("<br />");
    out.print("message : ");
    out.print(request.getAttribute("javax.servlet.error.message"));
    out.print("<br />");
    out.print("<br />");
    out.print("exception : ");
    out.print(request.getAttribute("javax.servlet.error.exception"));
    out.print("<br />");
    out.print("<br />");
    out.print("request_uri : ");
    out.print(request.getAttribute("javax.servlet.error.request_uri"));
%>
cs


반응형

'IT > 언어' 카테고리의 다른 글

Servlet Encoding Filter  (0) 2014.05.21
정규 표현식 예제  (0) 2014.05.21
Jquery validation  (0) 2014.05.21
tomcat7 SSL 설정  (0) 2014.05.19
[LIB] STRUT2  (0) 2014.05.19
반응형

참조 : http://love2u.be/40

JqueryValidation.zip

+ jquery-1.4.2.min.js

+ jquery.validate.js

+ validation.js (예제)

Validation EX

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
$(document).ready(function() {
    $("#joinForm").validate({
        rules: {
            name:{required: true, minlength: 2, maxlength: 4, kor_eng: true},
            age :{required: true, minlength: 1, maxlength: 2, number: true},
            job :{required: true, minlength: 3, maxlength: 20},
            address :{required: true, minlength: 3, maxlength: 20},                    
        },
        messages: {
            name: {required: "이름을 입력하세요",minlength: jQuery.format("{0}자리 이상"),maxlength: jQuery.format("{0}자리 이하"), kor_eng: "한글과 영문만 가능"},
            age : {required: "나이를 입력하세요",minlength: jQuery.format("{0}자리 이상"),maxlength: jQuery.format("{0}자리 이하"), number: "숫자만 가능"},
            job : {required: "직업을 입력하세요",minlength: jQuery.format("{0}자리 이상"),maxlength: jQuery.format("{0}자리 이하")},
            address: {required: "주소를 입력하세요",minlength: jQuery.format("{0}자리 이상"),maxlength: jQuery.format("{0}자리 이하")},
        },
        success: function(label) {
            label.html(" ").addClass("checked");
        }
    });
});
cs


반응형

'IT > 언어' 카테고리의 다른 글

정규 표현식 예제  (0) 2014.05.21
Servlet 에러 페이지 처리  (0) 2014.05.21
tomcat7 SSL 설정  (0) 2014.05.19
[LIB] STRUT2  (0) 2014.05.19
[LIB] JSON  (0) 2014.05.19
반응형
반응형

'IT > 언어' 카테고리의 다른 글

Servlet 에러 페이지 처리  (0) 2014.05.21
Jquery validation  (0) 2014.05.21
[LIB] STRUT2  (0) 2014.05.19
[LIB] JSON  (0) 2014.05.19
BSON encode/decode  (0) 2014.05.15
반응형

STRUTS2 사용시 필요한 최소 LIB


struts2.zip

+ commons-fileupload-1.3.1

+ commons-io-2.2

+ commons-lang-2.4

+ commons-lang3-3.1

+ commons-logging-1.1.3

+ commons-logging-api-1.1

+ commons-validator-1.3.1

+ freemarker-2.3.19

+ javassist-3.11.0.GA

+ ognl-3.0.6

+ struts2-core-2.3.16.3

+ struts-core-1.3.10

+ xwork-core-2.3.16.3

반응형

'IT > 언어' 카테고리의 다른 글

Jquery validation  (0) 2014.05.21
tomcat7 SSL 설정  (0) 2014.05.19
[LIB] JSON  (0) 2014.05.19
BSON encode/decode  (0) 2014.05.15
BSON 이해하기  (0) 2014.05.14
반응형

JSON 사용시 필요한 LIB


lib_JSON.zip


+ commons-lang 2.5

+ commons-lang 2.5

+ commons-beanutils

+ commons-collections 3.1

+ commons-logging 1.1.1

+ ezmorph 1.0.6

+ json-lib-2.1-jdk15


반응형

'IT > 언어' 카테고리의 다른 글

tomcat7 SSL 설정  (0) 2014.05.19
[LIB] STRUT2  (0) 2014.05.19
BSON encode/decode  (0) 2014.05.15
BSON 이해하기  (0) 2014.05.14
텍스트 파일 입출력 Example  (0) 2014.01.27
반응형

BSON

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
BSONObject doc = new BasicBSONObject();
doc.put("name""MongoDB");
doc.put("type""database");
doc.put("count"1);
BSONObject info = new BasicBSONObject();
info.put("x"203);
info.put("y"102);
doc.put("info", info);
        
BasicBSONEncoder encoder = new BasicBSONEncoder();
byte[] encoded = encoder.encode(doc);
for(int i = 0; i < encoded.length ; i++
System.out.print(String.format("0x%02X ", encoded[i]));
        
System.out.println();
        
BasicBSONDecoder decoder = new BasicBSONDecoder();
BSONObject decoded = decoder.readObject(encoded);
System.out.println("decoded = " + decoded);
cs


반응형

'IT > 언어' 카테고리의 다른 글

[LIB] STRUT2  (0) 2014.05.19
[LIB] JSON  (0) 2014.05.19
BSON 이해하기  (0) 2014.05.14
텍스트 파일 입출력 Example  (0) 2014.01.27
[펌][WEB] ajax 크로스도메인 설정~~  (0) 2013.12.18
반응형
문제:

한 달 전 즈음, 자바스크립트 스터디를 하면서,
K과장님이 BSON을 쓰는 경우가 있었냐는 질문을 하셨더랬다.
당시에는 BSON이 Binary JSON의 약어라고만 알고 있었고,
실제로 써본 적도 없었기에 '잘 모른다'고 대답하고 말았다.


그리곤 잊고 있다가,
얼마 전에 사내 위키에서 'BSON으로 인코딩해서 보낸다'라는 문구를 만나게 돼서,
이 참에 자세히 한 번 살펴봤다.


BSON 스펙을 정의한 사이트와 자세한 설명은 아래 링크에서 확인할 수 있다.


간단히 정리해보면, 다음과 같다.

BSON 은 Binary JSON의 약어로, JSON 문서를 바이너리로 인코딩한 포맷이다.
최초에 몽고 DB에서 제안하였으며, 주로 JSON 형태의 데이터를 저장하거나 네트워크 전송하는 용도로 사용된다.
바이너리 데이터를 JSON 구조에 추가할 수 있다는 장점이 있다.

헌데, 스펙 페이지의 하단에 JSON을 BSON으로 변환한 예제가 있는데,
이게 잘 이해가 되지 않더라.



실제로 JSON을 BSON으로 컨버팅할 땐 라이브러리를 사용할테니 몰라도 큰 문제가 없겠지만,
그래도 좀 궁금해서 하나하나 천천히 살펴봤다.

이 과정이 잘 이해가 되지 않는 다른 분들도 있을 것 같아 메모해둔다.


해결책:

예제를 보기 전에 먼저, BSON은 리틀 엔디안 방식으로 작성한다는 것에 주의한다.
(즉, 하위 바이트를 앞쪽에 쓴다.)

스펙의 예제에 나와있는 

    {"hello": "world"}

를 BSON으로 나타내면 아래와 같다.

     \x16\x00\x00\x00\x02hello\x00\x06\x00\x00\x00world\x00\x00


변환 과정을 설명하면 다음과 같다.

    1. BSON 도큐먼트를 정의한다.

    \x16\x00\x00\x00\x02hello\x00\x06\x00\x00\x00world\x00\x00

    전달하려는 총 바이트의 크기를 int 32로 추가한다.
    여기서는 총 22바이트(\x16)인데, 리틀 엔디안 방식으로 전달해야 하기 때문에,
    하위 바이트인 \x16을 먼저 쓴다.
    도큐먼트의 마지막을 나타내는 바이트로 마지막에 \x00 을 추가한다.


    2. 데이터의 타입을 정의한다.

    \x16\x00\x00\x00\x02hello\x00\x06\x00\x00\x00world\x00\x00

    키에 해당하는 데이터의 타입을 나타내는 코드를 추가한다.
    여기서는 "world"이고, UTF-8 string 이기 때문에 \x02를 추가했다.


    3. 키값을 정의한다.

    \x16\x00\x00\x00\x02hello\x00\x06\x00\x00\x00world\x00\x00    
    
    키 값은 UTF-8 인코딩된 문자열과 문자열이 끝났음을 알려주는 \x00을 추가한다.


    4. 데이터를 정의한다.

    \x16\x00\x00\x00\x02hello\x00\x06\x00\x00\x00world\x00\x00    

    string을 표기할 때에는 초기 4바이트에 종료 문자(\x00)을 포함한 문자열의 길이를 추가한다.
    여기서, 5바이트 크기인 "world"와 종료문자를 포함해 \x06을 길이로 추가했고,
    리틀 엔디안으로 표기해야하기 때문에 "\x06\x00\x00\x00" 와 같이 작성했다.


    5. 문서의 마지막임을 알린다.

    \x16\x00\x00\x00\x02hello\x00\x06\x00\x00\x00world\x00\x00

    1번에 설명했던 것처럼, BSON 도큐먼트가 종료되었음을 알리는 종료 문자를 마지막에 추가한다.




다른 예제로, 배열을 포함한 문서의 변환 과정을 설명하면 다음과 같다.

    {
      "BSON": [
       "awesome", 5.05, 1986
      ]
    }

    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

순서대로 읽어보면 아래와 같다.


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00


    총 길이 49바이트의 BSON 문서이고,


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    데이터는 Array 타입이고,


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    키 값은 BSON!


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    BSON에서 Array는 인덱스를 키로 갖는 문서와 동일하게 취급한다.
    따라서, 위의 예제에서의

        [ "awesome", 5.05, 1985 ]

    는 아래와 같은 도큐먼트라 생각하고 변환하면 된다.

        { "0": "awesome", "1": 5.05, "2": 1985 } 

    문서의 처음은 Array 데이터의 총 길이인 38바이트를 리틀 엔디안으로 표기한 \x26\x00\x00\x00 이다.


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    첫 번째 키에 해당하는 데이터의 타입은 string이다.


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    키 값은 0이고,


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    데이터의 크기는 종료 문자를 포함해 8바이트이다.


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    문자열의 값은 awesome


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    두 번째 데이터는 double 타입의 숫자이고,


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    키 값은 "1"이다.


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    BSON에서 double은 IEEE 754의 기준에 따라 8바이트로 표기한다.
    (5.05를 바이너리 데이터로 전환하는 게 잘 되지 않네요.-_- 과정을 아시는 분은 좀 알려주세요~~)


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    세 번째 데이터는 4바이트 크기의 정수이다.


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    키 값은 "2"이고,


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    1986을 4바이트로 표기한다.


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    Array를 포함한 문서가 종료되었음을 알리고,


    \x31\x00\x00\x00\x04BSON\x00
    \x26\x00\x00\x00\x020\x00\x08\x00\x00\x00awesome\x00\x01
    1\x00\x33\x33\x33\x33\x33\x33\x14\x40\x102\x00\xc2\x07\x00\x00\x00\x00

    전체 데이터가 종료된 것을 알린다.


반응형

'IT > 언어' 카테고리의 다른 글

[LIB] JSON  (0) 2014.05.19
BSON encode/decode  (0) 2014.05.15
텍스트 파일 입출력 Example  (0) 2014.01.27
[펌][WEB] ajax 크로스도메인 설정~~  (0) 2013.12.18
log4j 에서 ibatis 쿼리 로그 남기는 방법  (0) 2013.11.26

+ Recent posts