標籤:
本篇博文記錄本人解決一個"使用者無法註冊"的問題的過程
1 問題描述:
使用者可以刪除;但不能註冊,也不能修改許可權:
圖 1使用者註冊失敗
圖 2修改使用者權限出錯
2 解決過程
1)粗暴方法:直接替換正確的工程
我將一個正確的Access和DataService 工程替換掉原來出錯的Access和DataService,依然出錯。甚至,我將UserManage和DataAccessSilverlight兩個工程一起替換,依然不起作用。
圖 3被替換掉的幾個工程(這幾個工程與使用者管理相關)
2)修改連接埠號碼
鄙人曾經使用新的連接埠號碼發布DataService工程,也同樣不起作用:
圖 4建立新的連接埠號碼
3)替換資料庫
我甚至想到,有可能是資料庫出現了問題,所以我連資料庫也重新替換一個正確的,問題依然存在
4)使用測試資料在DataService內調試
上面提到的三種方法都是治標不治本。最根本的方法還是要調試服務本身。
我曾經想到用IE的開發人員工具可以捕獲請求和回應的過程,但我無法理解其中的具體過程,而且也看不出問題。所以這條路也行不通。
最終還是要到DataService工程下調試。
首先需要看一下註冊使用者的網頁函數定義:
圖 5註冊使用者函數
這個函數的參數的類型是一個自訂的類,而不是基礎資料型別 (Elementary Data Type),所以無法使用參數調試。如:
圖 6註冊使用者函數的調用
為瞭解決這個問題,我們可以寫一個測試函數:
圖 7測試函數
?
通過跟蹤測試函數,發現問題出在這裡:cmd無法轉化為MySqlCommand,cmd轉化之後為null
圖 8問題錯在:cmd無法轉化為MySqlCommand
我恍然大悟,應該是MySql.Data.dll的版本號碼問題。後來檢查,發現這個工程下面引用了
C:\Program Files (x86)\MySQL\Connector.NET 6.9\Assemblies\v4.0
這個路徑下的MySql.Data.dll,其版本資訊為:
圖 9預設庫版本資訊
而正確的版本是:
圖 10目標庫版本資訊
找到問題的原因之後,重新找到目標庫,重新引用,即可以解決問題。
Silverlight使用者無法註冊之MySql.Data.dll不一致