삼성 갤럭시에서 특수문자에 css 효과가 안먹는 증상

다음과 같이 리뷰 rating 기능을 개발 중

가급적 이미지는 사용하지 않기 위해 특수문자를 사용했습니다.

그랬더니 유독 Android kitkat 4.4을 OS로 사용하는 삼성의 갤럭시 기기들만 다음과 같이 보입니다.

sQybc

이곳에는 어떤 CSS 효과도 적용되지 않았습니다.

결국 전 이미지를 사용하긴 했지만 여기저기 찾아보니 아래와 같이

[box type=”info”] /system/fonts/NotoColorEmoji.ttf[/box]

삼성의 기본 이모지 폰트를 안드로이드 기본 emoji 폰트로 대체하고 해결되었다 합니다.

자세한 내용은 이곳을 보시면 확인이 가능합니다.

http://forum.xda-developers.com/showthread.php?t=2618523

 

다른 대안으로 fontawesome이나 추가적으로 iconmoon과 같은 대체 폰트를 이용해서 해결 하는 방법도 있으니 참고하시면 됩니다.

 

HTML:

 

CSS:

iOS8 + iPhone6에서 푸시 안되는 증상

remotePush 등록하는 부분에 다음과 같이 iOS8 대응 코드 추가

appDelegate.m내 다음 딜리게이트 처리

APNS 따라하기 시리즈 (iOS 구성하기)

앱단 개발 개요

앱에서 해줘야 할 일은 앱을 실행한 디바이스의 정보를 3rt Party 서버와 통신해 DeviceToken과 UUID 그리고 사용자 정보를 던져주면 됩니다.
해당기기로 접근할 수 있는 키(열쇠)라고 생각하시면 되며, 이외의 모든 일은 iOS와 APNS서버가 알아서 해줍니다.

 

아이폰/아이패드 개발 코드

코드 작성은 크게 4가지 메서드에서 처리하게 됩니다.

  1. 원격 알림서비스를 iOS에 등록해야 합니다. 등록 성공/실패시 2,3번을 각각 실행합니다.
  2. 앱을 실행시 사용자가 알림서비스를 승인하면 서버로 디바이스 토큰을 보내야 합니다.
  3. 앱을 실행시 알림서비스 등록에 실패하는 경우 로직을 구현합니다.
  4. 메시지를 수신했을 때 처리하는 로직을 구현합니다.

이렇게 구현하면 기본적인 구현 절차는 끝나게 됩니다.
앱에 따라서 처리하는 방식이 달라지는 부분은 주로 2번과 4번이 될 것입니다.
예를 들면 메시지 보낼때 참고할 다른 정보를 보내거나, 메시지를 수신하면 앱내의 특정 부분으로 이동해서 해당 내용을 보여주려고 하실텐데 그런 부분들이라고 생각하시면 됩니다.

그럼 작성해야 할 개발코드를 알아보도록 하겠습니다.
위에서도 언급했다시피 EasyAPNS를 이용해 구현하는 것이니 참고하시기 바랍니다.

우선 (BOOL)application:didFinishLaunchingWithOptions: 메서드에서 원격 푸시 서비스를 하겠다고 등록을 해야 합니다.
이것을 작성함으로써 처음 앱 실행시 푸시알림 메시지를 받겠냐고 물어보는 Alert창이 나타나게 되며, 이 절차를 통해 iOS에게 이 앱이 원격 푸시 서비스를 등록하겠다고 알리는 것입니다. 이렇게만 해주시면 APNS서버에서 메시지를 수신하는 처리는 iOS가 알아서 처리해 앱으로 통보해줍니다.

 

사용자가 푸시를 받겠다고 승인하면 (void)application:didRegisterForRemoteNotificationsWithDeviceToken: 메서드가 실행됩니다.
이때, 우리는 일전에 만들었던 서버단으로 UUID와 deviceToken을 보내 정보를 보관하고 있어야 합니다.
deviceToken은 어떤 앱인지와 어떤 디바이스인지의 조합으로 구성되어진 64개의 바이트 조합입니다.
여기서 UUID와 Token은 사용자의 동의를 얻은 후 외부로 보내져야만 하며 이를 어길시 리젝사유가 될 수 있음을 참고하시기 바랍니다.
deviceToken정보는 EasyAPNS로 구현되어진 서버단의 특정 URL로  정보를 담아 전송해주기만 하면 EasyAPNS가 Device정보를 데이터베이스에 저장해줄 것 입니다.

