ubuontu16.04安裝Opencv庫引發的find_package()錯誤信息處理及其簡單使用

来源:https://www.cnblogs.com/newneul/archive/2018/01/27/8364924.html
-Advertisement-
Play Games

在安裝完Opencv庫之後,打算測試一下Opencv庫是否成功安裝。下麵是用的例子對應的.cpp代碼以及對應的CMakeLists.txt代碼: .cpp文件: CMakeLists.txt文件: 在工程目錄下新建併進入build目錄,然後輸入命令:cmake ..之後出現如下錯誤信息: 根據它的提 ...


  在安裝完Opencv庫之後,打算測試一下Opencv庫是否成功安裝。下麵是用的例子對應的.cpp代碼以及對應的CMakeLists.txt代碼:

.cpp文件:

 1 #include <stdio.h>
 2 #include <opencv2/opencv.hpp>
 3 using namespace cv;
 4 int main(int argc, char** argv )
 5 {
 6   if ( argc != 2 )
 7   {
 8     printf("usage: DisplayImage.out <Image_Path>\n");
 9     return -1;
10   }
11   Mat image;
12   image = imread( argv[1], 1 );
13   if ( !image.data )
14   {
15     printf("No image data \n");
16     return -1;
17   }
18   namedWindow("Display Image", WINDOW_AUTOSIZE );
19   imshow("Display Image", image);
20   waitKey(0);
21   return 0;
22 }

CMakeLists.txt文件:

1 cmake_minimum_required(VERSION 2.8)
2 project(DisplayImage)
3 find_package( Opencv  REQUIRED)
4 if(Opencv_FOUND)
5     message(STATUS "The Opecv lib is found!") 
6 endif()
7 add_executable( Display test.cpp)
8 arget_link_libraries( Display ${OpenCV_LIBS} ) 

在工程目錄下新建併進入build目錄,然後輸入命令:cmake ..
之後出現如下錯誤信息:

CMake Error at CMakeLists.txt:5 (find_package):
  By not providing "FindOpencv.cmake" in CMAKE_MODULE_PATH this project has
  asked CMake to find a package configuration file provided by "Opencv", but
  CMake did not find one.

  Could not find a package configuration file provided by "Opencv" with any
  of the following names:

    OpencvConfig.cmake
    opencv-config.cmake

  Add the installation prefix of "Opencv" to CMAKE_PREFIX_PATH or set
  "Opencv_DIR" to a directory containing one of the above files.  If "Opencv"
  provides a separate development package or SDK, be sure it has been
  installed.

  根據它的提示,發現cmake 沒有找到FindOpencv.cmake文件,之後嘗試去找OpencvConfig.cmake。 結果也沒有找到。這個就是我們解決問題的突破口。首先我在系統根目錄下嘗試搜索FindOpencv.cmake,也嘗試尋找OpencvCongfig.cmake 結果都沒有找到。實際上庫的作者都會提供這兩個文件,但是我按照Opencv官網上的安裝說明編譯安裝的Opencv庫。仍然沒有找到。具體原因還不太清楚。於是我在編譯好的Opecnv文件的build的目錄裡面找到了OpenCVConfig.cmake 在/usr/local/share/OpenCV這個目錄下同樣找到了OpenCVConfig.cmake文件。雖然找到了類似的文件,仍然沒有實質性的解決問題。於是我在網上搜索了關於find_package()命令的有關使用。下麵簡單介紹Cmake 如何使用find_package命令對外部庫進行查找。最後提出解決上面cmake ..出現問題的解決方案。
