mysql - 与 MySql 的 ASP 经典连接不起作用

标签 mysql asp-classic

我被迫移动一个使用经典 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"

阅读后this previous answer类似的问题:

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=MSDASQLMySQL ODBC 5.2w 驱动程序(不确定您是否应该在“5.1.8”中提及“8.” - “5.1”或“5.2w” “应该没事)。如果没有帮助 - 检查 123-reg 是否为数据库提供 DSN(您使用无 DSN 连接)或尝试连接数据库的 IP。

为确保这是一个 asp 问题,请尝试从测试 php 脚本(示例 [1][2])进行连接。

关于mysql - 与 MySql 的 ASP 经典连接不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41548675/

相关文章:

php - 信用点 Web 应用程序

linux - mono 是否支持经典 ASP?

mysql - POW() 还是 POWER() 更好?

php - 如何在条件之后返回一个值

sql-server - 记录到文件还是数据库更好?

asp.net - 来自经典 ASP 或 ASP.NET 的 Microsoft Search Server 2008 Express Edition

javascript - 只有 Internet Explorer 给出错误 : 'document.getElementById(...)' is null or not an object

iis-7 - 重写规则以重写所有 EXCEPT 文件扩展名

php - 来自 phpMyAdmin 的跟踪报告的 MySQL 表

MYSQL 如何将一列与另一列的计数连接作为 DB 的输出