기본 콘텐츠로 건너뛰기

[Andorid] Export activity – 1. 안드로이드 라이브러리 프로젝트



내가 만든 activity를 다른 앱에 넣어야 할 경우가 있다.
가장 좋은 방법은 코드를 그냥 통째로 넘기면 된다.  
그런데 문제는 코드를 순수하게 내준다는게 영 꺼림직하다.
코드를 감추기 위해서는 jar로 묶어 라이브러리처럼 쓰게끔 하는게 가장 좋을듯 싶었다.

Android는 일반 자바 프로젝트하고 좀 다르다.
무작정 export를 했더니 xml, res 가 중복됬다고 어쩌고 난리다.
그래서 우선은 일단 라이브러리 시킬 수 있는지를 먼저 찾아봤다.

그래서 찾아보다가 발견한

Library project 

내가만든 프로젝트를 라이브러리화 시켜 jar로 만든뒤
다른 프로젝트에서 사용할 수 있게끔 해주는 프로젝트
안드로이드 개발 홈페이지에 라이브러리 프로젝트 사용방법과 소개가 나와있다.

라이브 프로젝트 생성

생성하는 법은 비교적 간단하다.
그냥 일반 안드로이드 프로젝트 생성한뒤에
프로젝트의 properties -> android -> is Library 선택.
끝.
참고로
is Library가 선택되면 이 프로젝트는 apk를 만들 수가 없게 되어 일시적으로 실행이 되지 않는다.
실행을 하려면 is Library의 선택을 풀어주면 된다.

라이브러리 프로젝트 추가하기

위에서 만든 라이브러리프로젝트를 새 프로젝트에서 추가 시키려면
위와 같은데로 들어가서   properties -> android 
Add를 누르면
라이브러리 선택하는 팝업이 나오고 밑에 GameLibrary가 선택되게끔 되어있다.
가볍게 선택해주고 ok 누르면
android Dependencies 밑에 GameLibrary.jar가 들어가 있음을 볼 수 있다.
마지막으로 androidmanifest.xml에서 액티비티 추가할때처럼
Gamelibrary의 activity를 추가로 선언 해주어야 한다.

라이브러리 프로젝트에 대한 몇가지 특징.

추가로 라이브러리 프로젝트의 특징 몇가지다.
Resource conflicts :  resource id의 이름이 동일한 경우 메인 프로젝트의 resource를 취함. 사전에 적당히 충돌 안나게 조심
you cannot export a library project to a jar file :   library project는 jar파일로 export될 수 없음. 추후 제공할 예정
include a jar library :  다른 jar파일 사용 가능
depend on an external jar library :  외부 라이브러리의 경우 <uses-library> 태그사용
library projects cannot include raw assets : 라이브러리 프로젝트는 assets 폴더를 사용하지 않음.
platform version must be lower than or equal to to android project : 라이브러리 프로젝트가 기본 프로젝트보다 플랫폼 버전이 높으면 안됨
each library project creats its own R class :  뭐 각자 따로 R class 가 생긴 다는 말.

결론

 - 어쨋든 라이브러리 프로젝트는 스스로 jar로 만들수 없기 때문에 본인의 소스를 공개해야 사용할 수 있다.
- 만약 소스를 감추고 싶다면 최소의 코드만 오픈하고
- 나머지 기능들은 적절하게 쪼개서  jar로 만들어
- 라이브러리 프로젝트 내에서 각종 jar파일들을 활용하면 될 것 같다.

댓글

이 블로그의 인기 게시물

메일서버가 스팸으로 취급받을때

