생각의 함정
카테고리 인문
지은이 자카리 쇼어 (에코의서재, 2009년)
상세보기

 전 회사 동료들과 술을 마시며 우리들의 착각하거나 잘못된 집착에 대해 이야기했다. 그러면서 이 책을 소개 받았다. 
과거사를 통해 잘못된 사고에 원인 결과 대해 나타내고 있다. 좁은 정보에 확신하지 말고 넓게 보자 이런 내용? ? 
IT에 관심이 많다보니 IBM을 다시 일으킨 루이 가트너 이야기와 프랑스의 한 부부 이야기가 인상 깊었다.  중산층인 
이 부부는 파티를 가기위해 부자 친구로 부터 다이아몬드 목걸이를 빌렸는데 파티에서 잊어버리고 말았다.
 이 부부는 비슷한 목걸이를 부자친구에게 사주고 10년동안 빛을 갚으며 고통스럽게 보내던 어느날 부자친구를 다시 
만나게 된다. 부자친구에게 그동안 있던 이야기를 해주었다. 부자친구는 놀라며 그 목걸이는 모조품에 지나지 않은 
싸구려였다는 대 반전내용이다. 

책을 안 읽어서 그런지 무지하다는 걸 느꼈다. 

교조 : 역사적 환경이나 구체적 현실과 관계없이 어떠한 상황에서도 절대로 변하지 않은 진리

페르소나(라틴어): 지혜와 자유의사를 갖는 독립된 인격적 실체

헤게모니(독일어): 주도권, 우두머리 자리에서 전체를 이끌거나 주동할 수 있는 권력

입적 : 어떤 사람이 어떤 가의 가족인 신분을 획득하는 일

명약관화 : 밝기가 불을 보는 것과 같다는 뜻 , 의심할 여지없이 매우 분명하다는 말

정태 : 움직이지 않고 가만히 있는 상태 
CTS(Common Type System)
닷넷 프레임워크는 여러 다른 언어가 동일한 데이터형을 사용하도록 공통언어를 사용하고 있다. 



값형은 데이터를 메모리의 스택영역에 저장(값) - 변수 복하면 새로운 영역으로 저장됨
int, float, struct, enum 등
참조형은 데이터를 힙영역에 저장(주소저장)
class, interface, delegate

출처 : http://cafe.naver.com/headstudy.cafe?iframe_url=/ArticleRead.nhn%3Farticleid=834

com을 등록하는 방법을 찾다가 우연치 않게 발견한 것이다. ㅠㅠ.. 

네이버 카페에서 퍼온글이며 문제가 있을 경우 삭제하겠습니다. 


안녕하세요. 마리입니다. ^^;

 

제가 또 뉴스그룹 서핑 도중... 질문을 하나 만났습니다.

 

"C#으로 COM을 생성하고 asp에서 VB나 C++의 COM처럼 사용할 수 있을까요?"

 

답변은 할 수 있다는 것이였습니다.

 

"C# 으로 만든 컴포넌트는 CCW( COM Callable Wrapper) 에 의해서 regsvr32.exe 로 COM 개체

 

를 등록된 것과 같은 효과로 등록되어질 수 있습니다."

 

저도 궁금하기도 하고 호기심도 생기고 해서... 테스트를 해보려고 맘 먹었습니다.

 

그런데 COM을 첨 해보는지라... 좀 헤맸습니다. ㅋㅋ

 

간단하게 테스트 예제와 함께 과정을 살펴보겠습니다.

 

