MySQL的ODBC接口實現是通過安裝MyODBC驅動,這個驅動程序是跨平台的。如果在Linux等unix體系操作系統下使用,需要先安裝iodbc這些第三方ODBC標准支援平台。
簡單的ASP示例代碼:
<%
dim sql,mysql
set sql = server.createobject("adodb.connection")
mysql="driver={mysql odbc 3.51 driver};database=庫;server=主機;uid=用戶;password
=密碼;" 'option = 設置
sql.open mysql
%>
上邊這段代碼是采用MyODBC開發版3.51連接的示例,使用開發版是因為一些新的特性和穩定性2.x正式版所不具備的。前幾天看了篇微軟安全專家所撰寫的如何編寫安全程序的教程。上邊提到如果按照上邊示例的方法一旦ASP文件的代碼被駭客看到,那麼數據庫可能不保,然後引發一連串的問題,甚至被奪得管理權限。文章中順便提到了解決方法,是通過編寫com組件,然後由ASP調用組件的方法連接數據庫。這麼做的好處是提高了安全性,但是問題是有能力這麼做的人畢竟是少數。那麼我的折衷方案是定義數據源。將庫、用戶、密碼以及設置這些連接信息統統在數據源中定義,從很大程度簡單化了實現的難度,而且也起到增強安全性的作用。當然,為了保證數據源可以在實際運作環境中被訪問到,一定要定義為“系統數據源”,開發時定義為“用戶數據源”或者“系統數據源”我倒覺得無傷大雅。
使用數據源的ASP示例代碼
<%
dim sql
set sql = server.createobject("adodb.connection")
sql.open "dns=MySQL數據源名稱"
%>