메뉴 건너뛰기

조회 수 8091 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

3.png


HTTPClinet( 데이터 )나 WebView( 화면 ) 으로 안드로이드에서 사용할 수 있다.


여러 방식이 있지만 Android WebView로 화면을 구성한다.


동작 과정을 다시 간략하게 정리하면


1. 웹에서 파라미터 암호화

2. 안드로이드 웹뷰에서 파라미터 복호화

3. 파라미터 원문 추출


이번 챕터에서는 웹에서 파라미터를 암호화해서 웹뷰로 전달하는 과정을 살펴본다.


핵심은 "Bridge를 통해 JS <-> WebView 간의 통신" 한다는 점이다.

 2.png


 

1
2
_webview.getSettings().setJavaScriptEnabled(true); //자바스크립트 사용 가능
_webview.addJavascriptInterface(jsClass , "androidtest");    //연결 Bridge 등록
cs


Andorid에서 자바스크립트를 활성화하고 콜백 메소드를 등록합니다.

"androidtest" 에 들어갈 문자열은 자바스크립트의 키워드와 겹치지 않으면 어떤 값이 들어와도 상관없다.


자바스크립트에서 window.androidtest.ToastLong(param); 를 호출하면 Android 에서 받을 수 있습니다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
public class JSInterface
    {
        private Decrypt dec = new Decrypt();   // 챕터 2에서 만든 암복호화 클래스
        private WebView mAppView;
        private Activity mContext;
                
        public JSInterface(Activity activity, WebView view)
        {
            mContext = activity;
            mAppView = view;
        }
        
        @JavascriptInterface
        public void ToastLong(final String arg)
        {
            String strDecryptText = dec.AESDecrypt(arg, "Key");
            Toast.makeText(mContext, strDecryptText, Toast.LENGTH_LONG).show();
        }
    }
 
protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.web_view);
 
        _webview = (WebView)findViewById(R.id.WebView01);
        jsClass = new JSInterface(this, _webview);
        _webview.loadUrl(_contentListPath);
 
        _webview.getSettings().setJavaScriptEnabled(true); //자바스크립트 사용 가능
        _webview.addJavascriptInterface(jsClass , "androidtest");    //연결 Bridge 등록
 
        _webview.setWebViewClient(new WebViewClient());
        _webview.getSettings().setBuiltInZoomControls(true);
}
cs

 


주의사항 .  관련 검색도중 나온 버그와 팁

1.

안드로이드 4.3.X 젤리빈 이상부터 "@JavascriptInterface" annotation을 붙이지 않을 경우

해당 메쏘드는 동작하지 않기 때문에 반드시 붙여줘야한다.(킷캣이상인가??;;)


2. 

그리고 Activity의 onCreate 혹은 Fragment의 onCreateView 에서 loadUrl이 불리기전에

WebView 객체의 addJavascriptInterface 메쏘드를 이용해 연결시켜 주면 바로 사용할 수 있다.

 


# 동작 과정

1. WebView 객체 생성 및 초기화

2. 자바스크립트 콜백 클래스 정의 및 초기화

   ( 콜백 생성자에 Context와 Webview 객체를 받아야 보이는 화면이 무엇인가 처리 가능 )

3. Webview에 addJavascriptInterface에 콜백 클래스와 브릿지 네임 설정

4. 자바 스크립트에서 window.androidtest.ToastLong(param); 를 호출하면 콜백 클래스의 ToastLong 메소드 실행

5. ToastLong 에서 넘어온 파라미터를 챕터 2에서 만든 암복호화 클래스로 복호화를 한다.

6. 복호화 한 값을 Toast로 출력한다.


결과는 다음과 같다




  1. 안드로이드 로그인유지 코드

    Date2015.12.14 Views8807
    Read More
  2. 안드로이드 EditText 필터링 검색 구현(adapter.getFilter().filter(cs))

    Date2015.12.14 Views8774
    Read More
  3. 안드로이드 webview (웹뷰) 개발 #3 - 초기 로딩화면 (splash) 띄우기 + 아이콘 적용하기

    Date2015.07.17 Views8697
    Read More
  4. JAVA JDBC를 사용하여 MySQL과 연동

    Date2015.11.21 Views8644
    Read More
  5. 화면 해상도에 관계없는 레이아웃(Layout) 만들기

    Date2015.07.16 Views8641
    Read More
  6. 폰갭(PhoneGap) 에서 페이지들간의 이동

    Date2015.06.29 Views8476
    Read More
  7. 폰갭(PhoneGap) 플러그인 만들기

    Date2015.06.29 Views8458
    Read More
  8. 안드로이드 소스 코드 보호 기법

    Date2015.06.29 Views8336
    Read More
  9. Activity Switching / 안드로이드 액티비티 전환 / 화면 전환

    Date2016.06.07 Views8311
    Read More
  10. 안드로이드 webview (웹뷰) 개발 #2 - 파일 첨부 및 플러그인 적용하기

    Date2015.07.17 Views8295
    Read More
  11. [안드로이드] 페이스북 같은 슬라이드 메뉴 만들기

    Date2015.07.21 Views8203
    Read More
  12. Android Navigation Drawer API 공개! 디자인 가이드 살펴보기

    Date2015.07.29 Views8141
    Read More
  13. 안드로이드 맵 API key (배포용 맵키)

    Date2015.07.01 Views8103
    Read More
  14. Android 와 JSP 간 파라미터 암복호화 (3)

    Date2016.05.26 Views8091
    Read More
  15. 화면 회전에 따른 애니메이션 효과 구현하기

    Date2015.07.16 Views8055
    Read More
  16. 안드로이드 로그인 화면 만들기

    Date2015.09.05 Views8043
    Read More
  17. 블루투스(Bluetooth) 통신에 대해 알아보자

    Date2015.07.01 Views7983
    Read More
  18. 안드로이드 - 소방시설바이블 어플 소스 ( 폰갭, 폰갭플러그인, assets 폴더안의 파일 이용, pdf 리더기 선택, 유튜브재생기 선택 )

    Date2015.06.29 Views7976
    Read More
  19. 안드로이드 NDK 개발환경 만들기 / 이클립스 NDK 설정

    Date2015.06.10 Views7890
    Read More
  20. 어댑터 뷰(Adapter View) & 어댑터(Adapter) (1)

    Date2016.06.08 Views7852
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 13 Next
/ 13

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved