首页 > 解决方案 > PythonAnywhere 上的 Django 项目工作但没有功能,虽然它在本地

问题描述

我刚刚在 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中建议的公认答案。谢谢!

标签: pythondjangodeploymentpythonanywhere

解决方案


一般来说,搜索请求是使用GET方法执行的,您甚至不需要提及method="GET",因为它是默认方法。你也不需要csrf_token你的,form因为它是一个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.

请改用GETPOST因为搜索请求是通过方法执行的,您将从错误中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

这就是我已经做的。


推荐阅读