http://fromkbs.net

실버라이트를 계속 공부 하였고, 머리속으로 구상은 계속 하고 있었는데 이제서야 완성하게 되었다. 내 머리속에 있는 구현하려고 했던 기능와 샤방한 디자인 등등은 구현하지 못했다 ㅜ.ㅜ.

검색어를 치게 되면 지마켓, 옥션, 11번가 세 온라인 쇼핑몰에서 상품리스트들을 가져와 한페이지에 노출되게 한다. 한쇼핑몰당 9개의 상품이 나타나게 되는데 간략하게 상품 이미지와, 가격, 그리고 링크할수 있는 링크 버튼을 넣었다. 상품을위에 올리게 되면 디테일한 상품 정보가 나온다. 디테일이라고 해봤자 상품명과, 배송비 유무까지만 이지만 ^^;

검색을 하게 되면 각 쇼핑몰의 현재 가장잘 팔리는 인기상품이 나타난다. 그래서 디테일한 상품리스트를 쭈~~~욱 볼수는 없다.. 그래서 검색을 할땐 검색어 단어를 잘 선택해야 한다.

'모니터'란 검색어보단 '2333hd' <- 이렇게 특정 상품 모델명을 검색하던지,
'아이팟'란 검색어보단 '아이팟 터치 16g' <- 이렇게 디테일한 상품 옵션으로 검색하면 그래도 어느정도 내가 원하는 결과는 나올것이다.

User inserted image


원래는 게시판으로 만들까 하다가 시간이 오래 걸릴것 같아서 메모장 식으로 먼저 만들어 봤다 솔직히 이미 올려진 것과 비교했을때 실버라이트로 페이징 처리 하는것과 바인딩을 처리를 하는것을 추가하고 특별이 더 한것은 없는것 같다.

이미 올려진것과 같은 테이블을 사용하기 때문에 같은 결과물이 나올것이다. 그리고 DB 역시 MySql을 사용하여 Xml로 통신하게 처리하였다.


 

구상을 멋지게 했는데 결과는 이렇게 나왔다 ^^;;; 뭔가 너무 허접하게 나왔다.. 멋진 애니메이션과 화려한 효과를 원했건만.. 그래도 Mysql을 이용한것에 의의를 가져야 겠다.

DB를 이용해서 간단한 메모를 기록할수 있는 프로그램을 만들어 봤다. 일단 DB는 Mysql 을 이용하였다. 공식적으로 실버라이트는 Mysql을 이용하기 위해 어떤한 것도 제공은 해주지 않는다.(아닌가? 내가 못찾은건가?) 그래서 어떻게 하면 Mysql을 이용할수 있을까 하는 생각에서 MSsql 의 쿼리문 중에 for xml auto, elements 라는 쿼리문이 떠올랐다. MSsql에서 쿼리문 제일 마지막에 위의 명령어 문구를 사용하게 되면 테이블의 구조와 필트명에 따라 결과가 xml로 나오게 된다.. Mysql에서도 해당 쿼리문을 사용할수 있다면 어느정도 이용은 가능할수 있을것 같았다. 근데 웬걸 Mysql에서는 저런 쿼리문은 사용되지 않았다.

어째던 그런 명령문은 사용되지 않았기 때문에 php로 db를 읽을때 테이블명, 필드명을 추출해서 XML 출력을 해줄수 있게 만들었다. 결국 php페이지를 읽을때 Sql문을 파라미터 값에다 넘기고 그 결과값을 xml로 받을수 있게 만들었다. 실버라이트에서는 xml을 읽는 것은 쉽기때문에..

이렇게 db를 읽게 하여 Mysql을 이용가능 하게 하였다. DB읽기가 어느정도 되었기때문에 간단한 메모기록 프로그램을 만들어 보았다. 프로그램명은 SilverBoard!!



로딩 될때 가장 최근쓴글 6개가 읽여진다. 어째던 Mysql을 이용하여 만들었다는 것에 의의를 두고 다음번엔 실버라이틀 게시판을 만들어봐야겠다. 물론 Mysql을 이용해서 좀더 에니메이션이 들어간 작품으로.... 썩 만족스럽진 않다.

실버라이트를 이용하여 rss읽는것 자체는 굉장히 쉬운일이다. 그렇지만 다른 호스트의 rss을 읽는것은 쉽게 할수 없는 일이다. 이유인 즉은 실버라이트에서 크로스도메인 접속시 해당 도메인에 대한 권한파일을 확인후 권한이 없다거나 권한파일 자체가 없다면 접근을 할수가 없다. 우리 회사도 요즘들어 굉장히 많은 인젝션 공격이 들어오는 걸로 봐선 어떻게 보면 당연하다고 볼수는 있지만..... rss뿐만 아니라 이미지라던가 웹페이지 등등등 그 어떠한 자료도 권한이 없다면 순수 실버라이트만 가지고 사용할수 없게 된다.

그렇다면 뭐야?? 내가 원하는 것은 다른 도메인의 rss일뿐 내가 내블로그 rss를 받아봤자 뭐하겠냐구 ^^;; 그리고 난 a 라는 사이트의 이미지 잠깐 쓰고만 싶을 뿐인데 그사이트에서 얼씨구나 좋와요 하고 권한 파일을 만들어 줄리는 없을거잖아 ^^;; 그렇담 이렇게 이용할수 있지 않을까? 닷넷이라면 내 도메인에서 HttpWebRequest 객체를 이용해 내가 읽고 싶은 URL을 읽은 다음에 다시 뿌려준다면 도메인이 다른 사이트라도 내 도메인에서 뿌려주는것처럼 실버라이트런타임을 속일수 있게 되고 그럼 이용이 가능할 것이다.

그래서 난 당장 내 블로그에서 이용 가능하게 해보려고 시도 했다. 그런데 또하나의 문제점이 있었다. 내 블로그는 PHP 서비스로 이용되는 블로그이다. 그렇기 때문에 난 PHP용 HttpWebRequest 객체와 같은 것을 이용해 사용해야 한다 ^^; 그래서 찾아낸 것이 PHP용 WebAgent인 snoopy 라는 것을 찾았다. snoopy 클래스를 이용하면 손쉽게 내가 원하는 페이지를 읽어 올수 있다.  snoopy 의 소스는

http://snoopy.sourceforge.net/

여기서 다운 받을수 있다.

여기서 snoopy 클래스를 이용시 팁이라고 한다면 snoopy 클래스에서 agent 속성을 설정하는 부분이 있는데
Snoopy v1.2.4 이라고 설정이 되있다. 그런데 이렇게 agent속성이 설정되 있게되면 이용에 제한이 돼있는 사이트가 있다. 아마도 사이트 긁는 검색엔진이라던지 봇을 막기위해 차단이 되는데 agent 속성을 IE의 agent 값과 같게 한다면 접근이 불가능한 사이트라도 가능해 진다. 물론 100% 차단 해제된다는 장담은 못함!

이렇게 snoopy 클래스를 이용하여 크로스 도메인 문제를 해결하는 URL을 만들었다.
이렇게 http://mydomain/get.php?target=http://targetdomain/rss 페이지를 요청하면 http://targetdomain/rss 의rss를 마치 내 도메인에서 뿌려주는 것처럼.

소스보기

어설프지만 위와 같이 실버라이트 만들어 보았다. ^^; ㅎㅎ 해보니 왠만한 rss는 잘긁어 오는것 같다. 아래는 구현한 예제이다.



이상 rss 읽어오기 끗~~~~~~~


div>