현재 실무에서 사용 가능한 100만개 Row 지원하는 무료 그리드 라이브러리

구글 검색하다가 어떤 새끼가 블로그에 그리드들은 HTML5 표준 아니고 jQuery 장식 플러그인이 아니라는 등의 불안감을 조성하여 웹을 포기하고 응용으로 돌아가겠끔 글 싸지르고 다닌다.

그게 2011년이었다. 근데 그때도 솔루션을 이미 쓴 곳은 별 문제 없다.

하지만 지금 2014년 HTML5 표준 재정 전인데 위 이슈로 씨부리는 새끼가 아직도 있다. 무시하자.

HTML5 표준에서 뭐하러 그리드 만드냐? 그리드 외에 여러가지 컴포넌트 편리하게 표준 만드는 것만으로도 감사해야지.

어쨌든 니들이 어쩌면 이미 사용하고 있을 테고 앞으로도 필요할 것 같은 무료 그리드 라이브러리를 보라.

1. jqGrid

HTML 웹 프로젝트에서 많이 알려지고 많이 사용하고 있는 프로젝트.

3.7 부터 가상 스크롤 지원으로 100만개 행도 문제없이 출력

현재 쓰기 쉽고 가장 많이 쓰는 제이쿼리 기반 프레임워크

상용 모듈도 출시했으나 기본 jQGrid 라이브러리는 MIT에서 바뀌지 않는다고 공식 블로그에서 밝혔으므로 기업에서 문제없이 쓸 수 있다.

단점은 좀 무겁지만 어느정도 개선됨.

상용의 경우 모바일 지원 및 기술 지원을 받을 수 있음. (물론 영어)

2. SlickGrid

대량 데이터를 순식간에 뿌리는 최초의 라이브러리로 먼저 소문난 라이브러리.

의외로 가볍고 제이쿼리 기반이며 자체 성능이 우수하다.

단점은 어려운 사용법과 뜸한 버전업. 하지만 커뮤니티가 활발하기 때문에 충분히 커버된다.

MIT 라이센스이기 때문에 기업에서 문제없이 쓸 수 있다.

상용이 없으며 기술 지원을 받을 수 없다.

3. DataTables

예전에 비해 많이 성숙해지고 깔끔해졌으며 속도도 향상되고 심지어 CDN까지 지원하는 (jQGrid도 마찬가지지만) 막강한 라이브러리.

초반에 한국에서는 많이 알려져 있지 않고 지금도 이거 쓰는 곳은 찾아보기 힘들 정도로 국내는 인기가 없으나, 지금은 대적할 만 하다.

페이징 기반 그리드에 최적화되고, 그리드에 불필요한 기능은 확장으로 채울 수 있다.

대량 데이터를 위한 가상 스크롤 또한 확장으로 사용 가능하며 기본 다국어가 지원된다.

MIT 라이센스로 기업에서도 쓸 수 있으며, 활발한 커뮤니티로 문제 해결을 할 수 있다.

테이블 태그로 초기화하기 때문에 Fallback 에 능하다. 근데 국내 정서에 필요한 확장 다 깔면 좀 느리다.

특히 가상 스크롤에서 조금 느린 성능을 나타낸다.

기술 지원을 받을 수 있다 (영어지만)

composite / 2015년 1월 30일 / 미분류 / 0 Comments

Javascript Polyfill CDN Service

Financial Times 에서 자바스크립트 및 HTML5 에 최대한 유연하게 대응할 수 있는 CDN을 공개했다.

일단 링크를 보라. https://cdn.polyfill.io/v1/

귀찮게 뭐하러 polyfill 찾아 구하는가?

얘가 그냥 브라우저 확인해서 알아서 polyfill 해준다.

닥치고 써라. HTML5를 여러 브라우저에 최대한 쓰고싶다면.

composite / 2015년 1월 30일 / 미분류 / 0 Comments

CloudFlare로 DNS에 보안을 더하는 방법

내가 아래 포스트에 아무리 CloudFlare 라 해도 허점으로 인한 진짜 IP 뽀려내기 글을 올렸었다.

그렇다면 네트워크 관리자는 이 안전하다는 CloudFlare DNS에 진짜 보안을 더할 것인가? 고민이 많지만 이미 cloudFlare 에서도 언급한 내용이다.

하지만 되새김질 하라는 의미이기도 하고 모르거나 관심없었던 관리자도 얼렁 관심을 가져서 서버 보안에 도움이 되라고 쓴다.

내친구도 저거 쓰니까.

1. direct.domain.com 등의 쉽게 다이렉트로 연결되는 도메인을 차단하라.

CloudFlare 는 도메인 세팅할 때 direct 라는 서브도메인을 기본으로 세팅한다. 이걸 통해 진짜로 들어갔을 때에 대한 경우를 비교하라고. 아시다시피 CloudFlare 의 웹 캐싱은 당신이 리소스를 바꾼다 해도 적용하는 시간이 클라이언트마다 틀리다. 최적화를 해주는 대신 업데이트 주기가 길다는 소리. 그래서 주어진 것이지만, CloudFlare 는 Development mode 라는 기능이 제공되기 때문에 그딴거 필요없다. 그 이유는 아래에 설명한다.

2. Development mode 는 테스트시에만 잠깐 이용하라.

Development mode 는 개발시 자주 있는 리소스 변경 사항을 바로 적용할 수 있도록 캐싱 기능을 잠시 꺼두는 기능이다. 기본적으로 3시간이 주어지며, 연장 가능하거나 해제할 수 있다. 하지만 이 기능은 오픈 전 테스트에서만 사용하는 것을 권장하고, 별도의 도메인을 만들어 별도의 테스트를 진행할 것을 권장한다.

3. MX 레코드는 공개된다. 가능하면 공개형 메일 서비스를 이용하라.

