ASP 与 MySql 的经典连接无效
ASP classic connection to MySql not working
我被迫在使用经典 ASP (VBScript) 和 MS 访问数据库的远程 windows 服务器上移动一个已经 运行 多年的旧网站。
新的托管公司 (123-reg) 在他们的 Windows 服务器上不支持 MS Access,所以我现在使用 MySQL。我在其他网站上成功使用了 MySQL,但总是使用 PHP 而不是经典的 ASP,所以我以前从未从 ASP 连接到 MySQL 数据库。
该网站有数百页,我希望我所要做的只是更改连接字符串。但是我现在收到 500 错误
80004005|[Microsoft] ODBC_Driver_Manager]_Data_source_name_not_found_and_no_default_driver_specified
这让我很困惑。
我试过了
set Conn=server.createobject("ADODB.CONNECTION")
set rs = server.createobject("ADODB.Recordset")
conn.open "DRIVER={MySQL ODBC 3.51 Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;"
我也试过:
conn.open "DRIVER={SQL Server};SERVER=" & servername & "\SQLEXPRESS;DATABASE=" & database & ";UID=" & username & ";PWD=" & pword"
读完 后出现类似的问题:
conn.open "DRIVER={MySQL ODBC 5.1 Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;charset=utf8;"
仍然出现同样的错误。
我在 Internet 和这个网站上搜索过,但每当我找到信息时,它都假定我使用的是我自己的服务器,而我不是。页面:https://support.microsoft.com/en-gb/kb/306345建议我修改服务器注册表,我当然做不到,而且无论如何我都很难接受一个123-reg这么大的公司还要改他们服务器上的东西允许我连接到数据库。
因此我得出结论,我的连接编码有问题(可能是一些简单的问题)。
我确实提出了 123-reg 的票,但他们告诉我这是一个编码问题,他们没有帮助解决这个问题,这强化了我的理论。
对于这方面的任何帮助,我将不胜感激。我现在确实打算在 PHP 中重新编写网站,我知道我可以让它很好地工作,但由于有数百页要编码,这将花费我几个月的时间,我正在寻找一个快速修复在 PHP.
中重写整个网站时,使用当前页面让网站重新上线
非常感谢
托格
更新:1 月 11 日
123-reg 回复我说 ODBC 版本是 5.1.8。我已经更改了连接字符串,但仍然出现 500 错误,即:
HTTP/1.1 500 Internal Server Error Cache-Control: private
Content-Length: 250 Content-Type: text/html Server: Microsoft-IIS/7.5
Set-Cookie: ASPSESSIONIDCCQSTSCA=FLAJJCCDFENAOEMMCGFGNPCF; path=/
X-Powered-By: ASP.NET Date: Wed, 11 Jan 2017 14:46:07 GMT Connection:
close An error occurred on the server when processing the URL
没有行号,也没有错误描述。
我写了一个简单的页面来测试连接,我的完整代码是:
<%@ Language=VBScript %>
<%
option explicit
Response.Buffer = true
'=============================
'database connection variables
dim servername, username, pword, database
servername = "cust-mysql-123-19" 'The name of the Server
username = "atourist" 'The username for the database
pword = "redacted for this post" 'The password for the database
database = "atourist" 'The database to use
'============================
dim rs
dim strSQL
dim conn
dim ds
dim county
dim numrec
county="Grampian"
%>
<html>
<head>
<title>Test Page</title>]
</head>
<body>
<%
' connect to database and retrieve recordset
set conn=server.createobject("ADODB.CONNECTION")
set rs = server.createobject("ADODB.Recordset")
strSQL = "select * from ukgh where county='" & county & "' ORDER by random ASC"
conn.open "DRIVER={MySQL ODBC 5.1.8. Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;"
set rs = conn.Execute(strSQL)
'===============================
ds=rs.GetRows()
rs.close
conn.close
set rs = nothing
set conn = nothing
'display records
for Numrec =LBound(ds, 2) To UBound(ds, 2)
response.write DS(1, numrec) & ", " & DS(2, numrec) & "<br />"
Next
%>
</body>
</html>
<%
response.end
%>
如果您的主机是 x64 机器,请尝试 x64 connection strings 与 Provider=MSDASQL
和 MySQL ODBC 5.2w Driver
(不确定您是否应该在“5.1.8”中提及“8.”)。 - “5.1”或“5.2w”应该没问题)。如果没有帮助 - 检查 123-reg 是否为数据库提供 DSN(您使用 DSN-less 连接)或尝试连接数据库的 IP。
我只在连接字符串 5.3 中添加 Unicode Driver
,问题已解决
改变这个:
Conn.Open "DRIVER={MySQL ODBC 5.3 };SERVER=localhost; DATABASE=psa; UID=admin;PASSWORD=mypassword;Port=8306; OPTION=3"
收件人:
Conn.Open "DRIVER={MySQL ODBC 5.3 **Unicode Driver**};SERVER=localhost; DATABASE=psa; UID=admin;PASSWORD=mypassword;Port=8306; OPTION=3"
此致
我被迫在使用经典 ASP (VBScript) 和 MS 访问数据库的远程 windows 服务器上移动一个已经 运行 多年的旧网站。
新的托管公司 (123-reg) 在他们的 Windows 服务器上不支持 MS Access,所以我现在使用 MySQL。我在其他网站上成功使用了 MySQL,但总是使用 PHP 而不是经典的 ASP,所以我以前从未从 ASP 连接到 MySQL 数据库。
该网站有数百页,我希望我所要做的只是更改连接字符串。但是我现在收到 500 错误
80004005|[Microsoft] ODBC_Driver_Manager]_Data_source_name_not_found_and_no_default_driver_specified
这让我很困惑。
我试过了
set Conn=server.createobject("ADODB.CONNECTION")
set rs = server.createobject("ADODB.Recordset")
conn.open "DRIVER={MySQL ODBC 3.51 Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;"
我也试过:
conn.open "DRIVER={SQL Server};SERVER=" & servername & "\SQLEXPRESS;DATABASE=" & database & ";UID=" & username & ";PWD=" & pword"
读完
conn.open "DRIVER={MySQL ODBC 5.1 Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;charset=utf8;"
仍然出现同样的错误。
我在 Internet 和这个网站上搜索过,但每当我找到信息时,它都假定我使用的是我自己的服务器,而我不是。页面:https://support.microsoft.com/en-gb/kb/306345建议我修改服务器注册表,我当然做不到,而且无论如何我都很难接受一个123-reg这么大的公司还要改他们服务器上的东西允许我连接到数据库。
因此我得出结论,我的连接编码有问题(可能是一些简单的问题)。
我确实提出了 123-reg 的票,但他们告诉我这是一个编码问题,他们没有帮助解决这个问题,这强化了我的理论。
对于这方面的任何帮助,我将不胜感激。我现在确实打算在 PHP 中重新编写网站,我知道我可以让它很好地工作,但由于有数百页要编码,这将花费我几个月的时间,我正在寻找一个快速修复在 PHP.
中重写整个网站时,使用当前页面让网站重新上线非常感谢
托格
更新:1 月 11 日 123-reg 回复我说 ODBC 版本是 5.1.8。我已经更改了连接字符串,但仍然出现 500 错误,即:
HTTP/1.1 500 Internal Server Error Cache-Control: private Content-Length: 250 Content-Type: text/html Server: Microsoft-IIS/7.5 Set-Cookie: ASPSESSIONIDCCQSTSCA=FLAJJCCDFENAOEMMCGFGNPCF; path=/ X-Powered-By: ASP.NET Date: Wed, 11 Jan 2017 14:46:07 GMT Connection: close An error occurred on the server when processing the URL
没有行号,也没有错误描述。
我写了一个简单的页面来测试连接,我的完整代码是:
<%@ Language=VBScript %>
<%
option explicit
Response.Buffer = true
'=============================
'database connection variables
dim servername, username, pword, database
servername = "cust-mysql-123-19" 'The name of the Server
username = "atourist" 'The username for the database
pword = "redacted for this post" 'The password for the database
database = "atourist" 'The database to use
'============================
dim rs
dim strSQL
dim conn
dim ds
dim county
dim numrec
county="Grampian"
%>
<html>
<head>
<title>Test Page</title>]
</head>
<body>
<%
' connect to database and retrieve recordset
set conn=server.createobject("ADODB.CONNECTION")
set rs = server.createobject("ADODB.Recordset")
strSQL = "select * from ukgh where county='" & county & "' ORDER by random ASC"
conn.open "DRIVER={MySQL ODBC 5.1.8. Driver}; SERVER=" & servername & "; DATABASE=" & database & "; UID=" & username & ";PASSWORD=" & pword & "; OPTION=3;"
set rs = conn.Execute(strSQL)
'===============================
ds=rs.GetRows()
rs.close
conn.close
set rs = nothing
set conn = nothing
'display records
for Numrec =LBound(ds, 2) To UBound(ds, 2)
response.write DS(1, numrec) & ", " & DS(2, numrec) & "<br />"
Next
%>
</body>
</html>
<%
response.end
%>
如果您的主机是 x64 机器,请尝试 x64 connection strings 与 Provider=MSDASQL
和 MySQL ODBC 5.2w Driver
(不确定您是否应该在“5.1.8”中提及“8.”)。 - “5.1”或“5.2w”应该没问题)。如果没有帮助 - 检查 123-reg 是否为数据库提供 DSN(您使用 DSN-less 连接)或尝试连接数据库的 IP。
我只在连接字符串 5.3 中添加 Unicode Driver
,问题已解决
改变这个:
Conn.Open "DRIVER={MySQL ODBC 5.3 };SERVER=localhost; DATABASE=psa; UID=admin;PASSWORD=mypassword;Port=8306; OPTION=3"
收件人:
Conn.Open "DRIVER={MySQL ODBC 5.3 **Unicode Driver**};SERVER=localhost; DATABASE=psa; UID=admin;PASSWORD=mypassword;Port=8306; OPTION=3"
此致