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
这就是我已经完成的所有工作。
我刚刚在 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
这就是我已经完成的所有工作。