偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

PhoneGap與Android之間通信實(shí)現(xiàn)原理

移動(dòng)開(kāi)發(fā)
PhoneGap與Android之間通信實(shí)現(xiàn)原理是本我要介紹的內(nèi)容,主要來(lái)了解PhoneGap實(shí)現(xiàn)原理,具體內(nèi)容的實(shí)現(xiàn)來(lái)看本文詳解。

PhoneGapAndroid之間通信實(shí)現(xiàn)原理是本我要介紹的內(nèi)容,主要來(lái)了解PhoneGap實(shí)現(xiàn)原理。PhoneGap為移動(dòng)開(kāi)發(fā)者帶來(lái)了全新的開(kāi)發(fā)模式,使用javascript調(diào)用移動(dòng)設(shè)備的本地接口,這樣,你就可以在js中調(diào)用你手機(jī)的攝像頭,文件系統(tǒng)等等功能,理論上來(lái)說(shuō),你的本地應(yīng)用程序可以訪問(wèn)的接口都可以通過(guò)javascript來(lái)調(diào)用了。不得不說(shuō),這樣功能實(shí)在是很強(qiáng)大。既能使用javascript,html等web技術(shù)來(lái)實(shí)現(xiàn)程序,又能通過(guò)統(tǒng)一的接口來(lái)調(diào)用本地接口。兼具了web應(yīng)用與app應(yīng)用的特點(diǎn)。

那么PhoneGap是如何實(shí)現(xiàn)javascript腳本調(diào)用本地設(shè)備的接口的呢?

相信大家都很想知道吧,那我就少點(diǎn)廢話了,一句話,通過(guò)ajax發(fā)送請(qǐng)求,實(shí)現(xiàn)腳本對(duì)設(shè)備發(fā)送消息;設(shè)備接受到消息處理后通過(guò)webView的loadUrl方法(這是Android系統(tǒng)下的瀏覽器控件對(duì)象)執(zhí)行腳本實(shí)現(xiàn)腳本的回調(diào)。

主要的代碼有下面三處:

1、

  1. xmlhttp.open("GET", "http://127.0.0.1:"+PhoneGap.JSCallbackPort+"/"+PhoneGap.JSCallbackToken , true); 

 這是phonegap.js里面的代碼,通過(guò)ajax請(qǐng)求,發(fā)送消息給設(shè)備。
 
2、      

  1. active = true;  
  2.             ServerSocket waitSocket = new ServerSocket(0);  
  3.             port = waitSocket.getLocalPort();  
  4.             token = UUID.randomUUID().toString();  
  5.             while(active)   
  6.             {  
  7.                 Socket connection = waitSocket.accept();  
  8.                 BufferedReader xhrReader = new BufferedReader(new InputStreamReader(connection.getInputStream()), 40);  
  9.                 DataOutputStream output = new DataOutputStream(connection.getOutputStream());  
  10.                 String request = xhrReader.readLine();  
  11.                 String response = "";  
  12.                 if(active && request != null)  
  13.                 {  
  14.                     if(request.contains("GET"))  
  15.                     {  
  16.                         String requestParts[] = request.split(" ");  
  17.                         if(requestParts.length == 3 && requestParts[1].substring(1).equals(token))  
  18.                         {  
  19.                             synchronized(this)  
  20.                             {  
  21.                                 do  
  22.                                 {  
  23.                                     if(!empty)  
  24.                                         break;  
  25.                                     try  
  26.                                     {  
  27.                                         wait(10000L);  
  28.                                         break;  
  29.                                     }  
  30.                                     catch(Exception e) { }  
  31.                                 } while(true);  
  32.                             }  
  33.                             if(active)  
  34.                             {  
  35.                                 if(empty)  
  36.                                 {  
  37.                                     response = "HTTP/1.1 404 NO DATA\r\n\r\n ";  
  38.                                 } else  
  39.                                 {  
  40.                                     response = "HTTP/1.1 200 OK\r\n\r\n";  
  41.                                     String js = getJavascript();  
  42.                                     if(js != null)  
  43.                                         response = (new StringBuilder()).append(response).append(URLEncoder.encode(js, "UTF-8")).toString();  
  44.                                 }  
  45.                             } else  
  46.                             {  
  47.                                 response = "HTTP/1.1 503 Service Unavailable\r\n\r\n ";  
  48.                             }  
  49.                         } else  
  50.                         {  
  51.                             response = "HTTP/1.1 403 Forbidden\r\n\r\n ";  
  52.                         }  
  53.                     } else  
  54.                     {  
  55.                         response = "HTTP/1.1 400 Bad Request\r\n\r\n ";  
  56.                     }  
  57.                     output.writeBytes(response);  
  58.                     output.flush();  
  59.                 }  
  60.                 output.close();  
  61.                 xhrReader.close(); 

               
這是java代碼,監(jiān)聽(tīng)javascript代碼發(fā)送過(guò)來(lái)的請(qǐng)求

3、

  1. appView.loadUrl("javascript:PhoneGap...."); 

通過(guò)loadUrl來(lái)執(zhí)行javascript代碼。

小結(jié):PhoneGapAndroid之間通信實(shí)現(xiàn)原理的內(nèi)容介紹完了,希望通過(guò)本文的學(xué)習(xí)能對(duì)你有所幫助!

責(zé)任編輯:zhaolei 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2017-03-28 10:20:24

Docker通信分析

2021-08-11 14:31:52

鴻蒙HarmonyOS應(yīng)用

2009-12-22 09:11:31

WCF雙向通信

2011-09-14 09:20:03

PhonegapAndroid平臺(tái)

2023-08-01 08:43:29

Python多線程

2009-09-10 11:26:59

C# form

2009-12-03 18:15:04

Linux

2011-03-10 09:07:47

liferayportlet

2012-12-24 14:40:54

iosjs

2019-06-25 10:53:06

AndroidFlutter通信

2011-09-05 15:09:06

Android平臺(tái)Phonegap

2011-04-22 10:30:11

VMwareWindowsFTP

2025-09-26 07:12:04

2009-07-15 16:05:04

IP通信捷思銳科技Zed-3

2012-03-07 11:23:09

PhoneGapAndroid代碼交互

2022-12-11 20:09:50

網(wǎng)絡(luò)編程通信

2011-09-13 10:07:10

PhoneGap

2011-12-20 15:52:03

PhoneGap架構(gòu)基礎(chǔ)工作原理

2018-10-11 05:07:19

物聯(lián)網(wǎng)通信IOT

2024-04-03 08:25:52

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)