(아래의 과정은 MS웹 사이트의 기술자료 http://support.microsoft.com/default.aspx?scid=kb;ko;306296 의 방법으로 한 것 입니다.)

 

먼저 새 프로젝트로 C#프로젝트에서 클래스 라이브러리를 하나 만듭니다.

 

이름은 ServicedCOM으로 하겠습니다.

 

자동 생성된 클래스 Class1의 이름을 Com_Test로 변경합니다. 아래... 생성자도 변경 하시는거

 

아시죠? ^^; 소스를 보여드리겠습니다.

 

using System;
using System.EnterpriseServices;

namespace ServicedCOM
{

   public class Com_Test : ServicedComponent
   {
      public Com_Test()
      {   
      } 
      public string DoTrans()
      {   
         return ".NET COM+ Testing";
      }  
   }
}

 

만약에 System.EnterpriseServices네임스페이스가 자동 완성되지 않으신다면...

 

솔루션 탐색기에서 참조추가를 합니다. 거기서 .NET 탭중 쭉..내리시면 있습니다.

 

등록을 해주세요. 소스는 간단한 문자열을 리턴하는 소스입니다.

 

이제 AssemblyInfo.cs파일에서 추가를 합니다.

 

System.EnterpriseServices 역시 상단에 using키워드로 명시하시구요.

 

[assembly: ApplicationActivation(ActivationOption.Library)]
[assembly: ApplicationName("Com_Test")]

 

이제 컴파일을 합니다. 그럼 dll파일이 하나 생기겠죠?

 

이제 어셈블리 이름을 강력하게 지정해야 합니다.

 

  1. 시작 메뉴에서 프로그램을 가리키고 Microsoft Visual Studio .NET을 누른 다음 Visual Studio .NET Tools를 눌러 Visual Studio .NET 명령 프롬프트를 엽니다.
  2. 명령 프롬프트에서 sn.exe -k ServicedCOM.snk를 입력하여 어셈블리에 강력한 이름을 지정합니다.

    강력한 이름으로 어셈블리에 서명하는 방법에 대한 자세한 내용은 .NET Framework SDK 설명서를 참조하십시오.
  3. ServicedCOM.snk를 프로젝트 폴더에 복사합니다.
  4. AssemblyInfo.cs에서 AssemblykeyFile 코드를 다음 코드로 대체합니다.
    [assembly: AssemblyKeyFile("..\\..\\ServicedCOM.snk")]

자... 이제 레지스트리에 등록을 해야 합니다.

 

  1. 시작 메뉴에서 프로그램을 누르고 Microsoft Visual Studio .NET을 누른 다음 Visual Studio .NET Tools를 눌러 .NET 명령 프롬프트를 엽니다.
  2. .NET 명령 프롬프트에서 regsvcs 프로젝트경로\bin\Debug\servicedcom.dll을 입력합니다. 그러면 클래스와 같은 이름의 COM+ 라이브러리 응용 프로그램이 만들어집니다.

이제 완료가 되었습니다.

 

간단한 asp코드로 테스트를 해보세요.

 

<%
set Com = server.createobject("ServicedCOM.Com_Test")
response.write Com.DoTrans()
%>

 

 

 

서핑 하던 도중 다른 방법도 있군요...

 

 

using System;

namespace ServicedCOM
{

   public class Com_Test

   {
      public Com_Test()
      {   
      } 
      public string DoTrans()
      {   
         return ".NET COM+ Testing";
      }  
   }
}

 

어셈블리쪽은 건드리지 마세요. 아... 위의 소스가 아니고 첨의 그대로...

 

regasm 프로젝트경로\bin\Debug\ServicedCOM.dll /codebase

 

이렇게 하면 COM에 등록이 됩니다. 사용법은 위와 동일하구요....

웹서비스 이해하려고 노력중이지만 아직 뭔 개념이 많은지.. 해매고 있다가 웹에서 찾은 이클립스 셋팅 방법을 보고 
나름대로 정리하려고 한다. 그분께 감사하고 링크를 걸려고 했는데 못 찾겠당.. ㅎㄷㄷ 

기본적으로 자바설치와 톰켓 설치는 되어 있다. (톰켓은 설치라기 보다는 그대로 받아서 특정폴더에 위치) 

또한 가니메데(이클립스) 버전을 사용하고 있다.


흠... 막막하다. ㅋㄷ 이제 시작


http://ws.apache.org/axis2/download/1_4_1/download.cgi  
Standard Binary Distributionzip파일을 다운 받는다.(오른쪽 끝에 있다)

다운을 받은 후 압축을 풀어서 C폴더나 넣고 싶은데 넣는다. (예: C:\axis2-1.4)

다시 이클립스로 돌아와서 [Window] - [Prefrences] 클릭한다. 


폴더를 잡아 달라고 하는 것 같다. (느낌상)... 


오 success .. ok를 누르고 닫는다. 


[File]-[New]-[Other]를 선택하고 Dynamic Web Project를 선택한다. (다른 프로젝트도 되지 않을까??  안해봤다.)


Target Runtime을 설정하여 준다. New를 누른다. 




JRE까지 설정(필수 아님) 하고 Finish를 누른다. 


Configuration에서 Modify를 누르자 


Axis2 나온 부분을 전부 체크하고 OK를 누른다. 

[Window] - [Show View] - [Other..] 누르고 Server를 선택하여 서버창을 보이게 하자 


이렇게 하면 서버창이 하단에 보인다. (나만 어려운 건가??? ㅋㄷ)


서버를 추가한다. 



적당히 선택하고 Finish....  추가해 준다. 


밑에 파란줄로 되어 있는 부분을 두번 클릭하니 이 화면이 나온다.  왼쪽 밑에 체크하고  서버를 시작한다. 


이걸 모르진 않겠지만 ㅋㅋㅋㅋ 


이 화면이 나온다면 제대로 설치 완료된 것이다. (http://localhost:8080/server/axis2-web/)

Services라는 것을 눌러보자 


머 서비스하는게 기본적으로 Version보여주는 것이 설치 되어 있다고 한다. 갑자기 크롬에서 IE로 바꾼 이유는 xml이 안 보이네 크롬에서 .ㅋㄷ  Version을 눌려보면 WSDL이 나온다. 

간단한 테스트 get방식으로 테스트가 가능하다. 주소창에 
http://localhost:8080/server/services/Version/getVersion 입력 


이 화면이 나온다면 정상적으로 응답을 받은 것이다. 흠.. 자바파일을 만들어서 하는 테스트는 다음 번에 써야겠다. 
화면캡처가 힘들구나... 쩝 실제 화면인지 알고 캡처한 그림을 클릭하는 실수를... 뜨헉.. 


회사에  asp와 웹서비스 연동이 필요해서 만든 메뉴얼..(????)
-------------------------------------------------
Web Service..
좋은 놈이져.. 다들 아시리라 생각하고 설명은 생략하겠습니다.

우리가 사용하고 있는 asp(classic asp)에서는 기본적으로 Web Service와의 연동이 불가능합니다.

그러나 하면된다!!! 의 정신으로 하다보면 asp에서도 웹서비스 연동이 가능합니다.

바로 Soap Toolkit 3.0을 이용하는 방법입니다.

애초에 Soap ToolkitVS용으로 나왔지만, asp에서도 사용가능 합니다.

현재 버전 3.0까지 나왔으며 더 이상의 버전없은 없습니다.

이 후에 대해 관심 있으신 분은 WSE(Web Service Enhancements)를 검색해 보시면 되며 현재 최신 역시 3.0 입니다.

그 이후는 또 WCF(Windows Communication Foundation)로 이어집니다. ~

Soap Toolkit 다운은 아래에서..

http://www.microsoft.com/downloads/details.aspx?FamilyID=c943c0dd-ceec-4088-9753-86f052ec8450&DisplayLang=en

이와 함께 깔아야 되는 것이 MSXML 4.0 입니다.

개발자들은 많이 깔려있지만 일반 서버는 안깔려 있을 수 있습니다. 다운은 역시 아래..

(이것 때문에 삽질 했다는 사례 몇몇 봤습니다.)

http://www.microsoft.com/downloads/details.aspx?displaylang=ko&FamilyID=3144b72b-b4f2-46da-b4b6-c5d7485f2b42

위의 두개를 깔고 나면 soap client가 등록이 됩니다.

ClientPropertyhttp로 읽어들인다고 설정 한 후, MSSoapInit을 이용하여 wsdl을 읽어들입니다.

(로컬에 wsdl을 받은 후 읽는것도 가능합니다.)

그 후 사용하면 됩니다. 간단합니다. =_=

아래는 샘플 소스 입니다.

해석이 필요하시면 도움말을 보세요 soal tookit 깔면 생깁니다.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >

<head>

  <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />

  <title>제목 없음</title>

</head>

<body>

  <%

   Dim obj, objXML

   Dim sStr

  

   Set objSoap = Server.CreateObject("MSSOAP.SoapClient30")

   Set objXML = Server.CreateObject("MSXML.DomDocument")

  

   objSoap.ClientProperty("ServerHTTPRequest") = true

   objSoap.MSSoapInit("http://wevservice.address/service.asmx?WSDL")

  

   sStr = objSoap.RequestOrder("<maxmovie></maxmovie>")

  

   Set objSoap = Nothing

   Set objXML = Nothing

  %>

 

  <textarea rows="20" cols="100">

  <%=Response.Write(sStr) %>

  </textarea>

</body>

</html>

한국골프대학 공지사항, 자유게시판, 이미지갤러리 만들게 되었다. 

서버에 적용하다보니 로그인이 제대로 구현이 되어 있지 않았다. 업체와 연락을 하여 겨우 적용 시켰다. 


CSS 책 추천
Head First HTML with CSS & XHTML
엘리자베스 프리먼,에릭 프리먼 공저/홍형경 역
CSS 완벽 가이드
에릭 마이어 저/남덕현,이준 등역
크리에이티브 디자이너를 위한 웹 표준
송태민 저
예스24 | 애드온2

헤드퍼스트는 벌써 샀지만 너무 기초라서 읽다가 지루해지기 시작했다. 모르는 것에 대해서 보는 것 좋은데 
웹개발 4년차로 HTML, 자바스크립트에 대해서는 알지만 CSS에 대해서는 디자이너 영역이라고 생각하고 
별 다른 노력을 안했지만 요즘 뜨는 자바스크립트 때문에 중요성과 어떤 브라우저에서도 잘 동작하는 웹을 
만들고 싶다.
 흠 어떤 책을 사면 좋을까? 고민이다. 완벽가이드는 어렵다고 하던데.. 일단 서점에 가서 봐야 겠다. 
누가 좋은 책 추천해줄 사람 없나요?? ㅋㄷ 
계층형 게시판의 경우 최근 답변이 위로 올라오는 형태를 많이 보았다.  하지만 내가 보기에는 아래로 나열 되는 것이 훨씬 더 추적(?) 하기 쉽게 느껴졌다. 최신 답변이 위로 올라올 경우 로직상 편리함이 있다는 사실은 알고 있지만 어자피 유저는 로직따위에는 관심이 없다. 화면에 어떻게 보여지는가 중요하다는 것.. 잡소리는 그만하고 구현 방법에 대해 연구해 보려 한다. 

일단 설명을 자세히 쓴다고 했지만 내용이 이해가지 않는 사람(?) 있을 것이다. (없을 것이라 믿는다... )
그럼 데이터베이스에 그냥 테스트 해보자 그럼 어떤 원리인지 대충 감이 올 것이다
데이터베이스 영역만 회색으로 표시를 해두었다. 무조건 날려보자 하나씩..  

CREATE TABLE BOARD(
BOARD NUMBER NOT NULL,
BGROUP NUMBER NOT NULL,
SORTS NUMBER NOT NULL,
DEPTH NUMBER NOT NULL,
SUBJECT VARCHAR(255)
);

 BOARD BGROUP  SORTS  DEPTH  SUBJECT
         

간단하게 5개가 필요하다  
board : 고유번호
bgroup : 그룹
sorts : 정렬
depth : 깊이
subject : 제목

기본적으로 두개를 추가해본다. 

INSERT INTO BOARD VALUES ('1', '1', '0','0','1번글'); 
INSERT INTO BOARD VALUES ('2', '2', '0','0','2번글');

 board  bgroup  sorts  depth  subject
 1  1  0  0 1번글
 2  2  0  0 2번글

리스트 쿼리를 통해 보도록 하겠다. 

SELECT * FROM BOARD ORDER BY BGROUP DESC, SORTS ASC

 board  bgroup  sorts  depth  subject
 2  2  0  0 2번글
 1  1  0  0 1번글

이제 시작이다. 조회를 할때는 위에 SELECT문으로 조회하자

자 이제 답변에 따라서  2가지로 나눠 진다. 
1. 최신글이 위로 올라가는 형태
2. 최신글이 아래로 내려가는 형태 (1번을 무시하고 봐도 무방!)

1. 답변 최신글이 위로 올라가는 형태

* 공식
1.UPDATE BOARD SET SORTS = SORTS + 1 
  WHERE BGROUP =  (원글의 BGROUP)  AND SORTS >(원글의 SORTS)
2. INSERT INTO BOARD VALUES
   (번호, (원글의 BGROUP), (원글의 SORTS +1), (원글의 DEPTH +1) ,'
 제목')

이렇게 두가지만 해주면 된다. 이해를 위해 따라 해보자
2번글(원글)에 대해서 답변을 달아 보겠다. 
필요한 것은 2번글에 대한 bgroup, sorts, depth에 대한 정보가 필요하다.  비교적 간단하다. 

INSERT INTO BOARD VALUES ('3','2','1','1','2번글 - 1')

bgroup : 2번글과 동일
sorts : 2번글 + 1
depth : 2번글 + 1 을 해준다. 

 BOARD  BGROUP  SORTS  DEPTH  SUBJECT
 2  2  0  0  2번글
 3  2  1  1  2번글 - 1
 1  1  0  0  1번글

하나더 추가해보자 

*INSERT문 하기 전 반드시 해주어야 할 것이 있다. 바로 SORTS는 증가 시켜야 한다는 것이다. 

UPDATE BOARD SET SORTS = SORTS + 1 WHERE BGROUP =  2  AND SORTS > 0

2번글 GROUP과  SORT를 정보를 가지고 UPDATE 시킨다. 

INSERT INTO BOARD VALUES ('4','2','1','1','2번글 -2')

 board  bgroup sorts depth subject 
 2  2  0  0  2번글
 4  2  1  1  2번글-2
 3  2  2  1  2번걸-1
 1  1  0  0  1번글

공식은 나왔다.  깊이도 상관없이 잘 된다. 테스트를 위해 데이터를 더 집어 넣고 확인해보자

UPDATE BOARD SET SORTS = SORTS + 1 WHERE BGROUP =  2  AND SORTS > 1;
INSERT INTO BOARD VALUES ('5','2','2','2','2번글-2-1');

 board  group  sort  depth  subject
 2  2  0  0  2번글
 4  2  1  1  2번글-2
 5  2  2  2  2번글-2-1
 3  2  3  1  2번글-1
 1  1  0  0  1번글

UPDATE BOARD SET SORTS = SORTS + 1 WHERE BGROUP =  2  AND SORTS > 3;
INSERT INTO BOARD VALUES ('6','2','4','2','2번글-1-1');

 board  bgroup  sorts  depth  subject
 2  2  0  0  2번글
 4  2  1  1  2번글-2
 5  2  2  2  2번글-2-1
 3  2  3  1  2번글-1
 6  2  4  2  2번글-1-1
 1  1  0  0  1번글

흠... 간단하군.. 

2. 답변 최신글이 아래로 내려가는 형태
  우선 이야기하자면 약간 복잡하다. 일단 공식을 보자 

*공식
1. SELECT NVL(MIN(SORTS),0) FROM BOARD
   WHERE  BGROUP = (원글의 BGROUP)
   AND SORTS > (원글의 SORTS)
   AND DEPTH <= (원글의 DEPTH)

2-1. 1번이 0 일 경우 

3. SELECT NVL(MAX(SORTS),0) + 1 FROM BOARD 
    WHERE BGROUP = (원글의 BGROUP);

4. INSERT INTO BOARD VALUES 
   (번호, (원글의 BGROUP), (3번값), (원글의 DEPTH +1) ,' 제목')

2-2. 1번이 0이 아닐 경우 

3. UPDATE BOARD SET SORTS = SORTS + 1 
  WHERE BGROUP =  (원글의 BGROUP)  AND SORTS >= (1번값)

4. INSERT INTO BOARD VALUES 
   (번호, (원글의 BGROUP), (1번값), (원글의 DEPTH +1) ,' 제목')

1번에 따라 2단계로 나눠진다. 말하자면 1번에서 SORTS를 구하는 것이다. 
만약 0일 경우 맨 마지막 오는 경우이다.
아닐 경우 중간에 넣는 것인데 중간이후에 있는 다른 것들을 SORTS를 1씩 더해주고 넣는 것이다.

일단 답변이 위로 가는 것을 해보신 분들을 위해서 DELETE문이 있다. 안 해본신 분은 살짝 무시해주자.

DELETE FROM BOARD WHERE SORTS > 0

시작이다. 시작 전에 SELECT문은 이 형태이다. 

SELECT * FROM BOARD ORDER BY BGROUP DESC, SORTS ASC

 board  bgroup  sorts  depth  subject
 2  2  0  0 2번글
 1  1  0  0 1번글

2번글에 대한 답변을 달겠다.

SELECT NVL(MIN(SORTS),0) FROM BOARD
   WHERE  BGROUP = 2
   AND SORTS > 0
   AND DEPTH <= 0

0이 나오는 경우이다. 2-1의 공식으로 진행되어야 한다. 

SELECT NVL(MAX(SORTS),0) + 1 FROM BOARD WHERE BGROUP = 2;

처음 답글이라 수행할 필요없는 구문이지만 우리는 알 수가 없다. 1이 나온다. 이것이 답글이 SORTS가 되는 것이다.

INSERT INTO BOARD VALUES (3, 2, 1, 1 ,'2번글-1')

bgroup : 원글의 bgroup
sorts : 계산한 값
depth : 원글의 depth+1

 board bgroup  sorts  depth  subject 
 2  2  0  0  2번글
 3  2  1  1  2번글-1
 1  1  0  0  1번글

2번글에 대하여 또다시 답글을 달아보자

SELECT NVL(MIN(SORTS),0) FROM BOARD
   WHERE  BGROUP = 2
   AND SORTS > 0
   AND DEPTH <= 0;

SELECT NVL(MAX(SORTS),0) + 1 FROM BOARD WHERE BGROUP = 2;

INSERT INTO BOARD VALUES (4, 2, 2, 1 ,'2번글-2');

물론 0이 나와 2-1 공식에 따르게 된다. 

 board  bgroup sorts  depth  subject 
 2  2  0  2번글
 3  2  1  2번글-1
 4  2  2   2번글-2
 1  1  0  0  1번글

이제 '2번글-1' 에 대한 답변을 달아 보겠다. 

SELECT NVL(MIN(SORTS),0)
FROM BOARD WHERE  BGROUP = 2
AND SORTS > 1
AND DEPTH <= 1;

2가 나올 것이다. 이럴 경우 2-2공식을 이용해야 한다. 빨간색부분을 유의하자 같은 것보다 큰 것이다.

UPDATE BOARD SET SORTS = SORTS + 1 
WHERE BGROUP = 2  AND SORTS >= 2

즉 2번글-2 의 sorts 번호를 올려주고 중간에 밀어 넣는 것이다. 

INSERT INTO BOARD VALUES (5, 2, 2, 2 ,'2번글-1-1')

bgroup : 2번글-1 의 bgroup  
sorts : 계산값
depth : 2번글-1의 depth + 1

 board  bgroup  sorts  depth  board
 2  2  0   0  2번글
 3  2  1  1  2번글-1
 5  2  2  2  2번글-1-1
 4  2  3  1  2번글-2
 1  1  0  0  1번글

board 번호 3번과 4번 사이에 밀어 넣음을 알 수 있다.  

가장 궁금한 것은 공식을 나누는 1번 공식일 것이다. 

SELECT NVL(MIN(SORTS),0) FROM BOARD
   WHERE  BGROUP = (원글의 BGROUP)
   AND SORTS > (원글의 SORTS)
   AND DEPTH <= (원글의 DEPTH)

자세히 보면 원글의 답글의 SORTS 큰 것 중에서 DEPTH 깊은 것을 제하고 가장 작은 SORTS값을 구하는 것이다. 
설명하기가 나의 실력으로는 이해하기 힘들다. 그냥 쓴다.  

더 나은 설명이나 더 좋은 게시판 로직이 있으면 알려주시기 바라면서 이렇게 글을 쓴다. 특히 아래로 떨어지는 것에 대한 게시판 로직이 좀 더 편한 방법이 없는지 궁금하다. 위아래로 떨어지는 방식에 대해서 성능상 이슈나 뭐 그런것에 대하여 태클은.... 어자피 내가 만든 로직도 아니니.. 친철한 설명으로 가르쳐주실 바라며 글을 마친다.  





+ Recent posts