質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
Visual Studio Code

Visual Studio Codeとは、Microsoft社が開発したマルチプラットフォーム対応のテキストエディタです。Visual Studioファミリーの一員でもあります。拡張性とカスタマイズ性が高く、テキストエディタでありながら、IDEと遜色ない機能を備えることができます。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

解決済

【Django】django.db.utils.DataError: (1406, "Data too long for column 'password' at row 1")のエラーが解決できない

kakeru0225
kakeru0225

総合スコア35

Visual Studio Code

Visual Studio Codeとは、Microsoft社が開発したマルチプラットフォーム対応のテキストエディタです。Visual Studioファミリーの一員でもあります。拡張性とカスタマイズ性が高く、テキストエディタでありながら、IDEと遜色ない機能を備えることができます。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

1回答

0評価

0クリップ

153閲覧

投稿2022/06/26 06:45

私自身初学者であり質問も初めてのため、必須情報の過不足があるかもしれませんが、下記内容についてご教示頂けますと幸いです。


<エラーについて>
【概要】
DjangoでWebアプリケーションを開発中(ユーザー登録フォームを作成しており、フォームへのCSSの適用方法やパスワードのValidationに取り組んでいる時にDBを何度か削除→作成していたところその過程でスーパーユーザーを作成できなくなってしまいました)。
スーパーユーザー作成時に、下記のエラーが出てしまいスーパーユーザーを作成することができない。

【詳細】

python

django.db.utils.DataError: (1406, "Data too long for column 'password' at row 1")

<お伺いしたいこと>
上記エラーの解決方法

<現状の理解>
①passwordフィールドにおけるmax_length以上の文字数を入力している可能性
→max_length=20で設定していることから、①によるエラーではない

python

password = models.CharField(_("password"), max_length=20, unique=True)

②/adminにアクセスは可能(ログインはもちろんできない)
③データベースへのユーザー情報の保存処理も正常に動作(Mysqlで確認するとフォームからのデータの送信と保存も正常に行われている)

<不明点>
models.pyが原因なのか、そのほかの要素が起因してエラーを起こしているのかが分からず、ご教示頂けますと幸いです。


<ソースコード>
models.py

models.py

from django.db import models from django.contrib.auth.models import PermissionsMixin from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager from django.core.mail import send_mail from django.utils import timezone from django.contrib.auth.validators import UnicodeUsernameValidator from django.utils.translation import gettext_lazy as _ class UserManager(BaseUserManager): use_in_migrations = True def _create_user(self, username, email, password, **extra_fields): if not email: raise ValueError('Emailを入力して下さい') email = self.normalize_email(email) username = self.model.normalize_username(username) user = self.model(username=username, email=email, **extra_fields) user.set_password(password) user.save(using=self.db) return user def create_user(self, username, email, password=None, **extra_fields): extra_fields.setdefault('is_staff', False) extra_fields.setdefault('is_superuser', False) return self._create_user(email, password, **extra_fields) def create_superuser(self, username, email, password, **extra_fields): extra_fields.setdefault('is_staff', True) extra_fields.setdefault('is_superuser', True) if extra_fields.get('is_staff') is not True: raise ValueError('is_staff=Trueである必要があります。') if extra_fields.get('is_superuser') is not True: raise ValueError('is_superuser=Trueである必要があります。') return self._create_user(username, email, password, **extra_fields) class CustomUser(AbstractBaseUser, PermissionsMixin): username_validator = UnicodeUsernameValidator() username = models.CharField(_("username"), max_length=50, validators=[username_validator], blank=True) email = models.EmailField(_("email_address"), unique=True) password = models.CharField(_("password"), max_length=20, unique=True) password1 = models.CharField(_("password1"), max_length=20, unique=True) is_staff = models.BooleanField(_("staff status"), default=False) is_active = models.BooleanField(_("active"), default=True) date_joined = models.DateTimeField(_("date joined"), default=timezone.now) objects = UserManager() USERNAME_FIELD = "email" EMAIL_FIELD = "email" REQUIRED_FIELDS = ['username']

forms.py

forms.py

from django import forms from toppage.models import CustomUser from django.core.exceptions import ValidationError class SignUpForm(forms.ModelForm): #password = forms.CharField(max_length=20, widget=forms.PasswordInput()) class Meta: model = CustomUser fields = ['username', 'email', 'password', 'password1'] #labels = {'username':"ユーザー名",'email':"メールアドレス",'password':"パスワード"} def clean_password(self): password = self.cleaned_data['password'] password1 = self.data.get('password1') if password != password1: raise ValidationError('パスワードが一致しません。') return password

admin.py

admin.py

from django.contrib import admin from django.contrib.auth.admin import UserAdmin from django.contrib.auth.forms import UserChangeForm, UserCreationForm from django.utils.translation import gettext_lazy as _ from .models import CustomUser """ class MyUserChangeForm(UserChangeForm): class Meta: model = CustomUser fields = '__all__' class MyUserCreationForm(UserCreationForm): class Meta: model = CustomUser fields = ('email','username') """ class MyUserAdmin(UserAdmin): fieldsets = ( (None, {'fields': ('email', 'password', 'password1' 'username')}), (_('Permissions'), {'fields': ('is_active', 'is_staff', 'is_superuser', 'groups', 'user_permissions')}), (_('Important dates'), {'fields': ('last_login', 'date_joined')}), ) add_fieldsets = ( (None, { 'classes': ('wide',), 'fields': ('email', 'password', 'password1'), }), ) """ form = MyUserChangeForm add_form = MyUserCreationForm """ list_display = ('email', 'username', 'password', 'is_staff') list_filter = ('is_staff', 'is_superuser', 'is_active', 'groups') search_fields = ('email', 'username') ordering = ('email', 'username',) admin.site.register(CustomUser, MyUserAdmin)

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

Visual Studio Code

Visual Studio Codeとは、Microsoft社が開発したマルチプラットフォーム対応のテキストエディタです。Visual Studioファミリーの一員でもあります。拡張性とカスタマイズ性が高く、テキストエディタでありながら、IDEと遜色ない機能を備えることができます。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。