find_package使用簡介:
  首先明確一點,cmake本身不提供任何關於搜索庫的便捷方法,也不會對庫本身的環境變數進行設置。它僅僅是按照優先順序順序在指定的搜索路徑進行查找Findxxx.cmake文件和xxxConfig.cmake文件(其中xxx代表庫的名字,特別註意的是有大小寫之分),這兩個文件大體上是沒有區別的,cmake能夠找到這兩個文件中的任何一個,我們都能成功使用該庫,也就是我們可以用庫的內置好了Cmake變數。包含了庫的頭文件和庫文件的路徑信息,雖然庫的作者一般會提供這兩個文件,但是也會遇到安裝完畢後找不到的情況。當我們在cmake..命令之後,Cmake 會讀取執行CMakeLists.txt中的代碼,當執行find_package()這條命令後,Cmake 就會從某些路徑中找這Findxxx.cmake文件或者xxxConfig.cmake文件,Cmake找到任意一個之後就會執行這個文件,然後這個文件執行後就會設置好一些Cmake變數。比如下麵的變數(NAME表示庫的名字 比如可以用Opencv 代表Opencv庫):

<NAME>_FOUND
<NAME>_INCLUDE_DIRS or <NAME>_INCLUDES
<NAME>_LIBRARIES or <NAME>_LIBRARIES or <NAME>_LIBS
<NAME>_DEFINITIONS

一般常用的就是xxx_FOUND 、xxx_INCLUDE_DIRS、xxx_LIBS,分別代表是否找到庫的標誌、庫的頭文件路徑、庫文件路徑。find_package()有兩種模式:Module模式和Config模式,分別對應上面的Findxxx.cmake 和xxxConfig.cmake兩個文件。cmake預設優先Module模式,而Config模式是備選項。

Module模式(僅僅查找Findxxx.cmake文件):
Cmake會優先搜索CMAKE_MODULE_PATH指定的路徑,如果在CMakeLists.txt中沒有設置CMAKE_MODULE_PATH為存儲Findxxx.cmake的路徑,也就是說沒有下麵的指令:
set(CMAKE_MODULE_PATH "Findxxx.cmake文件所在的路徑")
那麼Cmake不會搜索CMAKE_MODULE_PATH指定的路徑,此時Cmake會搜索第二優先順序的路徑,也就是<CMAKE_ROOT>/share/cmake-x.y/Mdodules (註意:x.y表示版本號。我的是3.10)。其中CMAKE_ROOT是你在安裝Cmake的時候的系統路徑,因為我並沒有指定安裝路徑,所以是系統預設的路徑,在我的系統中(ubuntu16.04)系統的預設路徑是/usr/loacl,如果你在安裝的過程中使用了
cmake -DCMAKE_INSTALL_PREFIX=自己dir路徑 ,那麼此時CMAKE_ROOT就代表那個你寫入的路徑 。剛剛說道第一優先順序的路徑搜索沒有找到Findxxx.cmake文件,就會到第二優先順序的路徑下搜索。如果Cmake在兩個路徑下都沒有找到Findxxx.cmake文件。那麼Cmake就會進入Config模式。

Config模式(僅僅查找xxxConfig.cmake文件):
Cmake會優先搜索xxx_DIR 指定的路徑。如果在CMakeLists.txt中沒有設置這個cmake變數。也就是說沒有下麵的指令:
set(xxx_DIR "xxxConfig.cmkae文件所在的路徑")
那麼Cmake就不會搜索xxx_DIR指定的路徑,此時Cmake 就會自動到第二優先順序的路徑下搜索,也就是/usr/local/lib/cmake/xxx/中的xxxConfig.cmake文件。
上面主要講了Cmake的搜索模式。如果Cmake在兩種模式提供的路徑中沒有找到對應的Findxxx.cmake和xxxConfig.cmake文件,此時系統就會提示最上面的那些錯誤信息。

