Raspkate - 基於.NET的可運行於樹莓派的輕量型Web服務器


最近在業余時間玩玩樹莓派,剛開始的時候在樹莓派里寫一些基於wiringPi庫的C語言程序來控制樹莓派的GPIO引腳,從而控制LED發光二極管的閃爍,后來覺得,是不是可以使用HTML5+jQuery等流行的前端技術做一個簡單的Web站點,讓樹莓派搭載這個站點,通過手機或者平板電腦來控制樹莓派。經過一番調研,考慮如下:

  • 使用Apache或者Nginx搭建一個Web服務器
    • 優點:服務器實現相對成熟
    • 缺點:偏重,而且與樹莓派的交互需要涉及Service調用,而實現RESTful服務對於Apache或者Nginx需要額外的組件支持,要付出一定的學習成本
  • 使用Python+Flesk
    • 優點:技術相對成熟,也有很多成功應用案例
    • 缺點:對於我來說需要額外學習Python語言

基於這樣的前提,鑒於目前Mono在Linux下的出色表現,想想還是自己使用.NET開發一個輕量型的Web服務器吧,第一期版本讓它既支持靜態文件的訪問服務,也支持RESTful API的調用,在RESTful API中可以暴露訪問樹莓派GPIO引腳的接口,供HTML5+jQuery的單頁面應用調用,於是也就實現了在任意設備上通過瀏覽器來控制樹莓派的目的。

Raspkate項目

Raspkate項目的名字,我想就是兩個方面:Rasp,它來源於樹莓派的英文名字Raspberry Pi,有表示“小、輕量”的意義,而Kate則寓意能夠充分發揮開發者的想象,對其進行擴展和定制。Raspkate就是這樣一款基於.NET Framework、由C#開發的輕量型Web服務器,它的核心部分是一個HttpListener對象,通過多線程模型將HTTP請求異步委托給HttpListener執行。當一個HTTP請求被接受的時候,Raspkate會根據請求的格式或類型,分配特定的模塊(Module)對請求進行處理,然后將處理結果返回。如果請求的是一個文件,那么Raspkate會返回文件的內容,如果是一個RESTful請求,則Raspkate會使用已經注冊的RESTful API控制器來處理這個請求,並將計算結果以JSON格式返回。

開源地址

Raspkate項目是開源的,代碼庫地址是:https://github.com/daxnet/raspkate,所使用的許可協議是GPL2.0,(因為其所使用的與樹莓派相關的組件是第三方的由GPL2.0授權的開源庫),因此,不能在商業環境中使用此項目。

應用場景

您可以在以下場景中使用Raspkate:

  1. 在自己的應用程序中實現內建的Web服務器(Self-Hosting)
  2. 將Raspkate寄宿在Windows Service中,向外提供RESTful服務
  3. 將Raspkate寄宿在Windows Service中,向外提供靜態Web頁面請求服務
  4. 將Raspkate作為樹莓派中的一個獨立的小型Web服務器,提供控制樹莓派GPIO的Web用戶界面

整體架構

下圖展示了Raspkate項目的整體架構設計:

ArchitectureOverview

可以看到,在Raspkate核心部分就是一個HTTP Listener組件,並且由Module和Configuration支撐Raspkate完成HTTP請求處理。每個模塊可以包含多個HTTP Handler,這在定義模塊的時候可以對多個HTTP Handler進行注冊。

Raspkate配置信息(也就是上圖中的Configuration)非常簡單,下圖就是這個配置信息的類型視圖,在RaspkateConfiguration對象上,設定了HttpListener所使用的Prefix,而Modules部分則指定了Raspkate掃描可用模塊的路徑,IsRelative指定模塊路徑是否是相對的。

image_thumb8

以下是一個標准的Raspkate配置文件:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="raspkateConfiguration" type="Raspkate.Config.RaspkateConfiguration, Raspkate"/>
  </configSections>

  <raspkateConfiguration xmlns="urn:Raspkate.Config" prefix="http://127.0.0.1:9023/">
    <modules>
      <add path="modules"/>
    </modules>
  </raspkateConfiguration>

</configuration>

代碼使用

首先,使用Git客戶端將代碼庫克隆到本地:

git clone https://github.com/daxnet/raspkate

然后,在裝有MSBuild的Windows機器上,執行build.bat命令:

  • build.bat All - 這將編譯所有模塊,並將模塊的二進制文件復制到modules目錄下
  • build.bat Minimal - 這僅編譯核心模塊(不包含類似樹莓派支持等擴展模塊)

如果是在裝有Mono的Linux機器上,則相應地執行build.sh即可。

在編譯完成之后,進入bin目錄,執行RaspkateService.exe即可(注意:如果是在樹莓派中執行,並且希望加載樹莓派支持模塊,則需要通過 sudo ./RaspkateService.exe 命令執行,以獲得root權限)。在成功啟動后,你應該看到類似下面的畫面:

image_thumb1

這時,打開瀏覽器,在瀏覽器中輸入http://127.0.0.1:9023,您應該可以看到類似以下的畫面:

image_thumb5

這表示您已經成功運行Raspkate服務,此頁面顯示了運行服務器相關的信息。注意:如果你希望你的Raspkate服務能夠在同網絡的其它機器訪問,請在執行RaspkateService.exe之前,將RaspkateService.exe.config文件中的Prefix設置修改為:http://+:9023/。但這樣做可能會牽涉到用戶訪問控制的問題,如果將Prefix改為該值后,出現Raspkate無法啟動的問題,請先在Command Line執行:

netsh http add urlacl url="http://+:9023/" user=everyone

演示

這里有幾張屏幕截圖,展示了Raspkate提供的相關功能。

獲取並顯示樹莓派信息

以下屏幕截取自我的手機瀏覽器,分別顯示了我的樹莓派系統信息、樹莓派主板信息以及樹莓派中所有引腳的名稱、類型和電平值列表。

Screenshot_2016-03-20-20-23-10_com.a[1]    Screenshot_2016-03-20-20-23-57_com.a    Screenshot_2016-03-20-20-24-22_com.a[2]

使用HTML5+jQuery控制發光二極管的點亮和熄滅狀態

前端是一個寄宿在Raspkate上的一個HTML5+jQuery的單頁面應用,后端是運行Raspkate的樹莓派。

image_thumb9    image_thumb10


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM