實現chrome擴展啟動本地進程 - 補充

實現chrome擴展啟動本地進程 - 補充

標簽:?chrome擴展啟動本地程序訪問本地磁盤
?分類:
Chrome Plugin

示例 主要包含如下部分
com.google.chrome.demo-win.json
native_cmd.bat
manifest.json
popup.html
popup.js
功能簡介:
實現一個擴展,用戶點擊一個按鈕后會啟動本地的notepad程序(也可以為自己寫的程序,這里示例就啟動notepad,類似迅雷擴展的功能)
實現概述:
通過啟動本地的一個批處理來進而調用啟動notepad.exe
拓展:
可以將批處理換成自己寫的程序,然后再在該程序中實現訪問本地磁盤數據或者其它事

程序源碼在網盤(Chrome Plugin目錄下的Demo.rar):

??http://pan.baidu.com/s/1hcVuQ

?

效果圖:

?

?

部分代碼:

?

manifest.json

?

[javascript]?view plaincopy
在CODE上查看代碼片派生到我的代碼片
  1. {??
  2. ?????//??Extension?ID:?ndnigonbfjhpjlcabmadmkpdcfomenlp??
  3. ?????"manifest_version":?2,??
  4. ??
  5. ?????"name":?"Invoke?Native?Application",??
  6. ?????"description":?"example",??
  7. ?????"version":?"1.0",??
  8. ??
  9. ?????"browser_action":?{??
  10. ??????????"default_icon"?:?"icon.png",????
  11. ??????????"default_popup":?"popup.html"???//定義了點擊擴展后顯示的頁面??
  12. ?????},??
  13. ?????"permissions":?[??
  14. ?????????"nativeMessaging"?????//定義權限,需要和本地應用程序通信??
  15. ??]??
  16. }??

?

?

popup.js
[javascript]?view plaincopy
在CODE上查看代碼片派生到我的代碼片
  1. function?updateResult(obj,?state){??
  2. ?????document.getElementById(obj).innerHTML?=?state;??
  3. }??
  4. function?invoke(){??
  5. ?????//hostName為注冊表上項的名稱??
  6. ?????var?hostName?=?"com.google.chrome.demo";??
  7. ????//啟動本地應用程序??
  8. ?????var?port?=?chrome.runtime.connectNative(hostName);??
  9. ?????updateResult("result1",?"invoke..");??
  10. }??
  11. ??
  12. //為button1添加監聽事件??
  13. document.addEventListener('DOMContentLoaded',?function()?{??
  14. ??document.querySelector('#button1').addEventListener(??
  15. ??????'click',?invoke);???
  16. });??
  17. ??
  18. com.google.chrome.demo-win.json??
  19. ??
  20. {??
  21. ??"name":?"com.google.chrome.demo",??
  22. ??"description":?"Chrome?Native?Messaging?API?Example?Host",??
  23. ?//path?必須是絕對路徑,指向要啟動的程序??
  24. ??"path":?"D:\\Work\\Chrome?plugin\\Native?Messaging?Example\\Demo\\native_cmd.bat",??
  25. ??"type":?"stdio",??
  26. ??"allowed_origins":?[??
  27. ????"chrome-extension://niekdnkneilndiimkikogmplndpcfknp/"??
  28. ??]??
  29. }??
com.google.chrome.demo-win.json
[javascript]?view plaincopy
在CODE上查看代碼片派生到我的代碼片
  1. {??
  2. ??"name":?"com.google.chrome.demo",??
  3. ??"description":?"Chrome?Native?Messaging?API?Example?Host",??
  4. ?//path?必須是絕對路徑,指向要啟動的程序??
  5. ??"path":?"D:\\Work\\Chrome?plugin\\Native?Messaging?Example\\Demo\\native_cmd.bat",??
  6. ??"type":?"stdio",??
  7. ??"allowed_origins":?[??
  8. ????"chrome-extension://niekdnkneilndiimkikogmplndpcfknp/"??
  9. ??]??
  10. }??


native_cmd.bat
notepad.exe
我的注冊表導出的值(位置要注意下HEKY..):
Windows Registry Editor Version 5.00

[HKEY_CURRENT_USER\Software\Google\Chrome\NativeMessagingHosts\com.google.chrome.demo]
@="D:\\Work\\Chrome plugin\\Native Messaging Example\\Demo\\com.google.chrome.demo-win.json"

======================2016.2.15 補充=============================================

? 之前有博友私信我關于不能啟動的問題,這里是我疏忽了一個挺重要的步驟,就是權限問題。