問題分析:
回顧一下上面的錯誤信息。根據提示以及上面的兩種模式的說明,可以發現我的CMakeLists.txt文件中沒有加入設置CMKAE_MODULE_PATH以及Opencv_DIR的命令,那麼也就是說Cmake執行find_package後,會自動到兩種預設的第二優先順序的搜索路徑下搜索Findxxx.cmake 和xxxConfig.cmake文件。雖然我在安裝Opencv的時候,是預設安裝系統目錄的,但是我在Moudule模式中的第二優先順序搜索路徑<CMAKE_ROOT>/share/cmake-x.y/Mdodules裡面沒有發現FindOpencv.cmake文件。然後我在Config模式中的第二優先順序搜索路徑/usr/loacl/lib/cmake/中也沒有發現Opencv文件夾,更沒有找到OpencvConfig.cmake文件了。而是僅僅看到了我之前在系統上安裝的Pangolin文件夾,裡面確實有對應的PangolinConfig.cmake文件。但是我在/usr/local/share/OpenCV/文件夾中找到了OpenCV.cmake文件。但不是最上面錯誤信息中提到的OpencvConfig.cmake文件。僅僅是大小寫不同。

解決方案:
(1)、我們可以忽略上面的錯誤信息,因為我們用find_package()查找庫的目的是,就是為了用include_directories()包含頭文件。用link_directories()包含庫文件。最後用target_link_libraries(可執行文件 庫)鏈接動態或者動態的庫,所以最簡單的方法就是自己在Opencv包的目錄下找到頭文件路徑和庫文件路徑。可以在CMakeLists.txt中設置如下指令:

1 set(Opencv_INCLUDE_DIRS "Opencv庫的頭文件目錄")
2 set(Opencv_LIBRARIES_DIRS "Opencv庫的庫文件目錄")
3 set(Opencv_LIBs "具體的鏈接庫文件.a  .so")
4 include_directories(${Opencv_INCLUDE_DIRS})
5 link_directories(${Opencv_LIBRARIES_DIRS})
6 target_link_libraries( <執行文件名字>   "${Opencv_LIBs} )

這裡有一點不好的地方就是指令的 "" 部分。前兩條指令還可以,我們只要寫下具體的文件路徑就行了。對於第三條指令。具體鏈接庫的文件 這個就很多了,而且很有可能我們寫入的不全,好的情況是我們沒有用那麼多的庫,所以簡單的程式可能正常編譯運行,但是當程式複雜的時候,所需要的庫就不是我們能夠考慮到的,我們就必須要把所有可能的庫都加入到這裡來,只要漏掉了工程需要的庫文件或者頭文件,都會導致程式編譯失敗。這是一個致命的缺點。當然對於我自己的情況,我的安裝包預設安裝到了系統目錄,也就是說我可以不添加頭文件和庫文件路徑,僅僅設置下一具體的鏈接庫文件 即以.so .a結尾的文件集。如果你安裝到了其他的地方,那麼就需要設置包含庫文件和頭文件的路徑。
"Opencv庫的頭文件目錄" 這個路徑的選擇有兩個。一個是安裝包的下的include目錄,一個是/usr/local/include
"Opencv庫的庫文件目錄" 這個路徑的選擇有兩個。一個是安裝包的build/bin,一個是/usr/local/lib
"具體的鏈接庫文件" 這個路徑的選擇有兩個。一個是安裝包的build/bin/所有庫文件名字,一個是/usr/local/lib下的所有庫文件名字 (註意:這個"具體的鏈接庫文件"怎麼能夠簡單的寫出來我還不太清楚,僅僅知道把所有文件寫出來,如果有人知道簡化寫,可以給我留言)

(2)、第一種方法雖然迴避了上面錯誤信息的發生,但是在後面也需要做很多的工作。每一步的工作不到位,都可能會導致編譯失敗。接下來的方法就是按照上面提示的信息尋找需要的FindOpencv.cmake和OpencvConfig.cmake文件。在問題分析裡面討論了,在我的cmake預設的搜索路徑中沒有包含上面的任何一個文件。僅僅在Opencv安裝包和/usr/local/share/OpenCV這兩個路徑下找到了OpenCV.cmake文件。接下來的操作有四種選擇(需要註意的是我的Opencv庫預設安裝到了系統目錄,所以在CMakeLists.txt沒有加入包含頭文件和庫文件的兩條指令。):
一、讓系統按照Module模式進行查找,也就是想辦法弄出一個FindOpencv.cmake文件,之後設置一下CMAKE_MODULE_PATH變數。下麵是具體操作:因為我們在所有目錄中沒有找到FindOpencv.cmake文件。只能找到OpenCVConfig.cmake文件。我們可以將這個文件名字更改為FindOpencv.cmake(更改方法有很多,如果沒有許可權可以滑鼠右鍵更改,如果有許可權那麼必須在命令行中sudo 進行更該)。然後在CMakeLists.txt中加入CMAKE_MODULE_PATH的路徑信息。因為OpenCVConfig.cmake文件出現的位置有兩個,一個是安轉包的build/下,一個是/usr/local/share/OpenCV/下。我選擇的是在安轉包的build/下麵直接滑鼠右鍵更改。更改完畢後在CMakeLists.txt中find_package命令前面加入下麵命令:
set(CMAKE_MODULE_PATH /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
最後的CMakeLists.txt中的命令如下:

1 cmake_minimum_required(VERSION 2.8)
2 project(DisplayImage)
3 set(CMAKE_MODULE_PATH  /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
4 find_package( Opencv  REQUIRED)
5 if(Opencv_FOUND)
6    message(STATUS "The Opecv lib is found!") 
7 endif()
8 add_executable( Display test.cpp)
9 target_link_libraries( Display ${OpenCV_LIBS} )

二、讓系統按照Config模式進行查找,想辦法弄出一個OpencvConfig.cmake文件,之後設置一下Opencv_DIR變數(這裡一定是Opencv_DIR 不能是OpenCV_DIR)。下麵是具體操作:因為我們在所有目錄中沒有找到OpencvConfig.cmake文件。只能找到OpenCVConfig.cmake文件。我們可以將這個文件名字更改為OpencvConfig.cmake(具體的更改方法參照上面)。然後在CMakeLists.txt中加入Opencv_DIR的路徑信息。因為OpenCVConfig.cmake文件出現的位置有兩個,一個是安轉包的build/下,一個是/usr/local/share/OpenCV/下。我選擇的是在安轉包的build/下麵直接滑鼠右鍵更改。更改完畢後在CMakeLists.txt中find_package命令前面加入下麵命令:
set(Opencv_DIR /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
最後的CMakeLists.txt中的命令如下:

1 cmake_minimum_required(VERSION 2.8)
2 project(DisplayImage)
3 set(Opencv_DIR  /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
4 find_package( Opencv  REQUIRED)
5 if(Opencv_FOUND)
6    message(STATUS "The Opecv lib is found!") 
7 endif()
8 add_executable( Display test.cpp)
9 target_link_libraries( Display ${OpenCV_LIBS} )

三、讓系統按照Module模式進行查找,將OpenCVConfig.cmake文件更改為FindOpenCV.cmake,之後設置一下CMAKE_MODULE_PATH路徑信息,之後在find_package的時候指定一個名字,比如:find_package(Opencv NAMES OpenCV REQUIRED )。此時find_package就會查找FindOpenCV.cmake文件,下麵是具體操作:因為我們在所有目錄中沒有找到FindOpencv.cmake文件。只能找到OpenCVConfig.cmake文件。我們可以將這個文件名字更改為FindOpenCV.cmake,然後在CMakeLists.txt中加入CMAKE_MODULE_PATH的路徑信息。因為OpenCVConfig.cmake文件出現的位置有兩個,一個是安轉包的build/下,一個是/usr/local/share/OpenCV/下。我選擇的是在安轉包的build/下麵直接滑鼠右鍵更改。更改完畢後在CMakeLists.txt中find_package命令前面加入下麵命令:
set(CMAKE_MODULE_PATH /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
並且修改find_package內容,具體命令如下:
find_package( Opencv NAMES OpenCV REQUIRED)
最後的CMakeLists.txt中的命令如下:

1 cmake_minimum_required(VERSION 2.8)
2 project(DisplayImage)
3 set(CMAKE_MODULE_PATH  /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
4 find_package( Opencv  NAMES OpenCV REQUIRED)#或者用find_package(OpenCV REQUIRED)
5 if(Opencv_FOUND)
6    message(STATUS "The Opecv lib is found!") 
7 endif()
8 add_executable( Display test.cpp)
9 target_link_libraries( Display ${OpenCV_LIBS} )

四、讓系統按照Config模式進行查找,設置一下Opecv_DIR路徑,之後在find_package的時候指定一個名字,比如:find_package(Opencv NAMES OpenCV REQUIRED )。或者顯示的指出用Config模式即
find_package(Opencv CONFIGS NAMES OpenCV REQUIRED),因為OpenCVConfig.cmake文件出現的位置有兩個,一個是安轉包的build/下,一個是/usr/local/share/OpenCV/下。我選擇的是在安轉包的build/路徑對Opencv_DIR設置。更改完畢後在CMakeLists.txt中find_package命令前面加入下麵命令:
set(Opencv_DIR /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
並且修改find_package內容,具體命令如下:
find_package( Opencv NAMES OpenCV REQUIRED)
最後的CMakeLists.txt中的命令如下:

1 cmake_minimum_required(VERSION 2.8)
2 project(DisplayImage)
3 set(Opencv_DIR  /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
4 find_package( Opencv  NAMES OpenCV REQUIRED)#或者用find_package(OpenCV REQUIRED)
5 if(Opencv_FOUND)
6    message(STATUS "The Opecv lib is found!") 
7 endif()
8 add_executable( Display test.cpp)
9 target_link_libraries( Display ${OpenCV_LIBS} )

總結:
你可以靈活的選擇上面的兩種方法中的任何一種,或者是第二中方法中的任何一種方式。任何一種寫法。實際上上面的過程中會有很多的細節,可以自己一一嘗試,看看輸出的內容到底是什麼。find_package具體用法可以參考cmake官方手冊。下麵將上面的四種方式寫的CMakeLists.txt,結合在一起進行對比(預設對應上面四種方式相應的更改了OpenCVCongfig.cmake文件):

 1 cmake_minimum_required(VERSION 2.8)
 2 project(DisplayImage)
 3 
 4 #設置Module模式路徑(想要使用的話前提要求有FindOpencv.cmake或者FindOpenCV.cmake,之後選擇對應的find_package模式,例如FindOpencv.cmake 對應find_package(Opencv REQUIRED),FindOpenCV.cmake對應find_package(Opencv NAMES OpenCV REQUIRED) )
 5 #set(CMAKE_MODULE_PATH  /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
 6 #設置Config模式路徑(想要使用的話,前提要有OpencvConfig.cmake或者OpenCVConfig.cmake,之後選擇對應的find_package模式,對應關係與Moudule模式同理,需要註意的一點是,我們也可直接顯示的使用Config模式,即Cmake不會按照Module模式進行查找。需要調用find_package(Opencv CONFIGS NAMES OpenCV REQUIRED)或者find_package(Opencv CONFIGS REQUIRED))
 7 set(Opencv_DIR  /home/gcj/Slam_Start/slam_directory/slam_packages/opencv-3.4.0/build)
 8 
 9 #對應FindOpenCV.cmake和OpenCVConfig.cmake
10 find_package( Opencv  NAMES OpenCV REQUIRED)#或者用find_package(OpenCV REQUIRED)
11 
12 #對應FindOpencv.camke和OpencvConfig.cmake
13 find_package( Opencv REQUIRED)
14 
15 if(Opencv_FOUND)
16    message(STATUS "The Opecv lib is found!") 
17 endif()
18 
19 #下麵兩個包含頭文件路徑的命令,可以選擇性的添加。因為我預設安裝到了系統目錄中,所以即使不添加下麵的命令,系統也能夠預設搜索到頭文件。如果你安裝這個庫到了其他地方,那麼下麵這句話就是必須的。
20 #添加包含頭文件的路徑
21 #include_directories(${OpenCV_INCLUCE_DIRS})
22 
23 #增加可執行文件
24 add_executable( Display test.cpp)
25 
26 #鏈接庫文件 這個命令是必須的。尤其是${OpenCV_LIBS}是在cmake找到對應的xxxConfig.cmake或者Findxxx.cmake後執行.cmake文件後定義的Cmake變數。註意OpenCV是大寫的,因為.cmake文件中僅僅定義了大寫的OpenCV_LIBS變數。所以在具體的寫其他庫的時候,要註意是大寫還是小寫,可以到相應的.cmake文件中查看。
27 target_link_libraries( Display ${OpenCV_LIBS} )

上面的理解可能不全面,更進一步的理解可以查閱下麵的參考資料,如果您有更好的理解,或者上面講解過程中有錯誤,希望您指出,謝謝!

參考資料:
1、http://blog.csdn.net/bytxl/article/details/50637277#t0
2、https://cmake.org/cmake/help/v3.10/command/find_package.html
3、https://stackoverflow.com/questions/8711109/could-not-find-module-findopencv-cmake-error-in-configuration-process


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言 大家好,我是Rector 又是星期五,很興奮,很高興,很high...啦啦啦。。。 Rector在圖享網又和大家見面啦!!!上一篇《 "一步一步創建ASP.NET MVC5程式\[Repository+Autofac+Automapper+SqlSugar\" ][1]》,我們完成了: Aut ...
  • 概述:LINQ又稱為語言集成查詢,是一種類似於SQL的一種查詢語言。語言集成查詢讓開發人員可以使用.NET程式語言(如C#)去查詢數據源,主要數據源為記憶體中的集合對象、ADO.NET數據集、資料庫以及XML,開發人員不用去分門別類地學習眾多的查詢語法就可以輕鬆地查詢異構數據源。 三種表現形式:複合查 ...
  • 回到目錄 因為docker上的大部分鏡像都是基於linux系統的,所以在向圖像中寫中文時需要考慮中文字體問題,例如在microsoft/aspnetcore2.0這個鏡像,它是基於debian系統的,它上面只有一個英文字體,所以在輸出中文時會出現亂碼,這是正常的,我們的解決方案也需要按著以下步驟即可 ...
  • 此處引用csdn博客。鏈接如下、 http://blog.csdn.net/cp1300/article/details/7773239 http://blog.csdn.net/aobai219/article/details/6092292 我們在寫程式的時候,總是或多或少會加入一些printf ...
  • 在Linux0.11中,進程的切換是基於intel提供的TSS機制的,要從一個進程切換到別的進程,就是切換TSS這個結構。但是,這樣的切換方式效率太低,所以後來Linux和Windows都改成採用基於內核棧來切換這種方式。由於TSS機制比較簡單,所以大部分精力用於講解基於內核棧機制。 以下的基於內核 ...
  • 我們按照Tiny210官方的裸板程式來梳理S5PV210的中斷體系。 關於 S5PV210 的中斷體繫結構 S5PV210 的中斷控制器是由 4 個向量中斷控制器(VIC)、 ARM PrimeCell PL192 和 4 個 TrustZone Interrupt Controller (TZIC ...
  • 項目名:基於linux下的高性能負載均衡聊天伺服器。 2018 年 1 月 15 日開始做這個項目,現在是1 月 27 號 已經把基礎功能先大概實現了,由於是我的第一個項目,接下來會好好記錄一下。後續會往裡面陸續地加入東西,以及壓力測試等,同時也是為3月的春招做準備。 首先需要使用socket編程, ...
  • MySQL慢日誌? MySQL的慢查詢日誌是MySQL提供的一種日誌記錄,它用來記錄在MySQL中響應時間超過閥值的語句,具體指運行時間超過long_query_time值的SQL,則會被記錄到慢查詢日誌中。long_query_time的預設值為10,意思是運行10s以上的語句。 預設情況下,My ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...