Silverlight使用者無法註冊之MySql.Data.dll不一致

來源:互聯網
上載者:User

標籤:

本篇博文記錄本人解決一個"使用者無法註冊"的問題的過程

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不一致

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.