• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Benjamin

            靜以修身,儉以養德,非澹薄無以明志,非寧靜無以致遠。
            隨筆 - 397, 文章 - 0, 評論 - 196, 引用 - 0
            數據加載中……

            編譯MQTT C++ Client

            MQTT(Message Queuing Telemetry Transport,消息隊列遙測傳輸)是IBM開發的即時通訊協議,有可能成為物聯網的重要組成部分。
            該協議支持所有平臺,幾乎可以把所有聯網物品和外部連接起來,被用來當做傳感器和制動器(比如通過Twitter讓房屋聯網)的通信協議。

            MQTT協議是為大量計算能力有限,且工作在低帶寬、不可靠的網絡的遠程傳感器和控制設備通訊而設計的協議,它具有以下主要特性:
            1、使用發布/訂閱消息模式,提供一對多的消息發布,解除應用程序耦合;
            2、對負載內容屏蔽的消息傳輸;
            3、使用 TCP/IP 提供網絡連接;
            4、有三種消息發布服務質量:
              • “至多一次”,消息發布完全依賴底層 TCP/IP 網絡。會發生消息丟失或重復。這一級別可用于如下情況,環境傳感器數據,丟失一次讀記錄無所謂,因為不久后還會有第二次發送。
              • “至少一次”,確保消息到達,但消息重復可能會發生。
              • “只有一次”,確保消息到達一次。這一級別可用于如下情況,在計費系統中,消息重復或丟失會導致不正確的結果。
            5、小型傳輸,開銷很小(固定長度的頭部是 2 字節),協議交換最小化,以降低網絡流量;
            6、使用 Last Will 和 Testament 特性通知有關各方客戶端異常中斷的機制;

            編譯環境 win10專業版+vs2017企業版
            1、安裝cmake,https://cmake.org/download/,直接下載安裝包(msi)

            2、安裝ActivePerl軟件,https://www.activestate.com/activeperl/downloads.用cmd命令行的形式輸入指令進入到安裝目錄,比如安裝在C:\Perl64\下,進入到C:\Perl64\eg目錄,輸入“perl example.pl”, 如果出現如下圖所示的:"Hello from         ActivePerl!",則表示軟件安裝成功。安裝時自動設置環境變量

            3、安裝openssl,https://www.openssl.org/,解壓縮文件。開始菜單-->Vistual Studio 2017-->x64 Native Tools Command Prompt for VS 2017,進入vs2017的命令行行提示工具,切換到openssl的解壓縮目錄,依次執行下面命令行
                perl Configure VC-WIN64 no-asm --prefix=C:\openssl(C:\openssl是openssl的安裝目錄)
                            no-asm,表示不使用匯編,如果你不加上的話,在執行nmake命令時會出錯;命令執行后控制臺上輸出NOTE: If in doubt, on Unix-ish systems use './config',則表示執行命令失敗()
                            如果這條命令執行不成,試試這個命令perl Configure VC-WIN64A --perfix=C:\openssl\win64 (還是其存儲路徑),這里使用的是VC-WIN64A這個參數
                ms\do_nasm 
                ms\do_win64a
               nmake  -f  ms\nt.mak(這是靜態庫,動態庫是ntdll.mak)
               nmake  -f  ms\nt.mak test(測試命令,如果成功則最后顯示“passed all tests”字樣)
               nmake  -f  ms\nt.mak install 成功則會在C:\openss\win64目錄下生成bin、include、lib、ssl四個文件夾
               如果需要編譯動態庫,nmake  -f  ms\nt.mak改成動態庫版本就可以了。
               清除上次OpenSSL動態庫的編譯,以便重新編譯:nmake -f ms\ntdll.mak clean
             清除上次OpenSSL靜態庫的編譯,以便重新編譯:nmake -f ms\nt.mak clean
               
               備注:利用openssl生成RSA公私密鑰對。
               在Windows環境下,打開OPENSSL安裝目錄bin文件下面的openssl.exe。
               生成RSA私鑰:genrsa -out rsa_private_key.pem 1024
               該命令會生成1024位的私鑰
               生成RSA公鑰:rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem此時,我們可以看到一個文件名為rsa_public_key.pem的文件,打開它,
              可以看到-----BEGIN PUBLIC KEY-----開頭,-----END PUBLIC KEY-----結尾的沒有換行的字符串,這個就是公鑰
               把RSA私鑰轉換成PKCS8格式:pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM –nocrypt
               生成的結果就是PKCS8格式的私鑰

            4、安裝cppunit(cpp單元測試件)下載地址:http://downloads.sourceforge.net/cppunit/cppunit-1.12.1.tar.gz,如果不需要測試可以省略這一步。一般我們編譯cppunit_dll工程,同時產生lib和dll文件
               里面有vc6的工程文件,用vs2017打開,升級工程后,編譯容易出現MSB3073的錯誤,編譯完成后,copy的時候提示找不到文件。需要做如下修改

            (1)General\TargetName中,$(ProjectName)-->$(ProjectName)d,而cppunit_dll工程比較特殊,它需要在cppunitd_dll中間加"d",沒辦法使用$(ProjectName),可直接寫為cppunitd_dll

            (2)Linker\General\Output Files中,DebugDll\cppunit_dll.dll-->DebugDll\$(TargetName)$(TargetExt)

            (3)Linker\Advanced\Import Libraries中,.\DebugDll\cppunit_dll.lib-->.\DebugDll\$(TargetName).lib

            (4)PostBuild Event\Command Line中:改為:

                   copy "$(TargetPath)" ..\..\lib\$(TargetName)$(TargetExt)

                   copy "$(TargetDir)$(TargetName).lib" ..\..\lib\$(TargetName).lib

            5、官網c++Mqtt Client 地址https://github.com/eclipse/paho.mqtt.cpp
               使用git下載git clone https://github.com/eclipse/paho.mqtt.cpp,進入剛剛下載的paho.mqtt.cpp文件中,將mqtt的c的源碼包下載下來git clone https://github.com/eclipse/paho.mqtt.c.git
               新版的mqtt文件夾里沒有sln文件,用cmake-gui生成sln文件,而后用vs2017打開編譯,openssl路徑;或者執行paho.mqtt.c文件夾下的cbuild批處理文件(git下來的是vs2015配置,vs2017則是
               "D:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Auxiliary\Build\vcvars64.bat",具體的路徑請根據自己安裝配置),這里如果是批處理的話openssl的安裝目錄必須是c:\OpenSSL-Win64;
               cmake-gui,Configure選用Visual Studio 15 2017 Win64,Generate后,可以選定OPENSSL_LIB OPENSSL_INCLUDE_DIR OEPENSSLCRYPTO_LIB的路徑。

               使用cmake-gui,產生sln文件,在一次General之后可以選定PAHO_MQTT_C_LIB和PAHO_MQTT_C_PAHT和openssl相關路徑。然后打開工程編譯就可以。
               如果不行產生ZERO_CHECK,在CMakelist文件中加入SET(CMAKE_SUPPRESS_REGENERATION 1)
               原來的CMakeLists文件比較龐雜,這是精簡后的phot.mqtt.c/src/CMakeList
               phot.mqtt.c下的CMakeList:phot.mqtt.c/CMakeLists(下載完成后修改成文件名為CMakeList),去除了ZERO_CHECK、INSTALL、  PACKAGE三個工程文件。
               
               

                

               

                

            posted on 2019-01-18 13:06 Benjamin 閱讀(5475) 評論(0)  編輯 收藏 引用 所屬分類: VC

            精品久久久久久久无码| 久久久无码精品亚洲日韩京东传媒| 狠狠综合久久AV一区二区三区| 国产精品99久久久精品无码| 久久亚洲精品成人AV| 99久久免费国产精品| 日本精品久久久久久久久免费| 伊人久久久AV老熟妇色| 久久久久久久综合日本亚洲 | 精品久久久久久无码中文字幕一区| 久久伊人精品青青草原高清| 亚洲美日韩Av中文字幕无码久久久妻妇| 久久综合亚洲色一区二区三区| 久久国产精品-国产精品| 国内精品久久久久影院亚洲| 久久精品无码一区二区三区| 伊人久久大香线蕉av不卡| 久久精品一区二区影院| 狠狠色丁香婷综合久久| 久久久久国产精品嫩草影院| 久久国产成人午夜aⅴ影院| 99久久777色| 无码专区久久综合久中文字幕| 性做久久久久久久久久久| 欧美精品一区二区精品久久| 久久精品国产亚洲av日韩| 久久久久亚洲精品日久生情 | 久久99亚洲综合精品首页| 久久精品国产亚洲精品2020| 亚洲中文久久精品无码ww16| 伊人色综合久久天天人守人婷| 国产精品无码久久综合网| 日本三级久久网| 国产免费福利体检区久久| 国产精品丝袜久久久久久不卡| 亚洲成色999久久网站| 成人久久综合网| 久久精品www| 久久久久人妻一区精品| 色诱久久av| 久久精品国产男包|