如果是托管的Dll或則com組件類,直接在項(xiàng)目上添加這個(gè)DLL的引用
成都創(chuàng)新互聯(lián)公司是一家專注于網(wǎng)站制作、網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),蘇家屯網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)10多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:蘇家屯等地區(qū)。蘇家屯做網(wǎng)站價(jià)格咨詢:13518219792
如果是非托管的,已API函數(shù)方式調(diào)用的DLL,使用DllImport方式申明DLL函數(shù)
不過(guò)一般這種情況是吧IP地址等配置信息寫(xiě)在配置文件里面,若XML,INI,應(yīng)用程序配置文件等方式
配置文件用戶可以直接打開(kāi)查看,連接字符串寫(xiě)在那里,數(shù)據(jù)庫(kù)就不安全了。
第一步,新建項(xiàng)目。
1
打開(kāi)vb.net,也就是打開(kāi)Microsoft visual studio 2010,第一次使用的時(shí)候設(shè)置為basic語(yǔ)言就行。新建項(xiàng)目--打開(kāi)excel。
2
新建成功。
END
第二步,添加引用。
1
“項(xiàng)目”--“添加引用”。
2
添加Microsoft Excel 14.0 Object Library。
END
第三步,添加打開(kāi)文件對(duì)話框工具。
1
工具箱--對(duì)話框--openfiledialog。
2
添加成功。
END
第四步,添加命令按鈕控件。
1
工具箱--公共控件--button。
在控件上右擊鼠標(biāo),進(jìn)入屬性設(shè)置。
2
text屬性設(shè)置為“打開(kāi)excel”。
3
name屬性也設(shè)置為“打開(kāi)excel”。
END
第五步,編寫(xiě)程序。
1
鼠標(biāo)雙擊命令按鈕,進(jìn)入編程界面,編寫(xiě)程序。
END
第六步,運(yùn)行程序。
1
鼠標(biāo)單擊啟動(dòng)調(diào)式圖標(biāo),程序開(kāi)始運(yùn)行。
2
單擊打開(kāi)excel命令按鈕,調(diào)用打開(kāi)文件對(duì)話框,選擇自己要打開(kāi)的excel文件。
END
第七步,保存程序。
第一次程序運(yùn)行完,關(guān)閉程序,出現(xiàn)關(guān)閉項(xiàng)目提示,選擇保存。
2
選好自己要保存的位置。
這是一個(gè)讀文件函數(shù)
Public Shared Function MFC_FSTextFileRead(ByVal FilePath_Name As String) As String
Try
If Dir(FilePath_Name) "" Then
Dim FileReader As System.IO.FileStream = System.IO.File.Open(FilePath_Name, System.IO.FileMode.Open)
Dim FileByte(FileReader.Length - 1) As Byte
FileReader.Read(FileByte, 0, FileReader.Length)
Dim MyEncoder As System.Text.Encoding = System.Text.Encoding.Default
MFC_FSTextFileRead = New String(MyEncoder.GetChars(FileByte))
FileReader.Close()
Else
Return ""
End If
Catch ex As Exception
Return ""
End Try
End Function
兩種方法
1.
Shell(""Explorer.exe", AppWinStyle.NormalFocus")
2.
Dim proc As New Process
proc.StartInfo.FileName="Explorer.exe"
proc.Start
方法2給予更多的控制,如結(jié)束進(jìn)程的方法Kill
DLL(動(dòng)態(tài)鏈接庫(kù))是一個(gè)很有用的東西,在開(kāi)發(fā)大項(xiàng)目的時(shí)候顯得非常重要,因?yàn)槎嗳撕献鏖_(kāi)發(fā)時(shí),可以給每個(gè)人分配一個(gè)任務(wù),用DLL完成,最后組合起來(lái),就不會(huì)出現(xiàn)互相沖突的問(wèn)題。這里給出最簡(jiǎn)單的DLL編寫(xiě)與調(diào)用的示例
首先,我們打開(kāi)VB.NET,選擇類庫(kù),名稱改為test
然后輸入以下代碼
Public?Class?test
Public?Function?test(ByVal?a?As?Long,?ByVal?b?As?Long)?As?Long
Return?a?+?b
End?Function
End?Class
保存后,生成DLL文件。
這就是最簡(jiǎn)單的一個(gè)DLL,下面是調(diào)用該DLL的示例
新建一個(gè)工程,單擊“項(xiàng)目” -- 添加引用
找到剛才生成的DLL,雙擊它
添加引用以后,似乎什么也沒(méi)發(fā)生,這時(shí)我們輸入以下代碼:
Imports test.test
這樣,就包含了該DLL的類。
然后我們定義一個(gè)類
Dim test As New test.test
這樣,就可以使用里面的函數(shù)了,下面是程序示例
Imports?test.test
Public?Class?Form1
Private?Sub?Form1_Load(ByVal?sender?As?System.Object,?ByVal?e?As?System.EventArgs)?Handles?MyBase.Load
Dim?test?As?New?test.test
MsgBox(test.test(1,?2))
End?Sub
End?Class
運(yùn)行該程序,可以看到,調(diào)用了DLL內(nèi)的函數(shù)。
這就是最簡(jiǎn)單的DLL示例,可以將一些復(fù)雜的代碼集成到DLL里,以后升級(jí)或重用都比較方便。
使用向?qū)гO(shè)置數(shù)據(jù)庫(kù)連接的好處是省去寫(xiě)代碼的過(guò)程,弊端是不易更改連接
使用代碼連接的好處是需要編寫(xiě)代碼,但容易更改和維護(hù)
如:數(shù)據(jù)庫(kù)的位置變化,直接更改代碼顯然容易一些
代碼:
imports System.data.oledb /*引用命名空間*/
dim cnstr = "provider=microsoft.jet.oledb.4.0,data source=Access數(shù)據(jù)庫(kù)文件位置" /*定義連接字符串*/
dim cn as oledbconnection = new oledbconnection(cnstr) /*定義連接*/
cn.open() /*打開(kāi)連接*/
sqlstr="select... from... 或其他sql"
dim cmd as sqlcommand=new sqlcommand()
cmd.commandtext=sqlstr
cmd.connection=cn
/*以上是建立執(zhí)行語(yǔ)句*/
cmd.executenonquery() 不返回結(jié)果
cmd.executescalar() 返回單個(gè)結(jié)果
cmd.executereader() 返回結(jié)果集
/*以上是執(zhí)行sql語(yǔ)句的方法*/
cn.close() /*關(guān)閉連接*/
你要做用戶驗(yàn)證的話,先根據(jù)用戶名查詢對(duì)應(yīng)的密碼,再判斷用戶輸入的密碼和查詢結(jié)果是不是相同就可以了
用cmd.executescalar() 這個(gè)方法