1. 程式人生 > >大華門禁SDK二次開發(一)

大華門禁SDK二次開發(一)

專案中需要能夠查詢門禁訊號和控制門禁裝置,因此需要基於大華門禁SDK進行二次開發,開發語言C#。門禁開發中遇到了一些問題,經過與大華技術的郵件溝通也一一解決。做這個開發的時候,發現網上的資料比較少,想著把自己遇到的問題整理下來,讓有需要的人儘量少走一些彎路。

1. 門禁狀態查詢/控制API

  • 門禁控制API
BOOL CLIENT_ControlDevice(
  LLONG                                   lLoginID ,
  CtrlType                                type ,
  void                                    *param ,
  int                                     waittime = 1000
);
  • 門禁查詢API
BOOL CLIENT_QueryDevState(
  LLONG  lLoginID,
  int    nType,
  char   *pBuf,
  int    nBufLen,
  int    *pRetLen,
  int    waittime=1000 
);


nType `NET_DOOR_STATUS_INFO`


//門禁狀態資訊
struct NET_DOOR_STATUS_INFO{
DWORD                         dwSize;
int                           nChannel;
EM_NET_DOOR_STATUS_TYPE       emStateType;
};


//門禁狀態型別
typedef enum __EM_NET_DOOR_STATUS_TYPE{ 
  EM_NET_DOOR_STATUS_UNKNOWN,                  
  EM_NET_DOOR_STATUS_OPEN,                     // 開啟
  EM_NET_DOOR_STATUS_CLOSE,                    // 關閉
  EM_NET_DOOR_STATUS_BREAK,                    // 門異常開啟};

2. 郵件列表

2.1 基於官網SDK開發

從大華官網下載SDK開發包,找到上面的兩個介面後,就開始操刀基於官方C# demo開發。裝置登陸程式碼是官方demo提供的,但是門禁裝置狀態查詢總是返回false。跟大華技術支援聯絡後,提供了新的門禁開發demo。

發件人: DK
傳送時間: 2017年9月27日 9:51
收件人: 大華SDK支援
主題: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

 

大華大神你好,

我是專案名稱平臺開發人員,在進行門禁除錯時遇到下面的問題,煩請幫忙診斷一下:

1、C#引入介面

[DllImport("dhnetsdk.dll")]
public static extern bool CLIENT_QueryDevState(IntPtr lLoginID,int nType,IntPtr pBuf,int nBufLen,ref int pRetLen,int waittime);

2、C#呼叫

public static bool QueryDevState(IntPtr lLoginID,ref NET_DOOR_STATUS_INFO statusInfo)
        {
            var pRetLen = 0;
            var nBufLen = Marshal.SizeOf(typeof(NET_DOOR_STATUS_INFO));

            IntPtr pBuf = IntPtr.Zero;
            pBuf = Marshal.AllocHGlobal(nBufLen);
            Marshal.StructureToPtr(statusInfo, pBuf, true);

            var result = OriginalSDK.CLIENT_QueryDevState(lLoginID, 0x0159, pBuf, nBufLen, ref pRetLen,1000);
            NetGetLastError(result);
            return result;
        }

3、呼叫結果:

result = false

error是一個不存在的錯誤編碼,一個很大的負數

 

**科技集團股份有限公司

            我打農村來

      187********

       2017-09-27

============================================================================================       
       
發件人: 大華SDK支援

傳送時間: 2017年9月27日(星期三) 上午10:12

收件人: DK

主題: 答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

 

請參照附件Demo進行門禁開發、封裝引用。

有問題反饋

裝置上下文環境:裝置型號、韌體版本

問題描述:截圖、操作步驟

 

我們再分析下。

附件Demo

2.2 基於新的門禁demo

這次跟上次出現的問題差不多,也是登陸正常,但是狀態查詢異常,這次又提供了新的門禁開發demo。

發件人: DK
傳送時間: 2017年9月27日 15:11
收件人: 大華SDK支援
主題: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

 

     

      你好,下午除錯了一下,有問題,詳細錯誤見附件,你幫忙看一下。

十分感謝。

 

------------------

**科技集團股份有限公司

            我打農村來

      187********

       2017-09-27
       
============================================================================================ 

發件人:大華SDK支援

傳送時間:2017年9月27日(星期三) 3:14

收件人:DK

主題:答覆: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

裝置型號、版本資訊再補充提供下。

============================================================================================ 

發件人:DK

傳送時間:2017年9月27日(星期三) 3:20

收件人:大華SDK支援

主題:回覆:答覆: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗 

裝置型號:DH-ASC1204B
 
軟體版本參考附件 

============================================================================================ 

發件人: 大華SDK支援

傳送時間: 2017年9月27日(星期三) 下午4:13

收件人: DK

主題: 轉發: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

 

附件是門禁C# Demo,供參閱。

1卡操作

2查詢記錄

3監聽事件、指紋抓取

 

看是否覆蓋業務,是否夠用?       

除錯問題文件

除錯問題程式碼

門禁C# Demo

image

2.3 針對版本的門禁demo

這次有進步,之前門禁狀態查詢一直返回的是無效的錯誤碼,這次找到了有效的錯誤碼-1。起初以為是Rec NO的問題,後來經電話溝通,確認是沒有複製大華的門禁相關dll到除錯輸出目錄下(debug)。把測試demo輸出目錄的所有dll拷貝到自己的除錯輸出目錄後,功能就正常了。

發件人:DK

傳送時間:2017年9月28日(星期四) 2:40

收件人:大華SDK支援

主題:回覆:轉發: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

你好,我今天試了下昨天發給我的demo:
1、登陸正常;
2、點選get按鈕,執行裝置查詢操作時,返回錯誤程式碼-1(未知錯誤)
 
    操作順序:點選get按鈕-》彈出彈出1(參見附件get按鈕彈出1)-》未填寫任何資訊,點選ok-》彈出錯誤資訊(參見報錯資訊2)
       
============================================================================================ 

發件人:大華SDK支援

時   間:2017年9月28日(星期四) 3:06

收件人:DK

主題:專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

這是查詢門禁卡的,要輸入Rec NO才行。

============================================================================================ 

發件人: DK
傳送時間: 2017年9月28日 15:42
收件人: 大華SDK支援
主題: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

你好,請問門禁卡的Rec NO如何獲取?

============================================================================================ 

發件人:大華SDK支援

時   間:2017年9月28日(星期四) 3:49

收件人:DK

主題:答覆: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

請注意接聽電話,我們打了兩遍您這邊都沒接

我打農村來187********

============================================================================================ 

發件人:DK

時   間:2017年9月28日(星期四) 4:52

收件人:大華SDK支援

主題:回覆:答覆: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗
 
你好,十分感謝,在您的指導下,已經除錯完畢。

get按鈕彈窗1

報錯資訊2

2.4 門禁控制結構體

這是個小問題,就是在開發門禁控制功能時,一個結構體找不到,原因是兩種語言下的命名方式不一致造成的。

發件人: DK
傳送時間: 2017年9月29日 11:13
收件人: 大華SDK支援
主題: 回覆:答覆: 回覆:答覆: 專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗

你好,

我在做門禁事件監聽時,查不到NET_ALARM_ACCESS_LOCK_STATUS_INFO這個結構體的構造,麻煩提供一下。

============================================================================================ 

發件人:大華SDK支援

時   間:2017年9月29日(星期五) 11:26

收件人:DK

主題:專案名稱-netsdk門禁-CLIENT_QueryDevState介面C#呼叫失敗 

C#命名規則都以NET開頭,和C++的可能不一致

去掉頭就能搜到了ALARM_ACCESS_LOCK_STATUS_INFO

2.5 門禁常開、常關

這個功能是後來發現的,現場的一些門是常開的,但是我在大華自己的門禁web系統裡看不到這種常開的狀態、包括我開發的門禁服務程式裡也區分不出來常開的情況。但是DH-ACS 100桌面軟體裡可以看到門是否常開,因此就想著肯定是有獲取門是否常開的介面。查詢文件和跟技術支援溝通,只得到了這個設定常開的介面。目前門是否處於常開狀態的訊號獲取未實現。

發件人:DK
傳送時間: 2018年4月25日 10:28
收件人: 大華SDK支援
主題: 專案名稱-netsdk門禁

 

你好,

 

      在現場發現了門有常開的狀態,想請問下如何查詢、控制門禁的常開、常閉狀態。
      
============================================================================================ 

  
發件人:大華SDK支援  
時   間:2018年4月25日(星期三) 5:16
收件人:DK
主題:答覆: 專案名稱-netsdk門禁

你好!

 

編譯執行附件demo,可以獲取設定門禁常開常閉狀態。

附件demo

門禁常開常關設定

3. 除錯問題

2.1 CLR20R3異常

門禁服務程式除錯完畢後,本地加入CLR連線、配置、類庫,並提升.NET版本後,在伺服器上執行直接崩潰。且無法進入除錯斷點,直接執行則報CLR20R3錯誤,無從入手。

經查,CLR20R3最好的解決辦法是檢視window日誌。

最終解決辦法,修改程式編譯版本為x86解決問題
參考地址)。

2.2. BEX64異常

調整編譯版本為x86,解決問題。

參考地址

2.3. 找不到dll

拷貝大華SDk資料夾下的庫檔案到Release或者debug目錄下即可。

3.4. 門開關機制

門禁控制邏輯是這樣的:收到開門命令後,觸發門鎖開門(發出開發訊息)並等待2-3秒,然後門會自動鎖上(發出關門訊息)。我理解常開有兩種情況:

  • 強制常開:門開啟後,一直阻擋門自動鎖上;
  • 設定常開:設定常開模式,門鎖開啟後,不在自動鎖上。