aps_binary_provider_2

Notification Format

여기서 DeviceToken만 저장해서 보내주면 되지~ 왜? 오만 잡다한 정보도 저장해야하는지 궁금하지 않으세요?
이는 해당 디바이스에서 어떤 설정을 갖고 있는지 알 수 있는 방법이 없어서 입니다. 현재 앱을 설치한 사용자가 배지설정을 켰는지 껐는지 사운드는 켰는지 껐는지를 보내는 쪽에서도 체크를 해야 합니다. 물론 애플에서 해당 디바이스의 정보를 가져올 수 있는 피드백이라는 기능을 제공하고 있긴 하지만 번거로운 작업인 것은 분명합니다. 만약 정보체크를 소홀히 하신다면 해당 사용자가 알림센터 기능을 끄더라도 메시지는 날아갑니다. 이점 반드시 참고하여주시고, 또하나 메서드를 살펴보면 NSData로 DeviceToken값을 넘겨주는데 이는 퍼포먼스때문에 컴퓨터가 좋아하는 바이너리 포맷으로 전달됩니다. 위의 그림에 다 나와있는 내용이니 참고하세요!
자 그럼, 아래와 같이 작성해서 처리를 완료해주시면 됩니다.

 

아래는 등록하다가 실패하는 경우 사용되는 딜리게이트입니다.
간혹 APNS등록해서 잘 사용하다가 Provisioning, Certification, AppID의 내용을 하나라도 수정하시는 경우 에러가 나타날 수 있습니다.
혹 안되실때 이런부분을 찾아보시기 바랍니다.

 

이제 여러분들이 가장 많이 손봐야할 딜리게이트 코드 입니다. 이곳으로 NSDictionary 형태로 메시지정보가 던져지게 됩니다.
그걸 받아서 원하는데로 처리하시면 되겠습니다.
아래는 기본적인 형태로 앱이 실행되지 않을때 경고창을 띄워 알려주는 역할하도록 따로 작성하고 그게 아닌 경우 로그만 찍히게 해봤습니다.
추후 저는 URL을 받아서 해당 URL로 강제이동되게 할 예정입니다.

 

자! 지금까지 iOS의 Application Delegate상에 코드 작성하는 것을 보셨는데요~!

여기서는 EasyAPNS를 사용해 프로바이더(서버)를 구성할 계획이므로 이와 같이 참고하시면 되겠습니다.
서버로 던져주는 인자값들은 EasyAPNS에서 정해진 그대로를 사용한 것입니다.
참고적으로 꼭 정해진 인자값만 보내실 필요는 절대 없다는 점 알아두시기 바라며, 가장 중요한 것은 deviceToken값만 있으면 전송에는 문제가 없습니다.

하지만 하이브리드로 작업하시는 경우 Device의 Unique한 값을 찾느라 고민하실 수 있습니다.
이는 키체인을 이용해서 DEVICE UID를 저장해서 쓰시기 바랍니다.
앱을 삭제했다 다시 설치해도 해당 UID값을 계속해서 쓸 수 있습니다.

참고로 안드로이드는 시리얼을 이용하시면 되겠습니다.

다음은 EasyAPNS을 이용해 프로바이더를 구성하는 법을 소개해드리겠습니다.

 

 Generate Hills of glory Ammo

 

APNS관련 포스팅 보기

하나의 주소로 아이폰/안드로이드 앱 다운로드 하기

앱을 만들어서 배포했는데, 간혹 마케팅을 위해 다운로드 URL이 필요할 때가 있습니다.
특히 안드로이드와 아이폰앱 둘 다 배포해서 서비스 하는 경우는 더욱 더 하나의 URL이 효과적이죠!
그래서, 만들어봤습니다. 원리는 간단합니다.

저희 서버에 download.php라는 파일을 작성해서 링크를 걸고 해당 파일을 호출하면,
기기에 따라 알아서 플레이스토어든 앱스토어로 자동 이동됩니다.

mskv9n1eb9647ii

저의 경우 ShortURL을 활용해서 해당 주소를 http://is.gd/godoapp 과 같은 주소로 줄여서 사용하고 있습니다.
덕분에 해당 주소를 클릭하는 횟수 정보도 해당 ShortURL 서비스 사이트를 통해서 확인할 수 있습니다.