메일 프로토콜은 DNS 검색 툴로도 금방 뽀록난다. 왜냐면 메일은 정방향과 역방향 둘 다 쓰기 때문에, 도메인과 IP 둘다 뽀록난다. 그러므로 MX 레코드는 가능하면 구글 등의 메일 서비스를 이용하는 것을 추천한다. 요즘 메일 서비스는 자체 메일 서버보다 훨 나을 것이다. 자체 메일 서버를 사용할 거면 내부적으로만 사용할 것을 추천한다. 메일 서버도 해킹 놀이터의 대상이기 때문이다.

4. 불필요한 직접 바인딩을 자제하라.

CloudFlare 로 보안성과 성능이 향상된 웹 사이트를 쓰면서 직접 바인딩으로 서비스 할 거면 CloudFlare 뭐하러 쓰는가?

5. CloudFlare 서비스가 불필요한 (웹 서비스 외) 도메인은 CloudFlare 가 아닌 다른 DNS 서비스를 이용하라.

웹 서비스가 아니라면 CloudFlare 안 쓰는게 낫다. CloudFlare 는 웹 서비스를 위한 DNS 관리를 제공하는 그 이상 그 이하도 아니다. 다양한 DNS 레코드 종류 등록을 지원하지 않기 때문에, 만약 다른 통신 서비스를 사용해야 한다면 DNS도 바꾸는 것을 추천한다.

끝.

composite / 2014년 5월 19일 / 미분류 / 0 Comments

Cloudflare 로 호스팅하는 웹 사이트의 진짜 IP 뽀려내기.

요즘 한국인도 CloudFlare 를 많이 이용하는데,

주로 해외에 효율적인 캐싱 서비스로 트래픽 조절을 할 수 있는 서비스라서 이용한다.

물론 뉴스타파같이 국내에 중점을 두는 사이트도 있고,

아이폰 탈옥툴 처럼 엄연히 불법은 아니지만 만든이를 숨기고자 하는 서비스도 있다.

(애플에서는 탈옥은 불법 아니지만 탈옥폰에 대해서 지원하지 않는다고 명시하고 있다.)

뭐 가장 큰 특징이 바로 CloudFlare 의 효율적인 캐시 정책과 DDOS 같은 무식한 공격에 방어하는 효과가 뛰어나서이다.

(실제로 Cloudflare 를 통해 호스팅한 사이트가 DDOS 공격을 받았는데 접속이 오래 걸렸을 뿐 서버가 뻗은 적이 없다고 하여 CloudFlare 서비스가 인기를 끈 원인이기도 했다.)

미국에도 한국의 보수(…)처럼 익명성을 혐오하는 이들이 있다. 좋게 보면 파수꾼일 수 있고, 나쁘게 보면 파파라치일 수 있다.

한국의 익명성은… 실명제하고 별 다를 거 없더라.

어쨌든 미국의 익명성을 반대하는 사람들은 불법적이라던가 등의 사이트가 하필 CloudFlare 에 호스팅을 해서, 이를 신고할 증거로 쓰지 못하기 때문에 애먹는(?)다고 한다.

그래서 몇몇 유저들이 CloudFlare 호스팅 하는 사이트의 진짜 IP 를 알아내는 방법을 “공유”하고 있다.

참고로 해킹 기술이 아니며, 그냥 네트워크 관리자라면 “아하 이거?” 할 수 있는 툴로 사용하는 방법이거나, 구글 검색으로 쉽게 접할 수 있는 별거 아닌 도구들이다.

물론 해킹으로 가능할 지는 모르겠지만, 불법이고, 이를 CloudFlare 가 인지하면 당신 고소미 먹으므로 알아서 해라.

어쨌든, 소개한다.

1. Uncovering bad guys hiding behind CloudFlare – CloudFlare Watch (현재 사이트 작동 안함)

http://www.cloudflare-watch.org/cfs.html (사이트 작동 안해서 링크 일부러 안적용)

Daniel Brandt 가 만든 이 사이트는 공공정보연구(Public Infomation Research) 프로젝트의 일환으로 “Cloudflare” 가 범죄 사이트도 수용하고 호스팅해줘서 “CrimeFlare” 라는 별칭을 만드는 등 CloudFlare 서비스에 반발하기 위해 만든 사이트라고 한다.

네임서버 히스토리 등의 공개적인 네임서버 IP 정보를 수집하여 CloudFlare 외 IP를 모두 솎아내서 정리했다는 이 사이트는 반익명성 네티즌에게 엄청난 호응을 얻었으나, 당연히 익명성을 요구하는 다수의 네티즌들에게는 반발의 대상이었고, 자금이 부족했던지 올해 초에 결국 사이트 자체가 폐쇄되었다.

그가 만들었던 동기 원문은 여기 살아있고, 영어다. 볼 사람 보라고.

http://cryptome.org/2012/07/cloudflare-watch.htm

  1. ping

물론 그냥 domain.com 만 핑걸면 cloudflare 만 잡힌다 하지만 CloudFlare 는 다이렉트로 접속하는 IP가 있다.

direct.domain.com : CloudFlare 기본 세팅할 때 다이렉트로 IP로 접속하라고 세팅한 IP. 뭘 좀 안다면 당연히 이는 삭제 대상인데, 실수라던가 귀찮아서 삭제 안할 경우 진짜 IP가 잡힐 수도 있다.

mail.domain.com : 주로 MX 레코드로, 이는 대부분 잡히지만 아닐 수도 있다. 뉴스타파가 잡히긴 했지만 메일 서버가 미국으로 잡히고, 메일 서비스는 심지어 무료로 제공하는 곳도 있기 때문에 신빙성이 적다.

그 외 알려진 서브도메인 알아서 하도록. 여기까지. 그래도 안잡히거나 CloudFlare IP만 잡히면 포기하자.

3. http://network-tools.com/

이 사이트는 해당 호스트에 대한 DNS 정보와 Traceroute 등등 호스트에 대해 공개된 정보를 보여주는 사이트이다.

도메인 Traceroute 및 DNS 정보, 도메인 정보와 IP whois 를 지원한다. 걍 IP나 도메인 누르고 GO 누르면 끝.

