999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

基于websocket的適配多種瀏覽器的插件開發方法

2020-05-11 12:24:30嚴偉苗諸葛楊楊劉瑞鄒翔
數字技術與應用 2020年2期

嚴偉苗 諸葛楊楊 劉瑞 鄒翔

摘要:針對當前各類瀏覽器插件不兼容問題,本文提出了一種基于websocket的適配多種瀏覽器的插件開發方法。

關鍵詞:瀏覽器;websocket;插件;連接

中圖分類號:TP311.1 文獻標識碼:A 文章編號:1007-9416(2020)02-0108-01

0 引言

瀏覽器插件是當前應用范圍較為廣泛的技術之一,如常見的adobe flash player,可用來在網頁中嵌入并播放視頻,再有各大銀行門戶網站中常見的安全網銀控件等等[1]。目前主流瀏覽器插件技術主要包括Microsoft的ActiveX插件技術、Mozilla的NPAPI插件技術以及Google的PPAPI插件技術,而國內互聯網公司推出的一些瀏覽器基本上采用了以上幾個國外廠家的瀏覽器內核,所以在插件技術上并沒有突破創新。

當軟件系統采用基于B/S架構模式進行開發,原本適配C/S架構模式的插件工具,如人臉采集儀、指紋采集儀等通常無法直接集成于網頁端,而這些設備的開發商往往僅提供一個簡單的開發工具包,開發人員必須根據不同瀏覽器各自指定的插件技術開發規范開發不同版本的插件實現兼容適配,不僅需要開發三種以上不同技術版本的插件代碼,同時也不可避免地存在重復工作,無形之中增加了程序出錯的概率。目前尚沒有一種插件技術能夠同時兼容多種瀏覽器,并實現無縫對接使用,而不同瀏覽器廠商出于安全考慮對各類插件的使用權限也做了不同程度的限制,導致應用系統在調用插件的時出現調用失敗、頁面無反應甚至直接被禁用等情況。

WebSocket同http一樣,都是基于TCP的可靠性傳輸協議[2],且都工作在應用層中,但webSocket僅需完成一次握手便可建立持久連接,并可進行雙向數據傳輸,且可以主動向瀏覽器等客戶端發送數據,數據當中也不必再帶有head的部分信息了。與http的長鏈接通信相比,不僅降低了系統壓力,而且也減少了部分多余的信息,節省了帶寬。本文提出了一種基于websocket協議的、可適配多種瀏覽器的插件開發方法。該方法依托websocket協議建立瀏覽器與插件之間的可靠持久性連接,以此支持瀏覽器調用插件開放的各服務功能接口,大大減輕了技術人員的開發、調試及維護工作量,有效規避了因瀏覽器版本差異等問題導致的插件服務調用失敗、頁面無反應甚至直接被禁用等情況,較好滿足了用戶及系統使用需求[3]。

1 插件設計

為實時監聽并響應來自瀏覽器的接口調用請求,插件應作為websocket的服務端,實際生產環境中還應注冊為操作系統的開機啟動服務,同時允許本地防火墻允許開放websocket服務端監聽端口。當作為客戶端的瀏覽器開啟并訪問特定應用網站時,若某個頁面集成了如人臉采集儀、指紋采集儀的相關功能,當用戶需要使用這些功能時,瀏覽器便會按照相關流程完成功能接口調用。

websocket連接必須由瀏覽器發起,因為初始請求為一個標準的http請求,格式如圖1所示。

圖1所示請求和普通的http請求有幾點不同:(1)該請求為GET方式的請求,請求地址以ws://開頭;(2)請求頭中Upgrade和Connection表示該連接將要被轉為WebSocket連接;(3)Sec-WebSocket-Key用于標識這個連接;(4)Sec-WebSocket-Version指定了WebSocket的協議版本。

當插件服務成功接受該請求后,會返回如圖2所示的響應內容,其中響應代碼101表示本次連接的http協議即將被更改,更改后的協議就是websocket協議,版本號和子協議規定了雙方能理解的數據格式,以及是否支持壓縮等。

當瀏覽器和插件成功建立websocket連接后,瀏覽器和插件之間就可以隨時主動發送消息給對方了。插件封裝的服務接口視具體需要的操縱本地設備而定,通常設備廠家會提供該設備在不同操作系統下的功能開發庫,以供開發者根據業務需求來定制自己的插件功能。

2 插件測試

為驗證基于websocket的適配多種瀏覽器的插件開發方法在實際應用中的可行性,本文開發了一套測試系統,該測試系統主要由浙江中正智能科技有限公司開發的MR-210臺式身份證閱讀機具、基于該閱讀機具的非接觸式Type-A卡讀寫功能庫開發的插件服務程序以及一個簡單的瀏覽器網頁應用程序(部署在tomcat上)組成。