자신의 스마트폰 브라우저에서 http://is.gd/godoapp 이 링크를 쳐서 확인해보세요!
바로 앱스토어로 이동합니다.

 

<모바일 검색용 라이브러리>

 

<실 다운로드 링크 파일>pantai indrayanti

 

iOS8 UITableView의 EdgeInset이 안먹는 경우

iOS7에서는 separatorInset을 UIEdgeInsetsZero로 주면 테이블뷰의 separator 라인의 마진이 없어졌었다.

하지만 iOS8에서는 separatorInset이 아닌 layoutMargin으로 바뀌었다.

테이블뷰에서 직접설정하면 되지만 커스텀 셀을 사용하는 경우 cell에 layoutMargin처리를 해야 제대로 동작한다.

 

하지만, 커스텀 셀이 많은 경우 테이블뷰의 willDisplayCell 딜리게이트를 이용해 다음과 같이 처리하면 보다 적은양의 코드로 처리가 가능하다.

 

-(void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath {

    if ([tableView respondsToSelector:@selector(setSeparatorInset:)]) {

        [tableView setSeparatorInset:UIEdgeInsetsZero];

    }

    

    if ([tableView respondsToSelector:@selector(setLayoutMargins:)]) {

        [tableView setLayoutMargins:UIEdgeInsetsZero];

    }

    

    if ([cell respondsToSelector:@selector(setLayoutMargins:)]) {

        [cell setLayoutMargins:UIEdgeInsetsZero];

    }

}

 

 

네이버 신디케이션 워드프레스 플러그인

네이버 신디케이션 플러그인

[button link=”http://wordpress.org/plugins/naver-syndication” type=”big” newwindow=”yes”] 플러그인 다운로드[/button]

 

주요기능

  1. 관리자내에서 컨텐츠의 타입(web, blog) 중 선택할 수 있음
  2. Permalink를 사용 중인 사이트만 사용 가능
  3. 사이트 상태를 체크

 

추후지원

  1. 컨텐츠의 복구/삭제시 신디케이션 기능 지원
  2. 카테고리 등록일자 지원 (대안 마련 필요)
  3. 기능 작동 위주로 만들어져 추후 코드 정리 필요
  4. 사용자 정의된 post_type에 대한 지원이 안됨 (현재 post만 지원)

 

각 신디케이션 XML 문서 목록

  1. http://qnibus.com/syndi/syndi_echo.php?id=tag:qnibus.com,2014:site&type=site (사이트 정보)
  2. http://qnibus.com/syndi/syndi_echo.php?id=tag:qnibus.com,2014:site&type=channel (채널 목록)
  3. http://qnibus.com/syndi/syndi_echo.php?id=tag:qnibus.com,2014:site&type=article (문서 목록)
  4. http://qnibus.com/syndi/syndi_echo.php?id=tag:qnibus.com,2014:site&type=deleted (삭제된 문서 목록)
  5. http://qnibus.com/syndi/syndi_echo.php?id=tag:qnibus.com,2014:channel:1&type=channel (특정 채널 정보)
  6. http://qnibus.com/syndi/syndi_echo.php?id=tag:qnibus.com,2014:channel:1&type=article (특정 채널내 문서 목록)
  7. http://qnibus.com/syndi/syndi_echo.php?id=tag:qnibus.com,2014:channel&type=deleted (삭제 채널 목록)
  8. http://qnibus.com/syndi/syndi_echo.php?id=tag:qnibus.com,2014:article:1-5081&type=article  (특정문서 정보)

기타 max-entry, page, start-time, end-time 등의 변수를 이용한 검색시 해당 정보 출력 가능

 

핑이 전송되는 시점

  • Post의 등록
  • Post의 수정
  • Post의 삭제
  • 카테고리의 등록
  • 카테고리의 수정
  • 카테고리의 삭제

 

유의사항

  1. 포스트 등록 및 수정을 하면 3분 이내에 사이트 상태가 standby로 변경됨
  2. 사이트에 따라 네이버에서 승인을 해주는 경우와 안해주는 경우가 있음
  3. https://help.naver.com/support/contents/contents.nhn?serviceNo=606&categoryNo=2017

 

워드프레스를 위한 다음뉴스 플러그인

스크린샷 2014-06-02 오후 8.57.29

다음뷰가 올해안에 없어질 예정이고, 그런 정책이 나오면서 다음뉴스 송고 API도 방식이 변경되었습니다.
이에 따라 워드프레스의 컨텐츠를 원하는 뉴스채널로 송고해주는 API를 워드프레스 플러그인으로 개발하게 되었습니다.

죄송하지만 무료는 아니구요!
필요하신 분께서는 qnibus@me.com 으로 문의 주시면 성심성의껏 답변드리겠습니다.

단, 뉴스검색제휴는 위 그림과 같이 가입할 수 있는 매체가 제한적이기 때문에 사용하기전 반드시 입점가능 여부를 타진하고 문의주세요!

 

플러그인 소개

그럼 간단하게 플러그인에 대해 소개해드리겠습니다.
다음뉴스 송고 API 방식은 이번에 변경되면서 많이 간결해졌습니다.

다음뉴스 송고 API의 방식은 간단합니다.

이미지태그를 display: none 시켜 보이지 않게 하고 링크는 다음뉴스를 향하고 변수값으로 xml링크와 원문링크 그리고 채널을 적어서 넘겨주면 끝입니다.
하지만, 어뷰징때문에 그런지 몰라도 굉장히 세세하게 따지는 조건들이 몇가지 있으며, 조건들을 지키지 못할 경우 다음측에 의해 강제로 제휴종료가 될 수도 있습니다. 하지만 본 플러그인은 프로그램단에서 사용자가 실수 할 수 있는 부분들은  제거함으로써 불필요한 경고를 최소화할 수 있기에 좀더 안심하고 사용하실 수 있으리라 생각합니다.

 

XML 샘플

실질적으로 해당 포스트의 XML만 구현해서 <img>태그에 해당 경로를 지정해주기만 하면 됩니다.
XML은 다음과 같이 다음뉴스 송고API에서 지정한 양식대로 출력이 됩니다.

http://qnibus.com/daum/1

현재 샘플로만 해놔서 정확하게 보이진 않지만 모든 내용은 포스트에서 추출되어 자동으로 기입되어집니다.

 

포스트 작성화면

스크린샷 2014-05-25 오후 3.27.12  스크린샷 2014-05-25 오후 3.34.00

 

기존에 제가 개발했던 다음뷰 플러그인과 사용방법은 유사합니다.
포스트 등록시 자동으로 되게 할 수 있으니 조건상 한번 뉴스검색제휴 서버와 연결되고 나면 더이상 해당 문서를 수집하지 않기때문에 실수가 발생할 수 있습니다. 이에 따라 글을 작성하고 필요할 때 송고할 수 있도록 개발되었습니다.
더불어 뉴스를 송고하시면 10분내에 검색엔진에 반영됩니다.

현재 인더스트리얼솔루션이라는 산업솔루션 뉴스매체에서 본 플러그인을 활용하고 있으며,
피드백을 통해 불필요한 부분들은 제거하고 필요한 부분들은 추가해 안정화시키고 있습니다.

관심있으시면 불편해하지 마시고 메일이나 댓글로 문의주시기 바랍니다.

앱 통계를 내 사이트에서 수집하기

스크린샷 2014-02-09 오후 11.35.26

 

프롤로그

모바일 앱을 보유하고 있다면 누구나 한번쯤 다운로드 혹은 리뷰 데이터를 한곳에 수집해서 보고 싶어했으리라 생각합니다.

2년전 회사에서 이런 요구가 있었고 이를 사내 사이트에 구현했던 일이 어렴풋이 기억납니다.
그때는 API가 따로 없어서 rss피드와 국가코드, 카테고리 정보등을 별도로 수집해서 사용했었는데요!
이제는 그렇게 하지 않아도 됩니다.

앱애니(AppAnnie)라고 하는 사이트에서 올 초부터 API를 지원하기 시작했기 때문입니다.
전 이것만 기다리고 있었는데, 마침 나와줘서 다운로드 통계 수집을 자동화시킬 수 있었습니다.

앱애니의 통계는 초기 아이폰만 수집해줬었는데요, 간만에 들어가보니 안드로이드는 물론 아마존의 다운로드 통계를 제공해주더군요!
앱애니에서 제공해주는 API는 생각보다 효율적이고 대단히 고마운 API라고 생각합니다.

다만,제약조건이 일일 1,000회, 분당 30회로 제약이 되어있긴 하지만, 앱 10개정도 보유하고 있다면 이정도로 충분합니다.
그럼 어떤 종류의 API를 제공하는지 알아보겠습니다.

 

지원하는 API의 종류

  1. Account Connection Sales
  2. App Sales
  3. App Ranks
  4. App Reviews
  5. App Ratings
  6. App Features
  7. App Details
  8. Platform List
  9. Country List
  10. Category List
  11. Currency
  12. Account Connections List
  13. Account Connection App List
  14. App IAP List
  15. Shared Apps List

이렇게 총 15가지를 지원하고 있습니다.
왠만한 필요한 정보들은 다 가져올 수 있습니다.
다음은 API를 신청하기 위한 절차에 대해 간략하게 나열해보겠습니다.

 

API신청 절차

  1. appannie.com 에서 회원가입을 한 후 로그인한다.
  2. 애플, 구글, 아마존 접속 계정으로 로그인해 통계 데이터 수집에 동의한다.
  3. 위의 단계로 appannie에서 자동으로 앱 데이터를 수집합니다.
  4. 그럼 https://www.appannie.com/account/api/key/ 여기서 API키를 발급받습니다.
  5. http://support.appannie.com/categories/20082753-Analytics-API 문서를 보고 개발을 합니다.

귀찮게 Oauth와 같은 인증방식을 요구하지는 않습니다.
다만 header에 Autherization에 API 키만 넣어서 쏴주면 원하는 결과값을 가져옵니다.
요청에 따라 xml과 json으로 선택적으로 받아올 수 있습니다.

 

이용예시

스크린샷 2014-02-09 오후 11.57.52

위 테이블은 API를 이용해 구축해놓은 예시입니다.
물론 테이블의 상단에는 앱별로 선택해서 현재 판매중인 모든 앱에 대해 정보를 조회할 수 있습니다.

여러분도 한번 만들어보세요! ^^

 

APNS 따라하기 시리즈 (프로바이더 구성하기)

프로바이더에서의 개발 개요

두번째 시리즈인 프로바이더에서 개발 방법에 대해서 알아보겠습니다.
이미 인증서 만들기에서 제작한 apns.pem 인증서 파일을 FTP 프로그램을 이용해 임의의 경로로 업로드 합니다.
보통 웹루트내에 파일을 올리면 주소나 파일명만 알면 바로 다운로드 받아갈 수 있기때문에 가급적 웹루트가 아닌 곳에 올려주시기 바랍니다.

이 인증서로 APNS 서버와의 통신을 통해 인증을 받고 인증을 받은 상태에서 Payload에 애플이 요구하는 텍스트를 채워 json데이터를 APNS서버로 전송해주기만 하면 됩니다. 이런 부분을 손쉽게 접근할 수 있도록 도와주는 친구들을 아래에서 몇 명 소개시켜드리겠습니다.

그래도 어떤 원리인지는 간단하게 알고 넘어가야겠죠?

 

Payload 작성 양식

다음의 애플문서를 보면 아주아주 자세하게 나와있습니다. 영어가 되시는 분은 애플에서 제공하는 원문을 보시는게 더 좋을 것 같네요!
기본적으로 Payload는 JSON 형식으로 전달되며 형식은 다음과 같습니다.

여기서 aps 키값은 Dictionary 형태로 만들어지며 각각의 키들은 다음과 같은 역할을 합니다.

  • alert : 스트링 혹은 딕셔너리 형태로 값이 들어갈 수 있으며 스트링으로 할 경우 보내고자하는 메시지를 적어 넣어주시면 됩니다.
    • body : 전달할 내용을 입력합니다.
    • action-loc-key : LocalizedString의 키값을 참조해 AlertView의 View Detail이라는 버튼을 언어에 맞게 변경시켜줍니다.
    • loc-key : LocalizedString의 키값을 참조해 내용을 채워줍니다.
  • badge : 배지의 숫자를 입력합니다.
  • acme1 or acme2 : 커스터마이징 변수값으로 임의의 문자열로 키와 값을 만들어 스트링 혹은 배열의 형태로 전달 할 수 있습니다.

PHP 테스트 코드:

아래는 EasyAPNS가 아닌 막코딩으로 전송테스트를 해보았습니다.
상단에 deviceToken정보만 제대로 입력해주면 해당 디바이스로 메시지가 잘 전송되는 것을 확인했습니다.

 

개발에 사용할 오픈소스

위와 같이 Github 및 검색을 해보시면 아시겠지만 다양한 개발자들이 만들어 놓은 오픈소스가 많이 있습니다.
가장 최근에 등록된 PHP_APN의 경우 API를 기능별로 세분화시켜놓아 관리기능을 별도로 제작할때 좋지 않을까 싶습니다.
하지만 저는 PHP로 개발코자 EasyAPNS를 이용해서 개발을 시작하다가 일이 커져 지금은

별도로 개발해 안드로이드까지 통합발송이 되도록 만들어 사용하고 있습니다.
GCM(Google Cloud Message)에 대한 정보는 다음에 시간날때 게재하도록 하겠습니다.

 

관련 참고 자료:

Why was my device token rejected by Apple?

Local and Push Notification Programming Guide

How to build an Apple Push Notification provider server (tutorial)

 

APNS 따라하기 시리즈 (인증서 만들기)

APNS 포스팅 개요

1년만에 다시 푸쉬서비스를 만들려고 하니 기억도 안나고 검색해서 찾아보니 너무 옛날 데이터들이라 헷갈리기도 해서 “이참에 좀 자세하게 기록해놓자!!” 하는 마음에 포스팅을 했습니다. 총 3단계로 나누어 인증서 설치, 서버단에서 푸시 보내기, 앱단에서 푸시 처리하기로 해서 포스팅을 시작하고자 합니다.
APNS란 용어는 애플 개발자 레퍼런스에도 너무 자세하게 나와있고 검색해도 수도 없이 나오기때문에 생략하고 철저하게 개발 적용에만 촛점을 맞추도록 하겠습니다.

 

APNS 인증서 발급 조건

  • 발급일 2013년 7월경
  • Mac OS  X 버전 10.8.4 (산사자)
  • Xcode 버전 4.6.3
  • iOS7이 베타3까지 출시

 

APNS 인증서 발급을 위한 개인 인증서 만들기

우선 애플(Apple) 사이트에서 Notification 인증서를 만들기 위해서는 아래와 같이 키체인을 이용해
CertificateSigningRequest.certSigningRequest 라는 인증서를 만들어야 합니다.

이 인증서는 Notification 인증서를 발급받을 때 반드시 필요하니 우선 따라서 만들어 봅시다.
키체인(Keychain)을 실행한 후 다음과 같이 따라 해보세요!

APNS 설치 인증서 만들기 1
키체인을 실행한 후 키체인접근> 인증서지원 > 인증 기관에서 인증서 요청을 누릅니다.

 

APNS 설치 인증서 만들기 3
디스크저장됨을 선택하고 본인이 키 쌍 정보 저장을 체크하세요! 특히 이메일은 개발하는 애플 개발자 아이디를 넣어주시기 바랍니다.
APNS 설치 인증서 만들기 4
그림과 같이 설정하시고 다음으로 넘어가세요!
APNS 설치 인증서 만들기 5
인증서 서명을 하기 위한 요청 파일이 완성되었습니다.

이렇게 작업을 완료하시고 Finder에서 보기를 눌러 보시면 다음과 같은 파일이 만들어집니다.

CertificateSigningRequest.certSigningRequest

 

 

APNS 인증서 발급받기

[box type=”warning”] 반드시 애플 개발자 계정을 가지고 계셔야 접근하실 수 있습니다. 일반 애플 계정과는 다르니 안되시는 분은 개발자 등록부터 해주시기 바랍니다.[/box]

이제 개인 인증서를 만들었으니 애플 개발자 사이트로 이동합니다.
개발자 사이트에 접속하시면 상단에 Member Center라는 곳이 있습니다.
접속하시면 바로 아래의 이미지와 같은 화면을 보실 수 있습니다. 그림을 보시면서 순서대로 따라하시면 금방 APNS용 인증서를 발급받을 수 있습니다.
그럼, 멤버센터에서 Certificates, Identifiers & Profiles > Identifiers > APP ID’s 메뉴로 이동하세요!

 

Member Center - Apple Developer_1
멤버센터 메인 화면에서 빨간 박스의 Certificates, Identifiers & Profiles를 클릭하세요!
Member-Center---Apple-Developer_2
APP IDs 메뉴를 눌러 들어온 화면입니다. 자신이 만들어놓은 앱아이디를 한눈에 보실 수 있습니다. 그럼, 노티를 원하는 앱아이디를 선택하세요!
Member-Center---Apple-Developer_3
선택하시면 해당 앱에서 무슨 서비스가 연동되고 사용되는지 한눈에 보실 수 있습니다. 그중 Push Notification 서비스가 Enable 되어있는지 확인하고 Disable 되어있으면 하단의 Edit 버튼을 누릅니다.
Member-Center---Apple-Developer_4
저는 이미 만들어 놓아 인증서 내역이 보이지만 몇개고 만들 수 있습니다. 개발용과 배포용으로 만들 수 있으며 우선 개발용으로 해보겠습니다. 자 그럼, Create Certificate를 눌러주세요!
Member-Center---Apple-Developer_5
이과정은 아까 맥에서 만들었던 인증서를 만드는 방법에 대해서 안내해주는 화면입니다. 우린 이미 만들었으니 다음 단계로 넘어가시죠!
Member-Center---Apple-Developer_6
아까 만들었던 인증서를 업로드해야 합니다. Choose File을 눌러 CertificateSigningRequest.certSigningRequest 파일을 연결해주세요!
Member-Center---Apple-Developer_7
자! 그럼 Generate를 눌러 APNS 인증서를 발급받아보세요!
Member-Center---Apple-Developer_9
드디어 인증서가 만들어졌습니다. 다운로드를 눌러주세요!
Member-Center---Apple-Developer_10
인증서가 이제 다운되었습니다. 다음은 인증서를 클릭해 실행해주세요! 그럼 키체인에 인증서가 추가됩니다.

 

이렇게 해서 인증서 발급을 과정을 마쳤습니다. 생각보다 어렵지 않습니다.
자 그럼, 이제부터가 중요한데요! 서버에 직접 설치할 인증서를 만들어 보겠습니다.

 

APNS 서버인증서 만들기

서버인증서를 만드는 작업을 하기전에 우선 키체인을 열어 방금 설치한 Apple Development(or Production) iOS Push Services: kr.co.godo.godo 인증서를 찾아서 Export(내보내기)를 해서 .p12 파일로 만들어줘야 합니다.
다음의 그림을 보면서 따라하시면 되겠습니다. 그림과 같이 인증서 옆에 화살표 아이콘이 있고 그걸 누르면 개인키가 나타나오니 참고하시면서 작업하시기 바랍니다.

Keychain에서 서버인증서 만들기 1
저는 개발과 출시용 Push Service 인증서를 둘다 설치해서 2개가 나타나며 원하는 것을 선택해서 만들어주시면 됩니다.
Keychain에서 서버인증서 만들기 2
우선 그림과 같이 마우스 오른쪽을 눌러 보내기 메뉴를 눌러주세요!
Keychain에서 서버인증서 만들기 3
그럼 이러한 창이 뜰 것이고 별도저장(Save as)에 cert라고 넣어주세요!
Keychain에서 서버인증서 만들기 3-1
저장을 누르면 패스워드를 넣으라는 창이 나타납니다. 이곳에 원하는 패스워드를 넣고 승인을 눌러주세요!
Keychain에서 서버인증서 만들기 4
다음은 개인키입니다. 그림과 같이 열쇠모양의 개인키를 선택해 오른쪽 마우스 눌러 보내기를 클릭합니다.
Keychain에서 서버인증서 만들기 5
별도저장(Save as)에 key라고 입력하고 저장을 눌러줍니다.
Keychain에서 서버인증서 만들기 3-1
외우기 쉽도록 cert에서 만든 패스워드를 동일하게 넣어주세요!

 

이작업을 하시면 바탕화면(여러분이 지정한 경로)에 cert.p12와 key.p12 파일들이 만들어집니다.
이제부터 중요합니다. 인증서 형식을 변환하기 위한 작업으로 Terminal에서 작업을 할 것 입니다.
딱 4가지 명령만 실행하시면 됩니다.  ———- 이걸로 표시된 부분은 결과값을 보여주려고 나타낸 것이니 터미널에서는 입력하지 말아주세요!

다음과 같이 입력하고 엔터를 치면 비밀번호를 물어봅니다.
이 비밀번호는 아까 cert.p12 만들때 작성하신 패스워드를 넣어주시면 됩니다.
이렇게 하고 나면 해당 경로에 cert.pem 이라는 파일이 생깁니다.

 

위 코드는 key.p12를 key.pem으로 만들어주는 작업입니다.
바로 윗부분에 cert.pem 만드는 작업과 동일하지만 마지막에 패스워드를 생성하는 작업을 해주셔야 합니다.

 

위에서 만들어진 key.pem을 가지고 key.unencrypted.pem을 만드는 코드입니다.
하단의 출력결과에도 써있다 시피 윗단계에서 새로 생성한 패스워드를 입력하시면 됩니다.
이제 마지막 하나가 남았습니다.

 

마지막부분에 apns.pem이라고 적어놓은 부분은 여러분이 만들고 싶은 이름으로 변경해서 작성해주시면 됩니다.
이렇게 마무리 하시면 작업하신 해당 경로에 아래리스트와 같이 6개의 파일들이 생성되어 있을 것이니 꼭 확인해주시기 바랍니다.

  • cert.p12
  • key.p12
  • cert.pem
  • key.pem
  • key.unencrypted.pem
  • apns.pem

 

윗 단계를 하나의 이미지로 보면 다음과 같습니다.

Keychain에서 서버인증서 만들기 6
총 6개의 파일이 생성되며 터미널 안에 보시면 타이핑한 내역이 그대로 있습니다.

 

이제 모든 것이 끝났습니다. 결국 apns.pem 이 파일 하나 만들고자 이짓을 했던 것 입니다.
푸시서버로 구성할 곳으로 apns.pem 파일을 업로드 해주시면 됩니다.
위치는 아무곳에나 하셔도 상관없지만 경로만 알면 다운로드가 가능한 웹루트는 피하시기 바랍니다.

이렇게 만들어진 인증서를 이용해 SSL Connect의 연결을 유지한 상태에서 Push메시지를 발송하면 됩니다.
개발에 관련된 부분은 다음 스텝에서 안내해드리겠습니다.

 

APNS관련 포스팅 보기

 

Manziel now has four sixty minute assessments to prove he is the future of the franchise and give the Browns fans some hope for next year. If oakley outlet he can’t do that then the city of Cleveland will likely be in for cheap nba jerseys a few more years despair.. The identity of these cell population was also further confirmed and functionally characterized by quantitative RT PCR in the presence or absence of lipolysaccharide (LPS) using microglia specific PCR primers sets (IBA1, CD11b, CX3CR1 and TNF) (Fig. 5C). You see, the media is like the attractive girl at your high school who you always hated. They’re deceptive, in love with the best, and as much as you want to stay away from them, you keep on giving them the attention they desire. If it turns out that a wedding, birthday, or bar mitzvah dares to interfere with throwback nba jerseys your upcoming Jimmy Buffet or Dave Matthews show, you needn’t fear. Selling your tickets over the Web is easy and legal.. The report showed Sirius XM’s short interest for the two weeks ending Nov. 15 had increased to just over 212 million shares, from its previous reporting period of 183 million. Now looking ahead to Q4, when I came back to Electronic Arts I made a commitment to invest in quality both because I believe it is the right decision for the long term financial health of the company and because it is what our consumers have a right to expect. This is an important principle, even if it results in short term pain.. Again I expect to see the $2.00 level act as a pivot for at least 4 weeks, with trading above and below that figure. If we have an entire mild winter, thanks to a strong El Nino, we could spend February and March 2016 having a ceiling of $2.00, with dips cheap oakleys down to the $1.50 to $1.60 level. This Cheap nfl jerseys is a good starting point for ideas. Each soo unique and amazing. While it was a substantial offer, we were advised by Jarryd’s management that it was not comparable to the other proposals. The club wishes Jarryd well in his future endeavours.”. This will help the stinger to pop out. Never use tweezers as they might actually push the stinger further in.. And for years they exempted athletics from the cut, but then these last few years there’s just been no choice. And that’s what the players are feeling now.. Stats Cheap nfl jerseys show the Lakers and Clippers main bench units have been equally good this season. The Laker group offensive rating, which measures points scored per 100 possessions, is 104.9. “Fair point” is where Clinton left it. Inevitability: Clinton launched her 2016 campaign pushing back hard on the perception that she expected to win ray bans ale the sense of inevitability that surrounded her campaign in 2008.