4. http://toolbar.netcraft.com/site_report?url=(도메인)

얘도 네트워크관리자라면 아 할 툴인데. 이녀석은 주로 DNS 내역을 보는 사이트이다. 따라서 오래된 도메인이라면 진짜 IP 대역도 볼 수 있는데, 뉴스타파는 신생 사이트고 처음부터 CloudFlare 를 채용했기 때문에 여기서 볼 수 없을 것이다.

그리고 그 오래된 IP가 접속되고, 올바른 곳인지는 나도 모른다. 알아서 판단하라.

5. # nmap -sV -sS -F <target>

nmap 은 DNS를 어떻게든 알아내는 DNS-brute 기능이 내장된 리눅스 유틸이다. 윈도우 사용자는 걍 구글링 해서 온라인 쓰던가.

어쨌든 이걸로 해당 호스트를 검색하면 해당 호스트의 레코드를 최대한 볼 수 있으며, 그 중 진짜 IP 대역이 있을 수도 있다.

물론 찾고 알아보고 발견하는 것은 각자의 몫이니 더이상 자세한 얘기는 생략한다.

내가 이 글을 올리는 이유는 내 친구를 포함해 CloudFlare 를 통해 웹 서비스 등을 이용하는 관리자라면 어떻게 보안성을 구축하고 운영할 것인지에 대한 참고사항이다. 이걸로 IP 잡고 뽀록내서 잡아서 뭐하게? 예를 들어 와레즈다? 불법 자료 공유한 정황을 증거로 남기면 된다. 그러면 경찰이 알아서 추적해서 잡아준다. 바보 아니다. 설령 반익명성 네티즌이라 해도 이거 쓰는 목적에 따라 범죄행위일 수도 있다. 무단 서버 침입일 수도 있기 때문이다.

CloudFlare 라도 항상 안전한 웹 사이트 운영은 힘들다. 이를 잘 알고 대비를 해 두면 당신의 서버는 안전할 것이다.

composite / 2014년 5월 13일 / 미분류 / 1 Comment

홈 네트워크 플레이? 소규모 IT 회사 보안? 하마치는 잊어라! NeoRouter!

윈도우던 리눅스던 일단 원격 접속해서 관리하는 것은 껄끄럽다. 아무대나 접속하자니 누군가 공격해서 비번 딸 것 같고, VPN 하자니 VPN 외의 망을 못쓰고 필요할 때만 키고 필요없으면 꺼야 하고, 고충이 이만 저만이 아닐 것이다.

같이 게임하는 사람들이라던가, 아니면 넷캔이라고 해서 온라인으로 같이 그림그리는 등의 너무 제한적인 네트워크 환경에는 하마치가 제격이었다. 옛날에는.

하마치는 이미 5년전인가 6년전인가 전에 그룹 하나당 16명 제한을 5명 제한으로 낮춰버렸다.

게이밍하는 사람이던, 홈 서버 관리하는 개인 입장에서는 상당히 껄끄럽기 그지없다.

랜 게임에서 네트워크당 접속 수가 늘었는데… 5명이 왠말인가.

게이밍 진영에서는 하마치 대체 프로그램인 아마 위피엔 같은 툴을 써왔을 테지만 그것도 이미 서비스 종료.

그래서 게임 진영은 이미 게임에 특화된 네트워크 프로그램으로 자리를 옮겼고, (예를 들면 가레나 등?)

소규모 IT 회사에서 VPN 구축은 부담의 대상이 되거나 아예 서버 호스팅이나 클라우드로 자리를 옮긴다.

하지만 역시 소규모 업체에서도 보안은 정말 피할 수 없고, 솔루션을 구입했는데 내부망에서만 된다. 골치 아픈건 이해한다.

그렇다고 하마치를? 겨우 5명으로 뭐하게. 게다가 상업적으로 무료도 아니고.

만약 이 글을 보고 있는 여러분이 소규모 IT 관리자나, 나처럼 쉽게 구축 가능한 홈 서버 보안을 원한다면,

지금부터 이 솔루션을 보라. 하마치는 이제 잊어라. 한물 갔다.

크로스 플랫폼이고, 쉽게 구축할 수 있는 VPN 방식의 네트워크 보안 솔루션이며, 기업이나 집에서도 쉽게 무료로 사용할 수 있다.

NeoRouter 를 소개한다.

NeoRouter 는 간단히 소개하자면 VPN 프로그램이다. 서버와 클라이언트로 나뉜다.

그렇다. 하마치하고는 틀리다. 하마치는 중계 서버를 제공하므로 서버가 따로 없다.(있긴 한데 솔루션으로 고가에 판매한다.)

하지만 NeoRouter 는 서버가 필요하다. 아마 그게 단점일 것이다.

하지만 하마치는 잊어라. VPN 구축에 대해 전문적인 지식도 필요없다.

윈도우의 경우 그냥 설치 마법사로 깔 수 있고, 맥과 리눅스로 서버와 클라이언트가 제공되며, 리눅스의 경우는 패키지를 제공하기 때문에 쉽게 설치할 수 있다.

한가지 설정해야 하는 사항이 있다면? 이 프로그램은 TCP 포트 32976 을 사용한다. 가정의 경우 공유기, 기업의 경우 방화벽에서 해당 포트를 서버 컴퓨터에서 열어줘야 한다. (포트 바꿔도 되는지 확인은 안해봤다.)

이것만 유의하면 VPN 서버 설치는 끝.

외국에서는 많은 소규모 IT나 홈 서버 보안에 하마치 대신에 선택하고 있다.

굿바이 하마치!