測試時需要先啟動插件服務程序,啟動成功后會提示“開啟websocket插件服務,等待連接…”,然后在瀏覽器中輸入應用程序網址(http://localhost:8080/websocket_client.html),并在彈出的網頁服務插件地址欄中輸入服務連接地址(ws://127.0.0.1:3000),連接成功后,下方響應詳細框中會提示“連接成功”。為方便測試,本文定義在請求輸入框中輸入“0”表示讀卡,輸入“1|JSON格式卡片數據”表示寫卡。

當瀏覽器端請求數據為0時,若請求成功,插件服務程序會提示“收到來自客戶端的讀卡請求”,然后讀取卡片數據并將數據返回給瀏覽器端。當瀏覽器端請求數據為“1|{“userName”:“張三”,“zoneName”:“宋都凱旋苑”,“buildingNum”:“01”,“unitNum”:“01”,“floorNum”:“10”,“roomNum”:“1002”,“beginTime”:1577426791,“endTime”:1609049191,“rollingCode”: 0, “cardType”: 11}”時,若請求成功,服務端會提示“收到來自客戶端的寫卡請求”,然后將待寫入數據寫入卡片中,并將寫卡結果返回給瀏覽器。從二次讀卡結果看,卡內數據已被成功覆寫。

3 結語

為適配多種瀏覽器,降低開發維護成本,本文提出了websocket的插件開發方法,該方法可不再遵循各個瀏覽器的插件開發規約,只需定義服務端與瀏覽器端的接口規范,在滿足用戶需求的同時大大簡化了開發流程。

參考文獻

[1] 汪詩林,吳泉源.WWW瀏覽器插件開發技術[J].計算機應用研究,2000(4):55-57.

[2] 湖北省數字證書認證管理中心有限公司.一種基于http的web插件調用方法及系統:CN201611216467.5[P].2017-05-31.

[3] Coward D. Java WebSocket Programming[M]. New York: McGraw-Hill,2014.

Websocket-based Plug-in Development Method Adapted to Multiple Browsers

YAN Wei-miao, ZHUGE Yang-yang, LIU Rui, ZOU Xiang

(Hangzhou Yihe Network Co., Ltd., Hangzhou? Zhejiang? 310012)

Abstract:In view of the incompatibility of various browser plug-ins, this paper proposes a web socket based plug-in development method which adapts to multiple browsers.

Key words:browser; websocket; plug-in; connection

主站蜘蛛池模板: 中文字幕天无码久久精品视频免费| 国产www网站| 五月天久久综合国产一区二区| 91无码网站| 欧美午夜视频| 凹凸国产分类在线观看| 亚洲日韩精品欧美中文字幕| 拍国产真实乱人偷精品| 欧美日韩国产成人高清视频| 亚洲天堂久久新| 在线毛片免费| 色欲国产一区二区日韩欧美| 91青青视频| 尤物在线观看乱码| 97视频精品全国在线观看| 青草国产在线视频| 香蕉伊思人视频| 国产日韩欧美成人| 亚洲狼网站狼狼鲁亚洲下载| 久久久久青草线综合超碰| 日本免费高清一区| 国产精品xxx| 制服丝袜一区| 99久久99这里只有免费的精品| 久久久精品国产SM调教网站| 国产精品一区在线麻豆| 精品人妻一区无码视频| 国产熟睡乱子伦视频网站| 久久香蕉国产线看观看亚洲片| 日韩在线1| 精品剧情v国产在线观看| 国产办公室秘书无码精品| 狠狠色丁香婷婷综合| 久久亚洲天堂| 欧美色99| 久久香蕉国产线| 亚洲精品午夜天堂网页| 国产一级在线观看www色| 久久精品国产国语对白| 中文一级毛片| 伊人色综合久久天天| 中文字幕人妻av一区二区| 国产白浆在线| 国产精品视频系列专区| 一级成人欧美一区在线观看| 一级黄色欧美| 国内精品自在欧美一区| 亚洲日本中文字幕天堂网| 国产高颜值露脸在线观看| 亚欧美国产综合| 欧美精品xx| 国产亚洲精品自在久久不卡| 亚洲欧美精品在线| 国产精品13页| YW尤物AV无码国产在线观看| 97视频在线精品国自产拍| 青青草原国产精品啪啪视频| 精品一区二区三区自慰喷水| 国产日韩精品欧美一区灰| 日韩毛片免费| 亚洲综合第一区| 成人福利在线观看| 国产xxxxx免费视频| 99精品视频在线观看免费播放| 在线观看亚洲天堂| 91麻豆精品国产高清在线| 亚洲成人网在线观看| 这里只有精品免费视频| 亚洲欧美另类日本| 久久无码免费束人妻| 先锋资源久久| 激情無極限的亚洲一区免费| 午夜电影在线观看国产1区| 久爱午夜精品免费视频| 日本日韩欧美| 国产在线一区二区视频| 国产色图在线观看| 91综合色区亚洲熟妇p| 最新痴汉在线无码AV| 无码aaa视频| 99人体免费视频| 一级黄色欧美|