在allowed_origins下的chrome-extension表示允許的插件。這串字母很重要,要和你安裝的ID一致。如下,這個插件為hnaekmhaniojodkaageacnjfldljhiek,那么相對于安裝的ID也是必須一致。

?

[javascript]?view plaincopy
在CODE上查看代碼片派生到我的代碼片
  1. "allowed_origins":?[??
  2. ???"chrome-extension://hnaekmhaniojodkaageacnjfldljhiek/"??
  3. ?]??

?

這里涉及了插件打包的問題,順便也提一下。

如下,選擇打包擴展程序,其中根目錄為插件所在位置,這樣打包后會生成兩個文件,一個pem密鑰文件,另一個為crx安裝程序。安裝后可以看到插件的ID,然后復制下來到填上,再將crx安裝程序刪除,重新來打包一次,但是這一次下面的私有密鑰文件要選擇剛剛生成的。這樣ID就對應了。

?

補充實現的由來:

這里對于當時我接到要寫一個chrome插件任務的時候,那時候首次接觸插件的時候,解決思路是先收集資料,然后確定采用Native Messaging方式來實現時,就查看相關文檔以及官方Demo,然后再研究迅雷的插件,看看迅雷是如何調用起來的(不是研究源碼,是看怎么關聯起來的,如注冊表),這個過程并不需要花多少時間,一周左右的時間。

轉載于:https://www.cnblogs.com/developer-ios/p/6057967.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/372037.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/372037.shtml
英文地址,請注明出處:http://en.pswp.cn/news/372037.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SpringMVC整合MongoDB

首先&#xff0c;在pom文件中新增spring-data-mongodb的依賴&#xff1a; <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-mongodb</artifactId> <version>1.8.1.RELEASE</version>&l…

單路電壓表c語言編程,用AT89C51單片機制作的數字電壓表

此數字電壓表&#xff0c;利用A/D轉換原理將被測模擬量轉換成數字量&#xff0c;并通過控制系統用數字方式顯示測量結果。本設計采用AT89C51單片機&#xff0c;ADC0809進行模/數轉換&#xff0c;能夠測量8路0&#xff5e;5V的輸入電壓值&#xff0c;可用四位LED數碼管輪流或單路…

ZK的實際應用:MVVM –加載和渲染數據

先前的文章簡要介紹了RIA框架ZK&#xff0c;以及它CSS Selector啟發式控制器機制如何通過使在控制器類中引用UI組件的任務變得相對靈活來減輕UI更改所帶來的一些負擔。 然后&#xff0c;我們在上一篇文章中探討了ZK中的MVVM模式如何允許單個ViewModel提供不同的視圖。 這篇文章…

搭建一個簡單的mybatis框架

一、Mybatis介紹 MyBatis是一個支持普通SQL查詢&#xff0c;存儲過程和高級映射的優秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數的手工設置以及對結果集的檢索封裝。MyBatis可以使用簡單的XML或注解用于配置和原始映射&#xff0c;將接口和Java的POJO&#xff08;Pla…

定時操作范例