일단 특징은 아래와 같다.

  • 윈도우, 맥, 리눅스, FreeBSD, 심지어 라즈베리, 안드로이드까지 서버와 클라이언트 모두 지원, iOS 는 클라이언트만 지원
    (하마치는 윈도우와 맥만 지원)
  • OpenWRT나 토마토 (LinkSys 같은 외산 공유기에서 사용하는 커스텀 펌웨어 공유기 관리도구) 에서까지도 서버로 지원
  • 아무데서나 클라이언트 프로그램만 있으면 접속 가능 (심지어 포터블 버전도 제공. 포터블은 클라이언트만 가능)
  • P2P 를 기본 방식으로 채택하며, 포트 변경 불가 등의 불가항력인 사항의 경우 NeoRouter 에서 릴레이 서버 제공
  • 비관리 서버 (하마치의 비관리 방식과 동일)
  • 애드온, 프록시, WOL, 네트워크 브릿지 지원. (네트워크 브릿지 궁금하면 구글링 ㄱㄱ)
  • 스킨 제공으로 사용자가 원하는 UI 꾸미기 가능

이것도 무료와 유료로 나뉘는데, 간단히 비교해 보면 아래와 같다.

  • 무료 버전은 최대 256 클라이언트 접속 가능, 유료 버전은 클라이언트 수만큼 한번 과금하면 영원히 사용 가능.
    (유료 예: 10클라이언트당 99달러, 1000클라이언트는 999달러. 라이센스는 서버당으로 제공)
  • 유료 버전은 내장 방화벽, 사용자 접근설정, 패킷 필터링, 사용자 감시 등의 관리 기능을 제공한다.

참고로 하마치의 그룹명을 담당하는게 NeoRouter 의 도메인이다. 그걸 알아야 접속이 가능하다. 물론 계정도 있다.

고로 하마치처럼 NeoRouter 는 도메인(그룹)이 공개되지 않기 때문에 안심해도 된다. 물론 접속하려면 해당 도메인을 알아야지.

이제 슬슬 나도 깔아보고 리뷰 올리겠다.

무료 버전은 방화벽이 없고 해당 서버가 로컬로 취급되기 때문에 해당 서버에 대해서 완전한 접근을 제공한다.

만약 무료로 쓰고 싶은데 보안성이 걱정되면 NeoRouter 에 쓸 간단하거나 저렴한 컴퓨터나 서버(NAS도 됨)를 구축하거나, 프로 버전을 구입한다. 사양 많이 안타므로 미니 컴퓨터로 해도 된다.

원격 접속 등의 컴퓨터 관리 목적이라면 무료에 없는 기능은 큰 문제는 안된다. 어자피 다른 프로토콜을 사용하게 되면 흔적은 남으니까. 거기에 대해 관리를 잘 한다면 무료 버전도 매리트가 있을 것이다.

한가지 첨언하자면, NeoRouter 유료인 방화벽 기능은 윈도우의 경우 “고급보안 방화벽”의 연결 보안 규칙으로, 리눅스의 경우 iptable 에서 포트 포워딩 방식으로 가능하다. PC1은 원하는 원격 대역, PC2 에다가 NeoRouter 대역을 설정하여 연결 규칙을 만들면 된다.

composite / 2014년 5월 7일 / 미분류 / 0 Comments

VMWARE를 쓸 때 SSD 활용 팁 (보조 HDD가 있을 경우)

노트북의 하드 성능은 정말 관리 안하면 쥐약이다. 일단 보통 5400RPM 이다보니 PC 용 HDD인 7200RPM보다도 약간의 성능 저하가 있다. 게다가 노트북 하드가 상당히 조밀조밀하다보니 열 발산이 많고, 게다가 통풍이 잘 안되면 HDD 가 금방 죽는 건 시간문제다. 그래서 그런지 스탠드형 쿨러는 노트북에서 필수 아이템. 내가 이런 식으로 당하다 보니까 안정적인 사용을 위해 이런 조치를 했다.

그리고 또한가지 문제. VMWARE 가 느려졌다. 나는 가상PC 와 가상하드를 죄다 보조 HDD에 관리를 하는데,

윈도우를 다시 깔고 나서 VMWARE 가 엄청나게 답답해졌다. HDD가 끝없이 읽어댄다. 그렇다 보니 가상PC 이용도 어렵고 심지어 보조 HDD에 있는 파일 열기도 껄끄럽다.

VMWARE 온갖 최적화 팁을 써도, 윈도우 최적화를 해도, 조각모음하고 디스크검사 하고, 심지어 HDD까지 바꿨는데도 개선할 기미는 보이지 않았다.

결국, 나는 생각을 달리 해봤다.

그리고 지금. 나는 VMWARE를 쾌적하게 쓰고 있다.

운영체제를 SSD, 저장을 보조 HDD로 한다면, 내가 쓰는 팁으로 VMWARE를 최적화 한번 해봐라. 우왕굳.

아주 간단하다. 가상PC 파일(.vmx) 과 그 떨거지들을 모두 SSD 에 맡기고, 가상디스크(.vmdk) 만 HDD에 맡기면 된다.

VMWARE 가 왜인지 vmx 폴더에서 캐시를 하고 있다. 게다가 자주 일어난다.

그렇다 보니 HDD가 느려지는건 시간문제. HDD가 캐시와 디스크 관리를 하니 HDD가 죽어난다.

그래서 캐시를 SSD에 맡기고 나서부터는 우왕굳. 쾌적해졌다.

가상PC의 재원이 이렇다. 2 CPU에 램 2GB를 할당했다.

1GB 까지는 별다른 일 없이 잘 되는데, 2GB 부터는 HDD가 풀로 읽고 있으니..

그렇다 보니 스왑을 하는 모양인데, 이게 많은 I/O가 오가므로 HDD에게는 장애가 될 수 있다.

Edit -> Preference 에서 Memory 탭에 RAM 에 모든 걸 맡겨도 같은 증상이 일어났는데 이렇게 관리했더니 말끔히 해결했다.

만약 나같은 환경에 VMWARE 쓰기 힘들다면 나같은 방법을 쓰면 깨끗해진다.

그 외 팁을 공유하면 감사하다.

추가: 이해 안가면 SSD+HDD 환경에서 VMWARE 쾌적하게 쓰는 방법 글을 봐라. 끗.

composite / 2014년 3월 11일 / 미분류 / 15 Comments

