반응형

CSS에서 width, height에 픽셀을 직접 입력하면 항목의 크기가 고정이 되고, 각각을 %로 하면 항목 내부에 높이가 다른 이미지를 다루는 경우에 서로 높이가 달라진다.


width의 경우에는 화면 너비의 %로 지정하고, 그 width와 동일한 값 또는 width의 비율로 표현되는 어떤 값을 height에 적용하고 싶을 때는 vw 단위를 쓸 수 있다.



CSS:


.test {

width: 100vw;

height: 80vw;

}



HTML:


<div class="test">

<img src="......(크기가 서로 다른 이미지)">

</div>



물론 이 방법은 무조건 요소(div)의 크기를 화면 너비에 맞춰서 일정한 비율로 유지하는 데 있으므로, 이미지의 고유한 비율은 당연히 망가지게 된다. 그것을 감수하고 박스 크기를 강제 지정하고 싶을 때 쓰면 될 것 같다. (가령 비디오 플레이어 같은 요소의 크기 지정할 때)




<참고자료>


[1] http://stackoverflow.com/questions/21537806/css-height-same-as-width

[2] https://drafts.csswg.org/css-values/#vw



반응형
블로그 이미지

Bryan_

,
반응형

최근에 은행에서 쓰던 공인인증서가 만료돼서 갱신을 하게 되었다.

안드로이드 폰의 은행 모바일 앱을 통해서 공인인증서를 재발급받아서 잘 쓰고 있었다.


갱신하고 나서 보니, 아이사랑포털 앱에서는 등록되지 않은 공인인증서로 나와서 내 계정에 공인인증서 등록을 새로 한 번 해줘야 한다고 나왔다.


그런데 모바일 앱에서는 새로 발급받은 공인인증서를 등록할 수 있는 방법이 없다. 내 계정에 새로운 공인인증서를 등록하려면 반드시 윈도우 PC에서 해야만 한다는 의미다.


...가능하면 PC에서 아이사랑포털 사이트에 들어가고 싶지 않았는데.


뻔하지 않은가?

  • 들어가자마자, 또는 로그인 페이지를 누르자마자 자동으로 "플러그인 설치 안내" 페이지로 리다이렉션(redirection) 되고,
  • 거기서 설치해야 하는 프로그램 목록이 나오면서 오른쪽에 다운로드 링크가 걸려 있고,
  • 대부분이 미설치 상태일 것이며,
  • 사실은 다른 은행 사이트에서 이미 한번 설치했던 것과 똑같은 이름의 플러그인(예를 들면 nProtect, XecureWeb 같은 부류)을 또 중복해서 설치해야 된다는 것에 놀라게 될 것이며,
  • 설치하는 과정에서 반드시 한 번 이상 웹 브라우저를 다 꺼버릴 것이고,
  • 그 뒤에 다시 로그인하려고 보면 높은 확률로 인터넷이 다운되거나 키보드 입력이 먹통이 되는 사고가 일어나고,
  • 결국 PC를 재부팅해야 하는...

PC 입장에서는 운명과도 같은 죽음의 길.


그리고 PC를 재부팅하고 나서도 nProtect Online Security 같은 악질 백그라운드 프로세스가 CPU와 메모리를 점유하고 (듀얼코어 2.4GHz CPU 기준에서 꾸준히 5% 가까이 차지), 그것 때문에 아이사랑포털과 전혀 관계 없는 크롬 브라우저에 일반적인 사이트조차 10배 넘게 느린 속도를 감수해야 한다.


한 순간 PC를 걸레짝으로 만들어 버리는 위엄이란... ㅡㅡ;

그 위엄이 압도적이라서 차마 내 PC에서 그걸 다 받들 수가 없다.

그래서 한 번 파도가 휩쓸고 가면 반드시 아래 프로그램들을 지워 줘야 PC가 그제서야 정신을 차린다.

  • nProtect Online Security
  • AnySign For PC
  • AhnLab Safe Transaction (그나마 이것은 최근 들어 좀 나아졌다. 사용자가 특정 사이트에 접속하기 직전에 수동으로 직접 켜고 끌 수 있는 옵션이 생겨서 평소에 CPU/메모리를 차지하지 않게 되었다)
  • Veraport


황당한 것은, Veraport라는 녀석이 원래 플러그인을 통합 관리하는 프로세스인데, 그게 아이사랑포털에서 쓰는 것과 다른 금융기관에서 쓰는 것 사이에 버전이 맞지 않아서 중복으로 설치된다는 점이다. 그러지 말고 최신 버전의 이미 깔려 있는 Veraport를 쓰도록 할 수도 있을 텐데...


(우리은행과 아이사랑포털 2개 사이트에 방문하고 나면 서로 다른 버전의 Veraport가 2개 설치되는 것을 알 수 있다. 참고로 아래의 낮은 버전이 "아이사랑포털"에서 설치된 것이다.)


그리고 중복 설치된 Veraport 중에서도 구 버전의 출처는 아이사랑포털 웹페이지다. 국내 전용 보안 관련 플러그인의 존재 자체도 문제지만, 그 중에서도 플러그인 관리 측면에서 가장 수준이 떨어지는 곳이 정부 사이트라는 사실을 알 수 있다.



