日韩精品中文字幕一区二区-日韩精品中文字幕一区-日韩精品中文字幕视频-日韩精品在线一区二区三区-第一页在线-第一福利视频

當前位置:首頁文章首頁 IT學院 IT技術

關于asp中connection對象封裝dll方法分享

作者:  來源:  發布時間:2011-7-8 16:03:05  點擊:

這篇文章將跟大家分享到關于asp中connection對象封裝dll解決方案,希望能給大家帶來幫助或啟發。

asp代碼保密一直是令人頭痛的問題,目前沒有非常好的解決方案,無非用vb編譯成dll,但工作量實在太大,于是一直苦苦尋求著另一種途徑。。。

  中午,突然靈感一發,“為什么不嘗試用加密數據庫?”,通過對數據庫設一個高強度的密碼,然后用vb封裝connection對像,將密碼信息寫在dll里,然后通過asp創建組件方式調用,就算人家拿了我的代碼,也無法改動數據庫!

  于是,開始了一步步既痛苦又刺激的旅程。vb三四年前用過,而且菜得不再菜,為了找思路,就上網搜,百度有時候也挺害人的,搜了一大堆誤人子弟的東東出來,特別是那個vb程序里只放一個連接字符串,然后用asp創建組件,取出字串,然后連接的思路,沒任何意思,一句respose.write 連接字串就出來。

  達到加密數據庫的目的,鏈接字串絕對是不能顯示的,所以我參考了龍卷風寫的"使用組件封裝數據庫操作(二)"中的方法,設定一個conn的全局變量,然后打開數據庫的函數返回的只有true跟false。更重要的一點就是封裝rs的execute方法,將其寫到dll里,具體操作如下:

  1.打開vb,創建一個activex dll工程,工程名稱叫myconn,類模塊是dbconn,然后寫入以下代碼:

Option Explicit
Dim rp As Response
Dim rq As Request
Dim ap As Application
Dim sr As Server
Dim sn As Session
Dim Conn As ADODB.Connection ''創建conn全局變量
Dim RS As ADODB.Recordset '' 創建全避變量rs

Public Sub OnStartPage(MyScriptingContext As ScriptingContext)
Set rp = MyScriptingContext.Response
Set rq = MyScriptingContext.Request
Set sr = MyScriptingContext.Server
Set ap = MyScriptingContext.Application
Set sn = MyScriptingContext.Session

End Sub

Public Sub OnEndPage()
Set rp = Nothing
Set rq = Nothing
Set sr = Nothing
Set ap = Nothing
Set sn = Nothing
End Sub

Public Function openConn()
Dim str As String
Set Conn = sr.CreateObject("ADODB.Connection")

str = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & sr.MapPath("/mssdatabase/dbtest.mdb") &";data password=123456789"
Conn.Open str
If Err.Number <> 0 Then ''就是在社里返回喔

openConn = False

Else

openConn = True

End If
End Function

Public Function execute(sql) As ADODB.Recordset ''創建一個execute的方法,返回為recordset對像
Set RS = New ADODB.Recordset
RS.CursorLocation = adUseClient

Call openConn ''這句得要加,好像在外部的asp中不能觸發全局conn變量,不知為此??

RS.Open sql, Conn, 3, 3
Set execute = RS
End Function

  編譯該工程時,切記引用(工程>引用)"Microsoft active server pages object library"和"microsoft activexX data object 2.6 library"兩個庫類(感覺像c#的using差不多一樣),然后編譯成dll(文件>生成myconn.dll),一般vb編譯成dll都會在系統中自動注冊,如果是ntsf分區,給該dll加個everyone 可讀,執行權限,然后到asp里調用,實現代碼如下:

<%
dim conn
dim dbLink

dbLink="2"

if dbLink="1" then ''如果代碼在別的機器上運行就使用dll組件鏈接數據庫,否則就使用本地鏈接
Set conn=Server.CreateObject("myconn.dbconn")
conn.openConn
else
set conn=Server.CreateObject("ADODB.CONNECTION")
DBPath = Server.MapPath("/mssdatabase/dbtest.mdb")

conn.open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="& DBPath
end if
%>

  由于兩種鏈接方式都只是使用了一個conn對像,所以不用對其他代碼進行大修改,還是比較方便,目前dll中的execute方法對select操作已經測試通過,還有insert、update、delete等方法有待完善。

  附件為myconn工程文件全部代碼:點擊這里下載源文件

相關軟件

相關文章

文章評論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
主站蜘蛛池模板: 人口高质量发展论文800字| 荒野求生21天美国原版免费播放| 相识韩国| 木乃伊5| 一人比划一人猜100个| 黑衣人| 孕妇入院待产包清单| 电影疯狂| 童宁的全部经典电影| 隐形人4| 喜羊羊开心闯龙年| 寡妇激情| 刘禹| 多尔衮电视剧全集40集| 许多组织都有自己的价值标准和行为理念 | 山口小夜子| 杨门女将一级裸片免费观看| 乡村女老师| 战长沙每个人的结局| 小学生数独入门100题| 男男性恋免费视频网站| 胎心监护多少周开始做| 稻森泉| 小数加减法100道题| 汤唯和梁朝伟拍戏原版视频| 电影《年龄差》| 央视7套| 电视剧《唐太宗李世民》| 日韩欧美电影网| 老江湖| 2018年党课主题及内容| 绿门背后| 性女贞德| 七年级下册语文读读写写拼音全部 | 我有一个好朋友作文二年级| 久久桃色视频| 日本电车系列| 少年科学俱乐部| 天河电影演员表| 挠丝袜| 一夜风流|