한국을 위한 CSS 그리드 디자인 프레임워크

그렇다. 사정은 잘 안다. 부트스트랩이나 파운데이션 같은 올인원 CSS 프레임워크는 안맞을 수밖에.

특히 디자이너가 있고, 기획이 재대로 되어 있다면, 한국 웹 사정에 부트스트랩은 어찌보면 경우에 따라 안어울릴 것이다.

디자인 떡칠해서 화려한 웹페이지 만들어야 직성이 풀리는 한국 웹사정에 안맞다 보니까.

하지만 이런 단어만 들으면 디자이너와 퍼블리셔는 가장 먼저 입에서 시발이라고 나올 것이다.

반응형 웹.

맞다. 반응형 웹의 주인공은 CSS의 미디어 쿼리다. 하지만 배우고 적용하기 까지는 시발 좆같다.

퍼블이나 디자가 왠지 개발자가 되어 가고 있는 기분 같을 것이다.

그럼 시발 개발자는 니들 하는 업무 다하고 있는 개발자도 있는데.

어쨌든, 그래도 자신이 맡은 업무에 충실하면서 클라를 만족하고 싶지 않은가?

그래서 시발 존나 위험한 개발자인 내가 소개한다. 퍼블과 디자인 니들을 위한 반응형 웹을 위한 CSS 프레임워크다.

나머지 디자인과 레이아웃 구성은 니들 꼴리는데로 하면 된다.

