gpt4 book ai didi

python - 使用 Django 和 Python 插入数据库时​​出现错误

转载 作者:太空宇宙 更新时间:2023-11-03 15:04:52 25 4
gpt4 key购买 nike

我在使用 Django 和 Python 将数据保存到数据库时遇到一个错误。错误如下。

Error :

Traceback (most recent call last):
File "/usr/local/lib/python2.7/dist-packages/django/core/handlers/exception.py", line 41, in inner
response = get_response(request)
File "/usr/local/lib/python2.7/dist-packages/django/core/handlers/base.py", line 187, in _get_response
response = self.process_exception_by_middleware(e, request)
File "/usr/local/lib/python2.7/dist-packages/django/core/handlers/base.py", line 185, in _get_response
response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/opt/lampp/htdocs/d30/carClinic_vulnerable/bookingservice/views.py", line 153, in signsave
passw.save()
File "/usr/local/lib/python2.7/dist-packages/django/db/models/base.py", line 806, in save
force_update=force_update, update_fields=update_fields)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/base.py", line 836, in save_base
updated = self._save_table(raw, cls, force_insert, force_update, using, update_fields)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/base.py", line 922, in _save_table
result = self._do_insert(cls._base_manager, using, fields, update_pk, raw)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/base.py", line 961, in _do_insert
using=using, raw=raw)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/manager.py", line 85, in manager_method
return getattr(self.get_queryset(), name)(*args, **kwargs)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/query.py", line 1063, in _insert
return query.get_compiler(using=using).execute_sql(return_id)
File "/usr/local/lib/python2.7/dist-packages/django/db/models/sql/compiler.py", line 1099, in execute_sql
cursor.execute(sql, params)
File "/usr/local/lib/python2.7/dist-packages/django/db/backends/utils.py", line 84, in execute
sql = self.db.ops.last_executed_query(self.cursor, sql, params)
File "/usr/local/lib/python2.7/dist-packages/django/db/backends/sqlite3/operations.py", line 135, in last_executed_query
params = self._quote_params_for_last_executed_query(params)
File "/usr/local/lib/python2.7/dist-packages/django/db/backends/sqlite3/operations.py", line 124, in _quote_params_for_last_executed_query
return cursor.execute(sql, params).fetchone()
ProgrammingError: You must not use 8-bit bytestrings unless you use a text_factory that can interpret 8-bit bytestrings (like text_factory = str). It is highly recommended that you instead just switch your application to Unicode strings.

我在下面解释我的模型文件。

class User(models.Model):
"""docstring for User"""

uname = models.CharField(max_length=200)
password = models.CharField(max_length=200)
date = models.DateTimeField(default=datetime.now, blank=True)
raw_password = models.CharField(max_length=200,blank=True, null=True)

以下是要保存到数据库中的数据。

if request.method == 'POST':
name = request.POST.get('uname')
password = request.POST.get('pass')
sec_pass = password
con_password = request.POST.get('conpass')
length = 16 - (len(password) % 16)
password += chr(length)*length
obj = AES.new('this is a carkey', AES.MODE_CBC, 'This is an IV456')
enpass = obj.encrypt(password)
if sec_pass == con_password:
passw = User(
uname=name,
password=enpass,
raw_password=password,
)
passw.save()
return render(request, 'bookingservice/login.html', {})

当我加密数据并尝试保存到数据库时,出现上述错误。请帮助我解决此错误。

最佳答案

可能是this answer会对你有帮助。

或者您可以使用 base64 将编码后的密码编码为字符串:

import base64
# your code before if statement is here
b64enpass = base64.b64encode(enpass)
if sec_pass == con_password:
passw = User(
uname=name,
password=b64enpass,
raw_password=password,
)
passw.save()

但是当然,在这种情况下,您必须在从数据库接收到 User 对象后解码密码。

关于python - 使用 Django 和 Python 插入数据库时​​出现错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44762031/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com