설치한 메일서버를 통해 발송되는 메일이 스팸으로 들어가는 경우가 더러 있다. 이게 한번 들어가기는 쉬운데, 빠져나오기는 드럽게 힘든것 같다... 본인의 경우에는 우선 국내서비스에는 별 무리 없이 들어간다. (naver,daum 등) 그런데 해외메일 그중 Gmail, Hotmail 에는 에누리없이 스팸으로 간주되고 있었다. Gmail같은 경우에는 그래도 스팸함으로 발송은 제대로 되는반면에 Hotmail같은경우에는 아예 수신자체가 안되는 경우도 더러있다.. ㅡ,.ㅡ; 제일 좋은 방법은 Gmail,Hotmail에 전화걸어서 우리 메일서버 IP white Ip로 등록해달라!!! 하면 좋지만, 얘네들은 걸어봤자 자동응답기고, 문의채널은 구글 그룹스 게시판이 전부다.. 본론으로 들어가서. 해외 메일이 차단될 경우 내 매일서버ip가 스팸ip로 등록되 버린 경우일 수 있다. (본인처럼. ㅎ) 이것부터 조회 해보고 싶으면 RBL(real-time blocking List) 체크를 해야 하는데, RBL체크 해주는 사이트는 꽤 많이 있고, 그중 좀 깔끔해 보이는곳 하나 소개. http://www.anti-abuse.org/ 메일서버ip 입력하고 조회해보면 쭈루룩 리스트가 나온다. 그 중 빨간불이 들어온 부분이 메일 서버가 스팸서버가 된 각종 이유들이다.ㅋ 본인의 경우 CBL 때문에 걸렸는데, 내용은 아래와 같다. This IP address is HELO'ing as  "localhost.localdomain"  which violates the relevant standards (specifically: RFC5321). 메일서버 도메인에 별다른 작업을 안해놓아서 "localhost.localdomain" 으로 설정되어있었다. 만약 CBL만 바로 테스트 해보고 싶으면 http://cbl.abusea...

[javascript] 특정시간에만 함수 실행

특정시간에만 팝업을 띄우려면?? 특정시간에만 로그인을 막으려면?? 특정시간에만 할일은 의외로 참 많다. 방법? 딱히 없다. 현재시간 구해서 시작시간, 종료시간 사이에 있을때 시작하는 수밖엔. if ((현재시간 > 시작시간) && (현재시간 < 종료시간)){ .. 팝업노출(); 공사페이지 리다이렉트(); 기타등등(); .. } 자바스크립트로 작성하면 다음과 같다. var startdate = "2014012008" ; var enddate = "2014012418" ; var now = new Date (); //현재시간 year = now. getFullYear (); //현재시간 중 4자리 연도 month = now. getMonth () + 1 ; //현재시간 중 달. 달은 0부터 시작하기 때문에 +1 if ((month + "" ). length < 2 ){ month = "0" + month; //달의 숫자가 1자리면 앞에 0을 붙임. } date = now. getDate (); //현재 시간 중 날짜. if ((date + "" ). length < 2 ){ date = "0" + date; } hour = now. getHours (); //현재 시간 중 시간. if ((hour + "" ). length < 2 ){ hour = "0" + hour; } today = year + "" + month + "" + date + "" + hour; //오늘 날짜 완성. / / 시간비교 i...

(java) 크롬에서 쿠키 삭제 안되는 경우

  java에서 쿠키 삭제하는 방법은 똑같은 이름의 쿠키를 만들고 업데이트 하는 방식이다.  이때 maxAge를 '0' 으로 설정한다.  그래서 아래처럼 코딩한결과  크롬을 제외한 나머지 브라우저에서는 전부 쿠키가 삭제가 되었으나 크롬만 삭제가 되지 않았다.  문제의코드 Cookie cookie = new Cookie(name , null ) ; cookie.setHttpOnly( false ) ; cookie.setMaxAge( 0 ) ; cookie.setPath( "/" ) ; cookie.setDomain( "test.co.kr" ) ; 결론만 얘기하면  Secure 설정을 ture로 추가해서 해결했다.  https, ssl 기반에서만 주고받을 수 있게된다.  public void setSecure ( boolean flag) { secure = flag ; } /** * Returns <code> true </code> if the browser is sending cookies only over a * secure protocol, or <code> false </code> if the browser can send cookies * using any protocol. * * @return <code> true </code> if the browser uses a secure protocol; * otherwise, <code> true </code> * @see #setSecure */ 원인은 이사이트의 쿠키설정중 samesite가 'none' 으로 설정되어있었다.  samesite가 none인 경우에는 반드시 secure 옵션을 같이 넣어줘야 크롬에서 정상동작한다. (chrome 80 버전 업데이트 이슈) 웹서버에서 변경하고 싶으면 nginx.c...