1. 960 Grid System (http://960.gs/)

전 세계에 인기를 한몸에 받고, 파생 CSS 프레임워크를 탄생시키게 한 장본인이자 웹에 생산성을 불어넣은 엄청난 놈이다.

이녀석은 웹 페이지의 한 행을 몇 열씩 나누게 하는 방식을 선보였는데, 전 세계적으로 인기를 한몸에 받았다.

이녀석의 특징은 960인데, 페이지의 기본 크기를 960으로 잡고 시작한다. 그리고 한 행당 12단씩 나눌 수 있다.

실질적인 컨텐츠가 들어갈 길이는 940이다. 여백 제외하고 말이다.

사용법이 무진장 간단하다.

<div class=”grid_나눌 숫자”>내용</div>

<div class=”clear”>행 나눔 (주로 공백을 넣는다. &nbsp; 같이.)</div>

예를 들어 12단 나눌 수 있을 경우, 3개씩 나누고자 한다면 이렇게 하면 된다.

<div class=”grid_4″>내용</div>

<div class=”grid_4″>내용</div>

<div class=”grid_4″>내용</div>

<div class=”clear”>&nbsp;</div>

이런 식으로 4+4+4=12 로, 총 12단으로 맞추는 것을 고려하여 4*3=12 니까 3개 div 에 grid_4 클래스를 넣으면 div 를 삽입하면 된다.

존나 쉽지 않은가?

단점은 니들이 원하는 반응형 그리드는 아니다. 타블렛이나 데스크탑에 적합한 레이아웃 구조에 탁월한 선택이다.

하지만 이거와 미디어쿼리를 합치면 반응형 그리드 디자인을 만들 수 있다.

그러면서 왜 이녀석을 소개하냐면 이녀석이 웹 그리드 디자인을 프레임워크로 탄생시킨 원조이기 때문이다.

2. Fluid Baseline Grid (http://fluidbaselinegrid.com/)

이녀석부터 이제 반응형 웹 디자인을 고려한 그리드 디자인 프레임워크 되겠다.

이녀석의 특징은 Baseline 인데, 글씨 크기 위주의 웹을 고려한 그리드 디자인을 생각했다고 보면 된다.

그래서 어찌보면 이미지 떡칠의 한국형 웹과 안맞을 지는 모르겠다. 그래도 소개한다.

이녀석의 특징은 % 단위의 넓이를 나눠서 처리한다는 것이다. 960.gs 또한 이를 지원한다.

그리고 이녀석은 최대 3단계 레이아웃이 있는데,

g1 은 작은 단위로 모바일에 표시 가능하도록 작은 크기의 영역을 잡는다.

g2 는 중간 단위로 타블렛에 표시 가능하도록 중간 크기의 영역을 잡는다.

g3 은 큰 단위의 테스크탑에 표시 가능하도록 큰 크기의 영역을 잡는다.

<div>

    <div class=”g2″>

         난 타블렛에서 하나를 다 잡아 먹는다.

     <div>

    <div class=”g3″>

         난 어느 장치에서 봐도 하나를 다 잡아 먹는다.

     <div>

    <div class=”g1″>

         난 휴대폰에서 하나의 영역을 잡아먹는다.

     <div>

</div>

솔직히 뭐 이 이상은 나눌 일이 없다고 봐도 무방하지 않은가? 그럼 됐다.

3. Negative Grid (http://chrisplaneta.com/free/negativegrid-generator/)

만약 직접 그리드 구조를 짜야 한다면 이녀석을 추천한다. 이녀석은 원하는 크기, 그리드 개수, 여백 등을 지정할 수 있다.

당연히 px 가 아닌 % 이기 때문에 % 단위로 짜야 한다. 만약 px 단위를 원한다면 960 그리드를 써라.

이녀석 또한 960 그리드와 마찬가지로 생성기 시스템인데, % 위주인 방식에서 틀리다.

게다가 가볍다. CSS 생성했는데 보기도 쉽고 내용도 별로 없다. 그리고 prefix 설정도 가능해서 반응형 웹 구성에 잘 맞는다.

사용방법은 대략 이렇다.

<div>

    <div class=”col4″>3단</div>

    <div class=”col4″>3단</div>

    <div class=”col4″>3단</div>

</div>

별거 없다. 나눌 크기를 정해서 col(또는 직접 정한 prefix) 옆에 숫자만 붙여주면 된다. 최대 숫자는 니가 정한대로다. 예를 들어 12개로 나뉘었다면 1부터 12까지를 쓰면 된다.

여백을 만드는 방법은 push(또는 직접 정한 prefix) 옆에 숫자만 붙여넣으면 된다.

난 굳이 미디어 쿼리 혼합하는 방법은 안가르쳐준다. 어자피 반응형 웹을 만들 거고 거기에 대응하기 위해 미디어 쿼리를 배웠을테니까.

그래서 이거와 잘 혼합한다면 깔쌈한 사이트가 만들어질 것이다.

IE를 위해서라면 respond.js 가 필요하다. 그냥 스크립트 쳐넣으면 끝이다 나머진 CSS에 맡겨라. 구글신 영접하면 바로 나온다.

귀찮아서 끝.

니들 그냥 좆돼봐라.

composite / 2014년 2월 27일 / 미분류 / 2 Comments

ECMAScript 6 Harmony 를 네 브라우저에 돌려봐라!

나 참.. 기분 존나 나쁘네.

뭐? CoffeeScript? TypeScript? 어쩌고 저째? 자바스크립트가 죽을 거라고?

난 동의 안한다. 제아무리 자바스크립트를 편하게 만들어도 오리지날이다. 결국 그들도 자스로 움직인다. 제아무리 편해도.

스칼라가 결국 자바에서 돌아가기 위해 자바 코드로 생성해서 컴파일 하는 것처럼 말이다.

튜닝의 끝은 순정이란 말이 괜히 나오는게 아니지.

그래서 소개한다. 니 브라우저에 직접 ECMA 6 을 적용할 기회를 내가 선사해 주겠다. 2가지 프로젝트가 있다.

1. Traceur

구글신은 미쳤다. 이번에 소개할 피로젝트는 자바 2명 타요가 아닌 외계인 2명 타요 해서 ECMA 6을 몸소 체험할 수 있는

Traceur 를 소개한다.

프로젝트 페이지는 https://github.com/google/traceur-compiler

이 스크립트 컴파일러는 ES6 을 당신 브라우저에 돌릴 수 있게 한다.

일단 IE 8은 안된다. 쳇. 최소한 8이라도 지원해주지.

크롬과 불여우는 일단 된다. 올ㅋ

Traceur 가 지원하는 ECMA 6 기능이다.

일단 여태 나오고 알려진 것들을 지원한다.

하지만 이 ES6 하모니를 쓸 때 몇가지 주의할 점이 있다.

알다시피 ES6은 확정된 표준이 아니다. 특히 클래스와 모듈이 그 대표적인데, 이들이 어떻게 바뀔지는 장담을 못하겠다.

제발 안바뀌길 바래라.

뭐.. 그래봐야 기반 스크립트 (타입스크립트 등) 또한 아직까지 안정화된 버전을 내놓지 못하고 있기 때문에

물론 커피스크립트는 상당히 안정화 되고 쓰는 사람 많은거 안다.

근데 뭐가 좋다 말을 못하겠지만, 그래도 그런 스크립트는 표준에 넣지 못할 것이다.

난 커피스크립트가 자바의 스칼라처럼 생각하지만, 그래도 스칼라도 많이 쓰지 않는가? 물론 갈라파고스 한국은 빼고.

난 표준을 만들고 따르는 주의자긴 하지. 자바스크립트는 아직까지는 강력하기 때문에. 단지 좀 귀찮고 짱나서 그렇지.

어쨌든, ES6 을 직접 체험해보고자 한다면, 이 컴파일러를 이용해 제작된 ES6Fiddle 을 사용하라.

http://www.es6fiddle.net/

ECMAScript 6 이 어떻게 돌아가는지 알 수 있을 것이다.

2. continuum 

그에 비해 이 ES6 컴파일러는 커뮤니티의 참여로 만들어졌다. 그다음 낫고, IE 8부터 지원해주기 때문에 우왕굳.

프로젝트 사이트는 https://github.com/Benvie/continuum

체험 사이트는 http://benvie.github.io/continuum/

현재 구현된 기능들이다.

  • 통합 할당 및 인자
  • 가변 처리자 및 배열 초기자
  • 가변 인자
  • 클래스와 상속
  • 화살표식 함수(람다식) (.NET 의 람다식과 동일한 형식)
  • 블록 단위 변수
  • 새로운 Math 함수
  • 새로운 Object 함수
  • 새로운 String 함수
  • concise methods in object literals
  • 열거 및 삭제 가능한 프로토타입
  • Map, Set, 그리고 WeakMap (가비지 컬렉션이 현실화되지는 않았음)
  • 열거자와 for…of 반복문
  • 템플릿
  • 모듈과 imports, exports
  • 내장 ‘@std’ 모듈 module std = '@std' 또는 import call from '@function'
  • 생성기
  • 프록시와 리플렉션
  • Symbols with syntactic @name support
  • 형식화된 배열Typed Arrays
  • Object.observe (es-next/es7)
  • 인자 기본값
  • 꼬리물기 호출 최적화
  • 배열 초기화 식 (부분 지원)

아래 기능은 아직 구현이 안되어 있으며 추후 지원될 예정이라 한다.

  • 생성기 식
  • 이진 데이터 api (structs, etc.)
  • 프로미즈 (내가 Feature request 했음.)

물론 프로미즈같은 경우 promisejs 또는 q 로 해결은 가능하기 때문에 커버는 해줄만 하다.

ECMA 6 기능에 목이 말랐다면 지금 바로 체험하라.

아참, 마지막으로 ES6의 새로운 기능을 한글로 잘 정리한 위키 페이지가 있어 이걸 소개하고 쿨하게 끝내겠다.

http://wiki.codekin.com/index.php/ECMAScript_%ED%95%98%EB%AA%A8%EB%8B%88

끝이다.

추신 업데이트 사항 : Traceur 외에 나머지 ES6 컴파일러는 몇달동안 활동이 없다. 그냥 Traceur 써라. 진자끝.

composite / 2014년 2월 25일 / 미분류 / 0 Comments

태그에는

다들 HTML 배우면서 가장 간단하면서 많이 지키는 사항이 있다. 물론 맞는 말이다. 표준이기 때문에.

  • inline 요소 안에는 block 요소를 자식으로 가질 수 없다.
  • block 요소 안에는 inline 및 block 요소가 모두 허용된다.
  • 단, p 요소 안에는 inline 요소만 허용된다.
  • inline 요소 안에는 inline 요소만 허용된다.

근데 나모 웹에디터 때문에 <p> 요소에다가 <div> 넣는 등의 표준을 위반하는 사례가 있다. 그리고 IE 기반 위지윅 에디터가 그리한데, designMode 기능이 기본 문단 태그를 <p> 로 지정했기 때문이다. 그래서 초창기 위지윅 에디터가 상당히 말이 많았고, 그리고 이에 대한 문제를 고치느라 고생하던 시절이 있었다.

하지만 지금은 많은 위지윅 에디터가 문단 태그를 <div> 로 강제하였기 때문에 더이상 HTML 표준 위반 및 XHTML 표준 전선 이상 무!

자. 잡담은 끝내고 이제 본론으로 들어가보자. HTML 표준에는 일단 문장(inline) 요소에는 문단(block) 요소를 넣을 수 없게 되어 있다. 따라서 원래 <a> 태그에 <div> 태그같은 게 들어갈 수 없는게 정설이다.

하지만 HTML5 부터는 얘기가 달라졌다.

마치 p 태그가 인라인 요소만 허용한다는 예외 처럼, a 태그에도 예외가 생겼다.



두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구두구



그러하다.
HTML5 에서는 <a> 태그 안에 아무 태그나 넣을 수 있게 되었다.
이 때문에, 플랫 디자인 다음이 뜬금없는 카드 디자인 패턴이 나온 것이다.
예제 코드를 보자.
<article>
<a href="story1.html">
<h3>Bruce Lawson voted sexiest man on Earth</h3>
<p><img src="bruce.jpg" alt="gorgeous lovebundle. ">A congress representing all the planet's women unanimously voted Bruce Lawson as sexiest man alive.</p>
<p>Read more</p>
</a>
</article>
이렇게 생겼다.
하나의 글 영역 안에 모든 것들을 링크 걸고, 그 안에 제목과 요약 내용, 그리고 read more 라고 링크를 부추기는 글을 넣는다.
이렇게 하면 장점이 뭐냐?
웹 접근성이 향상된다. 모바일이나 특수 컴퓨터 (시력장애인 등을 위한) 에서 링크 클릭에 대한 접근성이 향상된다.
또한 이런 접근성으로 인해 스크립트 의존성이 떨어지며, 원하는 문서를 손쉽게 이동할 수 있는 장점이 생긴다.
바로 접근성을 고려해서 W3C가 이렇게 HTML5 표준과 함께 내놓은 거다.
여담으로, XHTML2 에서는 모든 요소에 href 를 넣을 것을 고려했다고 한다. 바로 이런 접근성에 용이하기 위해.
하지만 알다시피 XHTML2 는 완전히 새로운 표준을 지향했고, 하위 호환성이 철저히 무시한 덕분에 많은 웹 관련 개발자와 디자이너, 연구진들이 반발했고, 그리고 무산된 표준이 바로 XHTML2 였다.
만약 XHTML2 표준으로 웹 페이지를 만들었고, 브라우저가 그걸 지원하려면 정말 엄청 머리 아팠을 것 같지 않은가?
왜냐하면 바로 하위 호환성이 사라지기 때문에, 엔진을 2개 만들어야 하는 꼴이 되니까. 당연히 달갑지 않았던 거다.
지금은 HTML5 에서는 이 표준이 아직 하위 호환성이 적잖아 문제가 있다. 모든 브라우저가 이 표준을 지원한다. 쿼크 모드에 대한 호환성 때문인데, 이 기능이 지원된 게 다행이라 생각하지 않는가? 만약 <div> 가 <a> 로 감쌌다고 지우면, 이건 정말 골치아플 수도 있다.
하지만 아직까지 현재 브라우저에 한계가 있는데,
비록 <a> 태그 안에 모든 태그가 지원된다 해도, 현재 표준에 의한 예외 사항이 있는데, 바로 테이블이다.
테이블 태그 안에 비표준 태그들을 싸그리 지우도록 엔진이 설계한 덕분에, <a> 태그를 <tr> 안에 넣지 못하는 사태가 일어난다.
이에 대응할 지는 아직 지켜봐야 할 단계지만, 이를 지원한다면, 웹 접근성 향상에 어느정도 기여할 것으로 기대된다.
자. 이제 찬양하라. HTML5를!
자세한 링크는 HTML5 에서 신뢰성 있는 정보를 제공하는 HTML5닥터 에서 보도록 한다.

composite / 2014년 2월 18일 / 미분류 / 0 Comments

JetBrains 의 IDE 제품을 포터블로 쓰기.

먼저 노파심에 말하는데, 이건 공식 포럼에서 얻은 글을 한글로 재구성한거고, 불법 아니다.

못믿겠으면 니가 직접 포럼이나 지원에 물어보던가.

자바 개발자라면 Intelij IDEA 를 들어봤을 것이고, 쓰는 사람도 있을 것이다.

여담으로 희한하게 전자정부 프레임워크 개발시 이 IDE로 개발이 안된다. 왜그런진 나도 모르겠다. 내 경험상.

그리고 요즘 HTML5 최강 에디터라 불리었다고 들었던 WebStorm 출시 이후 아마 많은 주목을 받았을 것이고,

PHP 개발자 중에서도 PHPStorm 을 쓰는 유저도 좀 있을 것이다. 필자는 PHP 플젝 뛸때 PHPDesigner 썼다.

강력하긴 강력한데 저장시 한글 처리 누락 때문에 조금 고생한거 빼면.. 꼼꼼해야 하는 단점만 빼면 한글 잘 안깨지고 쓸만하다.

어쨌든, 상용이지만 전세계 자바 개발자들에게 인기가 많아서 오픈소스인 이클립스와 쌍벽을 이루며, (NetBeans? 2인자.)

하드 리소스를 많이 활용하는 이클립스와 달리 램을 좀 활용하는 인텔리는 어정쩡한 노트북에서도 괜찮은 개발환경을 만들어낸다.

이에 힘입어 제조사인 JetBrains 에서는 이 인텔리 IDE 를 기반으로 개발한게 WebStorm 과 PHPStorm 등이 있는데,

이들의 공통점이래봐야 기반이 인텔리다. 개발할 언어 대상이 틀리고 거게에 맞춰서 개발했을 뿐.

이제 본론으로 들어가서, 이들을 포터블로 만드는 게 가능한가?

가능하다.

인텔리 IDE는 자바로 만들어졌다. 인텔리 플러그인도 자바로 개발이 가능하고, JetBrains 에 배포가 가능하다.

또한 JetBrains 에서도 다양한 플러그인을 만들어 배포하고, 유저 플러그인도 꽤나 많아 왠만한 환경 개발에 불편함이 없다.

특히, node.js 개발에 많이 신경을 썼고, 배척하지 않는 모습이 유저층을 사로잡았다고 봐도 된다.

어쨌든, 인텔리 IDE 기반이라 어떤 프로그램을 실행해도 개발언어 환경만 틀릴 뿐 환경이 하나도 안변하고, 자바로 실행하니 별도의 시스템 세팅 (레지스트리 등록한다던가 ThinApp 로 포터블화 등) 또한 필요가 없다.

이 IDE를 이제 포터블로 만드는 방법을 알아보자. 전혀 어렵지 않으므로 금방 따라할 수 있다.

또한 WebStorm, PHPStorm, InteliJ IDEA 등 관련 IDE 제품에 모두 적용이 가능하며, 윈도우 기준이지만 맥에서도 비슷한 방법으로 만들 수 있다.

<

p style=”text-align: center; clear: none; float: none;”>

먼저 자신이 구입했거나 사용하길 원하는 IDE 제품을 다운받는다. 만약 이미 깔았다면, 무시하고 일단 설치본을 받는다. 이미 설치한 사람은 조금만 참으면 내가 알려주겠다. 그냥 따라하라.

다운받은 exe 파일의 확장자를 zip으로 바꾸거나, 그냥 가지고 있는 압축 프로그램으로 연다. (알집 왜쓰냐?)

원하는 폴더(USB 등)에 압축을 모두 푼다. 남김없이. 폴더명은 원하는 폴더명으로 해도 된다. 폴더 만들고 푸는 것을 추천한다.

그리고 폴더 구조는 바꾸지 말자. 실행 안되는 수가 있다.

그러면 bin 폴더와 jre, lib 등등.. 여러가지 폴더가 있다. 여기서 손대지 말고 bin 폴더로 가자.

그리고 idea.properties 를 쓰고 있는 아무 편집기로 열자 (기존에 깔았던 IDEA 제품으로 열지 말고.)

그러면 path=${user.home} 이 들어있는 상위 4개 세팅값이 주석으로 처리되어 있을 것이다. 물론 당연히 기본값이라 생각하면 된다.

주석을 풀고, ${user.home} 모두 ${idea.home} 으로 바꿔준다. 그러면 사용자 전용 폴더가 아닌, 당신이 압축 푼 폴더에다가 .WebIde 폴더를 생성할 것이다. (첫 실행시)

끝.

허무하다. 정말 허무해.

만약 이미 설치형으로 이미 깔았다면, 설정값을 옮기는 2가지 방법이 있다.

사용자 폴더에 (윈도우 기준 C:(XP는 Users and Settings, 비스타 이상은 Users)(사용자명).WebIde, 맥이나 리눅스는 /home/(사용자명)/.WebIde) 폴더를 찾으면 있을 것이다. 그걸 모조리 압축 푼 곳으로 이동한다. 버전이 같다면 이렇게 해도 된다.

또는, 압축 푼 폴더/bin/(제품명).exe 을 실행하여 프로그램을 실행하면 기존 config 를 가져올 것이냐 물을 것이다. 그 때 config 를 지정해서 옮기는 방법이 있다.

편한 방법을 쓰면 된다.

참고로, 라이센스 키 또한 config 에 저장되기 때문에, 정품 등록을 하고 config 환경을 가져왔다면 별도의 키 입력은 필요없이 기존 세팅대로 개발하면 되며,

만약 그러지 않고 쌩으로 시작하길 원한다면, 등록 키가 있다면 다음에 나올 라이센스 키 여부를 물을 때 넣으면 된다.

없으면 그냥 21일 체험판 되는거다.

그리고 써주면 된다. 그러면 당신의 개발환경에 날개를 달아줄 것이다. 특히 프리랜서.

덤으로 오픈소스 라이센스에 대해 알려주겠다.

당신이 오픈소스 라이브러리나 프레임워크, 프로그램 등을 개발했다면 공짜로 쓸 수 있다.

단점이 있다면 년 단위로 갱신을 해야 한다는 것이고, 심사 후 제공하는 것이다.

심사에 성공했다면, 라이센스 키를 보내주는데, 그 키는 사용자 제한이 없어서 오픈소스 참여자 모두 다 써도 불법이 아닌 라이센스가 된다. (단, 라이센스 키를 인터넷 공개 행위 등으로 외부로 공개하면 불법이 된다.)

신청서는 여기를 클릭하면 있다.

그리고 마소 MVP가 됐다면, 이 또한 연간 공짜로 쓸 수 있다. 마소 증명 URL을 증명으로 제출하기만 하면 된다. 단점이라면 닷넷 기반 제품으로 한정되있다는 점이다. (비닷넷으로 WebStorm 제품만 가능)

하지만 닷넷 리플렉션 프로그램인 ReSharper 라는 강력한 프로그램을 공짜로 쓸 수 있으니 MVP라면 놓치지 말자.

그럼 즐개발 해라. 끝.

composite / 2014년 2월 12일 / 미분류 / 0 Comments