1 package timetask.demo;2 3 import java.text.SimpleDateFormat;4 import java.util.Date;5 import java.util.Timer;6 import java.util.TimerTask;7 8 /*9 * time類 是一個線程實施&#xff0c;可以用來實現在某一個時間或者某一個時間段后安排某一個任務執行一次或者定期…

c語言空格符 r t,c語言中、\t \r \n 和空格什么意思

具體意思&#xff1a;都是轉義字符&#xff0c;空格就是單純的空格&#xff0c;輸入時可以輸入空格\t 跳格 \r 回車 \n 換行\\ 反斜杠 \a 警告 \b 退格 \f 換頁 \v 垂直跳格 \ddd ddd 是 1、2 或 3 位八進制數字。轉義字符串(Escap…

如何在運行時更改日志記錄級別

在運行時中更改日志記錄級別很重要&#xff0c;這主要在生產環境中非常重要&#xff0c;在生產環境中&#xff0c;您可能希望在有限的時間內進行調試日志記錄。 好了&#xff0c;更改根記錄器非常簡單–假設您有一個具有所需記錄級別的輸入參數&#xff0c;只需獲取根記錄器并…

擴展中國剩余定理

轉自&#xff1a;http://blog.csdn.net/clove_unique/article/details/54571216 對于兩個方程$x\equiv c_1\pmod {m_1}$$x\equiv c_2\pmod {m_2}$將其合并為一個方程&#xff0c;有解條件為$(m1,m2)|(c2-c1)$$m\frac{m1m2}{(m1,m2)}$$c(inv(\frac{m1}{(m1,m2)},\frac{m2}{(m1,m…

易語言添加ctrl c鍵,易語言操作快捷鍵匯總

以下是關于易語言的快捷鍵內容&#xff1a;預覽被設計窗口 CtrlEnter運行 F5終止運行 CtrlF5編譯 F7菜單編輯器 CtrlE即時幫助 F1在編輯窗口之間跳轉。按下 Ctrl 鍵后不放&#xff0c;然后反復按 Tab 鍵可以在目前所有的編輯窗口之間跳轉&#xff1b;按下 Ctrl 鍵后同時按下 Ta…

在代理類中引用動態代理

在Stackoverflow中有一個有趣的問題 &#xff0c;關于Spring Bean如何獲??得對由Spring創建的代理的引用以處理事務&#xff0c;Spring AOP&#xff0c;緩存&#xff0c;異步流等。需要對代理的引用&#xff0c;因為如果存在對自身的調用通過代理bean&#xff0c;此調用將完全…

Array的用法總結-swift

Araay是有序的數據集&#xff0c;在OC中分為不可變數組NSArray和可變數組NSMutableArray&#xff0c;在swift中只有常量和變量兩種類型&#xff0c;聲明成變量那就可以說明是可變的了&#xff01; 學習時的具體的用法總結成如下的代碼&#xff1a; //數組var arrInts [Int]()/…

Frame URl

http://www.zi-han.net/theme/hplus/?v4.1 http://webapplayers.com/inspinia_admin-v2.5/ http://baijunyao.com/article/67 轉載于:https://www.cnblogs.com/shijiaoyun/p/6065755.html

linux的i o模型,淺談Linux 網絡 I/O 模型簡介(圖文)

1、介紹Linux 的內核將所有外部設備都看做一個文件來操作(一切皆文件)&#xff0c;對一個文件的讀寫操作會調用內核提供的系統命令&#xff0c;返回一個file descriptor(fd&#xff0c;文件描述符)。而對一個socket的讀寫也會有響應的描述符&#xff0c;稱為socket fd(socket文…

handsontable 方法匯總

核心方法1.為handsontable添加鉤子方法 addHook(key,callback):key為鉤子方法名 例如&#xff1a;hot.addHook(beforeInit, myCallback); addHookOnce(key,callback)&#xff1a;添加只使用一次的方法&#xff0c;用完后自動刪除 例如&#xff1a;hot.addHookOnce(beforeInit, …

swing中JTable的使用方法

1 public static void main(String[] args) {2 3 Student s1 new Student("張三", "001", 0);4 Student s2 new Student("李四", "002", 1);5 Student s3 new Student("王五", "003",…

android仿高德地圖透明黑字,Android 仿高德地圖可拉伸的BottomSheet

原標題&#xff1a;Android 仿高德地圖可拉伸的BottomSheet2018安卓巴士開發者大會-上海站你一直期待的安卓技術盛宴即將登場&#xff01;前言最近項目中需要用到高德地圖搜索結果后的結果展示的可拉伸控件。而我看到這個效果圖&#xff0c;覺得這個就是一個slidingpanel&#…

Java EE 7中包含哪些JSR?

我開始填寫所有應該加入Java EE 7的Java規范請求的表。 由于平臺版本仍在確定中&#xff0c;因此某些細節很難確定。 完整的Java EE 7 EJB產品具有以下標準組件和API&#xff1a; 名稱 版 描述 JSR 網頁 輪廓 批處理 1.0 批量處理 352 Bean驗證 1.1 Bean驗證框…

[ Javascript ] JavaScript中的定時器(Timer) 是怎樣工作的!

作為入門者來說。了解JavaScript中timer的工作方式是非常重要的。通常它們的表現行為并非那么地直觀&#xff0c;而這是由于它們都處在一個單一線程中。讓我們先來看一看三個用來創建以及操作timer的函數。var id setTimeout(fn, delay); - 初始化一個單一的timer&#xff0c…

android dropbox anr分析,Android如何分析排查ANR

釋放雙眼&#xff0c;帶上耳機&#xff0c;聽聽看~&#xff01;在Android開發中&#xff0c;當程序發生異常時會拋出異常信息&#xff0c;先說下三種常見類型&#xff1a;列表內容KeyDispatchTimeout(谷歌default 5s&#xff0c;MTK平臺上是8s) –主要類型按鍵或觸摸事件在特定…

修改httpd默認端口號

Tomcat: vim /etc/httpd/conf/httpd.conf//別忘了service httpd restart Nginx: vim /etc/nginx/nginx.conf//完了之后service nginx restart 轉載于:https://www.cnblogs.com/bincoding/p/6067054.html