무엇보다도 모바일에서만 모든 작업을 완료할 수 있게 좀 해줬으면 좋겠다.




앞으로는 굳이 PC가 없이도 대부분의 인터넷 관련 작업을 하는 경우가 많아질 테고, 더군다나 처음 인터넷을 경험하는 장비가 PC가 아닌 스마트폰이 되는 경우도 많아질 텐데, 반드시 PC를 연계해서만 정부의 지원이나 관련된 일처리를 할 수 있는 것은 너무 제약이 크다. (스마트폰과 PC 모두 더럽혀지는 것은 덤이다)


은행이나 쇼핑 등은 진작에 스마트폰만 가지고 회원가입에서부터 결제까지 모든 것을 다 할 수 있는데, 정말 수준떨어지는 웹사이트와 모바일 앱을 내놓는 보건복지부 보육정책과는 반성해야 한다.




반응형
블로그 이미지

Bryan_

,
반응형

OS: Ubuntu 14.04 (amd64)


터미널에서 별 생각없이, 


cd smb://주소/원하는_디렉토리/


이런 식으로 접근을 시도해 봤는데, 안되었다.

/mnt, /dev 등을 뒤져 보았는데 잘 모르겠다.


윈도우처럼 그냥 드라이브마다 알파벳을 할당하듯이 되는 줄 알았는데 아니었군.. ㅠㅠ


찾아보니 어렵지는 않다. 단지 익숙한 경로가 아니었을 뿐.


우분투 14.04 기준에서,


cd /run/user/[숫자]/원하는_디렉토리/

이런 식으로 접근할 수 있다.

[숫자] 부분은 $ id -u 이므로 uid인 듯.





<참고자료>


[1] How do I navigate to a samba location I've mounted in Nautilus on the command line?, http://askubuntu.com/questions/33480/how-do-i-navigate-to-a-samba-location-ive-mounted-in-nautilus-on-the-command-li



반응형
블로그 이미지

Bryan_

,
반응형

OS: Ubuntu 14.04 LTS (amd64)


우분투(Ubuntu)에서 그냥 apt-get install로 gradle을 설치했더니 1.4가 설치되었다.


그런데 Spring REST 서버 코드를 빌드하는 과정에서 에러가 발생했는데 살펴보니 gradle-2.9 이상을 쓰라는 것이었다.


사실 그냥 gradle 공식 사이트 [1]에서 직접 받아서 설치해도 문제는 없다.

하지만 apt-get을 통해서 높은 버전 (또는 비교적 최신 버전)을 설치하고 싶을 경우에는 ppa를 통해 최신 gradle을 받을 수있는 repository를 등록해서 해결할 수 있다. [1]


$ sudo add-apt-repository ppa:cwchien/gradle

$ sudo apt-get update


$ sudo apt-get install gradle-3 <-- 여기까지 입력하고 탭(Tab) 키를 연타해서 설치할 수 있는 버전을 찾아서 설치하면 된다.




<참고자료>

[1] https://gradle.org/gradle-download/

[2] Upgrading Gradle to the latest version on Ubuntu, http://wtanaka.com/node/8079

반응형
블로그 이미지

Bryan_

,
반응형

OS: Ubuntu 14.04 (amd64)

g++ version: 4.8.4

Eclipse: Mars, Neon



이클립스(Eclipse)에서 C++2011  문법(std::thread나 향상된 for loop 같은 것)을 쓰려고 하면 빌드 설정에 -std=c++0x 또는 -std=c++11 같은 플래그를 추가해 두어도 정작 에디터에서 계속 syntax error를 표시하는 경우가 있다.


(이클립스 에디터가 C++11 문법에 따라 쓴 std::thread 코드를 

unresolved symbol error로 표시하고 있다.)



해결하려면, 프로젝트 이름에 마우스 오른쪽 단추를 누르고 Properties로 가서,

C/C++ General > Preprocessor Include Paths, Macros etc.로 간 다음,

Providers 탭에서 CDT GCC Build-in Compiler Settings를 선택한다.


그리고 하단에 "Use global provider shared between projects" 선택을 해제하고,

Command to get compiler specs 칸에 -std=c++0x 를 추가한다.


또한 순서상 중간 쯤에 와 있는 CDT GCC Build-in Compiler Settings 항목을 Move Up을 이용해서 가장 위로 끌어올린 뒤에 Apply 버튼과 OK 버튼을 누른다.




마지막으로, 이클립스 메뉴에서 

Project > C/C++ Index > Re-resolve Unresolved Includes

Project > C/C++ Index > Freshen All Files

Project > C/C++ Index > Rebuild

를 차례대로 눌러 주면 에러로 표시하지 않게 된다.


(C++ 2011 문법의 syntax error가 해결된 이후의 에디터 화면)




<참고자료>

[1] http://stackoverflow.com/questions/17457069/enabling-c11-in-eclipse-juno-kepler-luna-cdt



반응형
블로그 이미지

Bryan_

,