PythonAnywhere 上的 Django 项目可以运行但没有功能,尽管它在本地运行

Django project on PythonAnywhere works but no functionality, although it does locally

我刚刚在 PythonAnywhere 上部署了我的第一个站点,它是 Craigslist 的克隆,其搜索功能在本地按预期工作,但部署后我只能访问主页,然后我会收到两个不同的错误,具体取决于浏览器我试穿。欢迎在 http://matipule.eu.pythonanywhere.com/

亲自尝试

这是 Safari https://dpaste.com/3ZAJFC4PM

这是Chrome https://imgur.com/PjvLrao

Chrome 声称 CSRF 存在问题,但我已将令牌包含在表单中,如下所示,然后再一次,它实际上在本地有效,所以我一无所知。

这是令牌所在的代码。

<form action="{% url 'new_search' %}" method="post">
     {% csrf_token %}
     <input type="text" name="search" placeholder="search">
     <button class="btn waves-effect waves-light" type="submit" name="action">Submit
         <i class="material-icons right">send</i>
     </button>
 </form>

更新 使它起作用的是更新 2 中建议的公认答案。谢谢!

一般来说,搜索请求是使用 GET 方法执行的,您甚至不需要提及 method="GET",因为它是默认方法。此外,您的 form 中不需要 csrf_token,因为它是 GET 请求。

如果您进行了这些更改,应该会出现错误,但您会收到另一个错误:

IntegrityError at /new_search/
NOT NULL constraint failed: my_app_search.search

我不知道,但这似乎与你的数据库(sqlite3)逻辑有关

如果你分享一些代码我可以帮助你

更新

views.py

def new_search(request):
    # search = request.POST.get('search')
    search = request.GET.get('search')  # the value should be Not NULL and the 'IntegrityError' should go.

使用 GET 而不是 POST,因为搜索请求是通过 GET 方法执行的,您将避免出现 IntegrityError 错误。希望这能解决您的问题。

更新 2

除了上述更改外,我在 heroku 上部署了应用程序,在 settings.py

上几乎没有变化
..
ALLOWED_HOSTS = ['127.0.0.1', '.herokuapp.com']  # HERE
..

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    }
}

# HERE added these lines to override the default database config with postgress settings
import dj_database_url
db_from_env = dj_database_url.config(conn_max_age=500)
DATABASES['default'].update(db_from_env)

..

我运行这个命令

heroku addons:create heroku-postgresql:hobby-dev

heroku run python manage.py migrate

这就是我已经完成的所有工作。