我正在尝试配置ArrestDB为我的站点创建一个api
https://github.com/alixaxel/ArrestDB
正如安装中所说,我需要将$dsn更改为:MySQL:
$dsn = 'mysql://[user[:pass]@]host[:port]/db/;
目前我有
$dsn = 'mysql://user:password@localhost/database/';
我用上面的括号尝试过,但这导致了503服务不可用的错误。当我删除括号时,会导致以下错误:
{
"error": {
"code": 400,
"status": "Bad Request"
}
}
你知道我做错了什么吗?在我看来一切都是正确的
编辑:
尝试了下面的建议,api返回:
array(28) {
["REDIRECT_STATUS"]=> string(3) "200"
["HTTP_HOST"]=> string(16) "api.shopsavr.com"
["HTTP_CONNECTION"]=> string(10) "keep-alive"
["HTTP_ACCEPT"]=> string(74) "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8"
["HTTP_USER_AGENT"]=> string(109) "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/30.0.1599.101 Safari/537.36"
["HTTP_ACCEPT_ENCODING"]=> string(17) "gzip,deflate,sdch"
["HTTP_ACCEPT_LANGUAGE"]=> string(14) "en-US,en;q=0.8"
["PATH"]=> string(209) "/usr/local/jdk/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/lib/courier-imap/sbin:/usr/lib/courier-imap/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin:/usr/X11R6/bin:/root/bin"
["SERVER_SIGNATURE"]=> string(0) ""
["SERVER_SOFTWARE"]=> string(136) "Apache/2.2.25 (Unix) mod_ssl/2.2.25 OpenSSL/0.9.8e-fips-rhel5 mod_auth_passthrough/2.1 mod_bwlimited/1.4 FrontPage/5.0.2.2635 PHP/5.4.20"
["SERVER_NAME"]=> string(16) "api.shopsavr.com"
["SERVER_ADDR"]=> string(11) "50.28.7.250"
["SERVER_PORT"]=> string(2) "80"
["REMOTE_ADDR"]=> string(12) "67.247.5.220"
["DOCUMENT_ROOT"]=> string(30) "/home/shopsavr/public_html/api"
["SERVER_ADMIN"]=> string(26) "webmaster@api.shopsavr.com"
["SCRIPT_FILENAME"]=> string(40) "/home/shopsavr/public_html/api/index.php"
["REMOTE_PORT"]=> string(5) "58487"
["REDIRECT_URL"]=> string(8) "/PRODUCT"
["GATEWAY_INTERFACE"]=> string(7) "CGI/1.1"
["SERVER_PROTOCOL"]=> string(8) "HTTP/1.1"
["REQUEST_METHOD"]=> string(3) "GET"
["QUERY_STRING"]=> string(0) ""
["REQUEST_URI"]=> string(8) "/PRODUCT"
["SCRIPT_NAME"]=> string(10) "/index.php"
["PHP_SELF"]=> string(10) "/index.php"
["REQUEST_TIME_FLOAT"]=> float(1383666718.92)
["REQUEST_TIME"]=> int(1383666718)
}
http://localhost/ArrestDB/index.php/[table]
非常适合我
不要在dns上加括号…仍在研究如何发布。。。。
问题
根据您的代码和转储信息,ArrestDB没有收到您的完整请求。$_SERVER['REQUEST_URI']
的内容是"/"
,这意味着.htaccess
文件中可能有问题,应该捕获任何地址并将其引导到ArrestDB PHP文件。
背景信息
通常,4XX
范围内的HTTP响应代码表示错误的请求。通常,5XX
范围内的HTTP响应代码表示错误。
如果发生其他错误(错误的SQL参数、服务器超时等(,ArrestDB将返回4XX
错误代码(不是400,而是另一个4XX错误(。如果数据库连接以任何方式"坏",ArrestDB将以5XX
错误代码(特别是503(进行响应。
推理
由于它以400作为错误代码进行响应,这意味着它无法提供"特定"错误代码(400表示"未知类型的坏连接"(。
可能的修复
首先,为了证实我的理论,我建议你去掉我要求你放的var_dump + exit
,代之写$_SERVER['REQUEST_URI'] = "/products";
。这应该会迫使ArrestDB认为它需要列出products
表。在确认一切正常后,当我们使用此破解时,我们将尝试解决您的.htaccess
问题。
如果你没有.htaccess文件,你需要放完整的URL才能工作,就像这样:http://localhost/ArrestDB/index.php/[table]