0

上个月我使用 OpenCart v1.5.5.1 并且有几十个订单顺利通过。

今天突然,我在访问 www.domain.com/shop/* 时收到 HTTP 错误 500,但 www.domain.com 工作正常。到目前为止,我尝试无济于事:

  • 重新启动服务器
  • 清除 /logs/error.txt
  • 删除 .htaccess

日志中的最后一个错误是:

2013-03-17 19:10:11 - PHP Notice:  Error: Table 'shop_db.geo' doesn't exist<br />Error No: 1146<br />SELECT g.id,g.full_name,g.name,g.postcode,z.zone_id,z.country_id FROM geo g LEFT JOIN zone z ON g.zone_id = z.zone_id WHERE g.name LIKE '99%' AND g.postcode <> '' ORDER BY population DESC LIMIT 12 in /var/www/domain.com/html/shop/system/database/mysql.php on line 50
2013-03-17 19:10:11 - PHP Notice:  Error: Table 'shop_db.geo' doesn't exist<br />Error No: 1146<br />SELECT g.id,g.full_name,g.name,g.postcode,z.zone_id,z.country_id FROM geo g LEFT JOIN zone z ON g.zone_id = z.zone_id WHERE g.name LIKE '990%' AND g.postcode <> '' ORDER BY population DESC LIMIT 12 in /var/www/domain.com/html/shop/system/database/mysql.php on line 50

这是.htaccess

# 1.To use URL Alias you need to be running apache with mod_rewrite enabled. 

# 2. In your opencart directory rename htaccess.txt to .htaccess.

# For any support issues please visit: http://www.opencart.com

Options +FollowSymlinks

# Prevent Directoy listing 
Options -Indexes

# Prevent Direct Access to files
<FilesMatch "\.(tpl|ini|log)">
 Order deny,allow
 Deny from all
</FilesMatch>

# SEO URL Settings
RewriteEngine On
# If your opencart installation does not run on the main web folder make sure you folder it does run in ie. / becomes /shop/ 

RewriteBase /
RewriteRule ^sitemap.xml$ index.php?route=feed/google_sitemap [L]
RewriteRule ^googlebase.xml$ index.php?route=feed/google_base [L]
RewriteRule ^download/(.*) /index.php?route=error/not_found [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_URI} !.*\.(ico|gif|jpg|jpeg|png|js|css)
RewriteRule ^([^?]*) index.php?_route_=$1 [L,QSA]

### Additional Settings that may need to be enabled for some servers 
### Uncomment the commands by removing the # sign in front of it.
### If you get an "Internal Server Error 500" after enabling any of the following settings, restore the # as this means your host doesn't allow that.

# 1. If your cart only allows you to add one item at a time, it is possible register_globals is on. This may work to disable it:
# php_flag register_globals off

# 2. If your cart has magic quotes enabled, This may work to disable it:
# php_flag magic_quotes_gpc Off

    # 3. Set max upload file size. Most hosts will limit this and not allow it to be overridden but you can try
    # php_value upload_max_filesize 999M

    # 4. set max post size. uncomment this line if you have a lot of product options or are getting errors where forms are not saving all fields
    # php_value post_max_size 999M

    # 5. set max time script can take. uncomment this line if you have a lot of product options or are getting errors where forms are not saving all fields
    # php_value max_execution_time 200

    # 6. set max time for input to be recieved. Uncomment this line if you have a lot of product options or are getting errors where forms are not saving all fields
    # php_value max_input_time 200

    # 7. disable open_basedir limitations
    # php_admin_value open_basedir none

    # 8. force the administration log-in screen to always load in HTTPS
    #RewriteEngine On
    #RewriteCond %{HTTPS} off
    #RewriteRule (.*) https://www.overair.ca/shop/admin/ [R]

和 php.ini

magic_quotes_gpc = Off;
register_globals = Off;
default_charset = UTF-8;
memory_limit = 64M;
max_execution_time = 36000;
upload_max_filesize = 999M;
safe_mode = Off;
mysql.connect_timeout = 20;
session.use_cookies = On;
session.use_trans_sid = Off;
session.gc_maxlifetime = 172800;
allow_url_fopen = on;
;display_errors = 1;
;error_reporting = E_ALL;

但是,我注意到他们过去几天一直在附近,没有任何问题。在我从备份恢复并丢失几个订单之前,我希望有人能提供帮助。

感谢您的时间!

4

1 回答 1

0

错误编号 1146 表示它正在尝试连接的表不在数据库中,您可能需要检查数据库并查看表是否存在并检查 config.php。希望你能找出问题所在!!!

于 2013-03-20T06:31:26.450 回答