ホームページ バックエンド開発 Python チュートリアル DRFシリアナーがパラメーターを取得できない場合はどうすればよいですか?

DRFシリアナーがパラメーターを取得できない場合はどうすればよいですか?

Apr 01, 2025 pm 08:12 PM
red

DRFシリアナーがパラメーターを取得できない場合はどうすればよいですか?

Django Rest Framework(DRF)Solution Solult for Selializerでグローバル検証パラメーターを取得できない

Serializerグローバル検証にDRFを使用する場合、 validateメソッドが予想されるパラメーターを取得できない場合があり、この記事では原因を分析してソリューションを提供します。

質問の説明:

LoginViewで、 LoginSerializerを使用してログインします。ユーザーが存在しない場合、 LoginSerializerデータ検証を実行しますが、 validateメソッドはcodemobileパラメーターを取得できません。

コード例:

loginview:

 serializer_obj = loginserializer(data = request.data)
ログイン後にコピー

loginserializer:

クラスLoginserializer(Serializers.Serializer):
    code = serializers.charfield(write_only = true、max_length = 255、必須= true)
    Mobile = serializers.Charfield(max_length = 11、min_length = 11、必須= true)
    #...他のフィールド...
ログイン後にコピー

問題の原因:

request.dataにはすべてのリクエストデータが含まれていますが、 LoginSerializer(data=request.data)データソースとしてのみ使用し、検証に参加するフィールドを指定しません。 attrs validateメソッドの辞書にはrequest.data Serializerが実際に処理するフィールドのみが含まれています。

解決:

LoginSerializerインスタンスを作成する前に、必要なパラメーターをrequest.dataから明示的に抽出し、辞書としてシリアナーに渡します。

 code = request.data.get( 'code')
Mobile = request.data.get( 'Mobile')
login_type = request.data.get( 'login_type')

serializer_obj = loginserializer(data = {
    「コード」:コード、
    「モバイル」:モバイル、
    'login_type':login_type
})
ログイン後にコピー

このようにして、 validateメソッドは、 attrscodemobilelogin_typeパラメーターに正しくアクセスして、グローバル検証を完全にアクセスできます。

重要なヒント:

request.datacodemobilelogin_typeキーが存在するかどうかを必ず確認してください。それが存在しない場合、 request.data.get() None返されるため、エラーが発生する可能性があります。判断するためにヌル値を追加することをお勧めします:

 code = request.data.get( 'code')
Mobile = request.data.get( 'Mobile')
login_type = request.data.get( 'login_type')

コードがなしまたはモバイルの場合、またはlogin_typeがなしである場合:
    #エラーメッセージ返信応答の返却など、パラメーターが欠落している状況を処理します({"エラー": "欠落パラメーター"}、status = status.http_400_bad_request)

serializer_obj = loginserializer(data = {
    「コード」:コード、
    「モバイル」:モバイル、
    'login_type':login_type
})
ログイン後にコピー

上記の変更により、 validateメソッドがパラメーターを正しく取得し、DRFシリアイザーのグローバル検証機能を実現できるようにします。

以上がDRFシリアナーがパラメーターを取得できない場合はどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

HDFSでCentosを構成するために必要な手順 HDFSでCentosを構成するために必要な手順 Apr 14, 2025 pm 06:42 PM

CENTOSシステムにHadoop分散ファイルシステム(HDFS)を構築するには、複数のステップが必要です。この記事では、簡単な構成ガイドを提供します。 1.初期段階でJDKをインストールする準備:すべてのノードにJavadevelopmentKit(JDK)をインストールすると、バージョンはHadoopと互換性がある必要があります。インストールパッケージは、Oracleの公式Webサイトからダウンロードできます。環境変数構成: /etc /プロファイルファイルを編集し、JavaおよびHadoop環境変数を設定して、システムがJDKとHadoopのインストールパスを見つけることができるようにします。 2。セキュリティ構成:SSHパスワードなしログインSSHキーを生成する:各ノードでSSH-KeyGenコマンドを使用する

スロークエリログを設定する方法Centos Redis スロークエリログを設定する方法Centos Redis Apr 14, 2025 pm 04:54 PM

CENTOSシステムのRedisスロークエリログを有効にして、パフォーマンスの診断効率を改善します。次の手順では、構成をガイドします。ステップ1:最初にRedis構成ファイルを見つけて編集し、通常は/etc/redis/redis.confにあるRedis構成ファイルを見つけます。次のコマンドで構成ファイルを開きます:sudovi/etc/redis/redis.confステップ2:構成ファイルでスロークエリログパラメーターを調整し、次のパラメーターを見つけて変更します:#slow query-log-log-slower-slower-than10000#スロークエリのエントリの最大数

Redisキャッシュソリューションを使用して、製品ランキングリストの要件を効率的に実現する方法は? Redisキャッシュソリューションを使用して、製品ランキングリストの要件を効率的に実現する方法は? Apr 19, 2025 pm 11:36 PM

Redisキャッシュソリューションは、製品ランキングリストの要件をどのように実現しますか?開発プロセス中に、多くの場合、ランキングの要件に対処する必要があります。

DICR/YII2-GOOGLEを使用して、Yii2にGoogle APIを統合します DICR/YII2-GOOGLEを使用して、Yii2にGoogle APIを統合します Apr 18, 2025 am 11:54 AM

vProcesserazrabotkiveb-Enclosed、する、するまみ、するまで。 leavallysumballancefriablancefaumdoptomatification、čtokazalovnetakprosto、kakaožidal.posenesko

RedisキャッシュがSpring Bootで失敗した場合はどうすればよいですか? RedisキャッシュがSpring Bootで失敗した場合はどうすればよいですか? Apr 19, 2025 pm 08:03 PM

スプリングブートでは、Redisを使用してOAuth2Authorizationオブジェクトをキャッシュします。 Springbootアプリケーションでは、Springsecurityouth2authorizationserverを使用してください...

HDFS Configuration Centosで変更するには、どのファイルが必要ですか? HDFS Configuration Centosで変更するには、どのファイルが必要ですか? Apr 14, 2025 pm 07:27 PM

Hadoop分散ファイルシステム(HDFS)をCentOSに構成する場合、次のキー構成ファイルを変更する必要があります。Core-Site.xml:Fs.DefaultFS:HDFS:// LocalHost:9000などのHDFSのデフォルトファイルシステムアドレスを指定します。 hadoop.tmp.dir:Hadoop一時ファイルのストレージディレクトリを指定します。 hadoop.proxyuser.root.hosts and hadoop.proxyuser.ro

CentOS HDFS構成のエラーを解く方法 CentOS HDFS構成のエラーを解く方法 Apr 14, 2025 pm 07:06 PM

CENTOSシステムの下でのHDFS構成エラーのトラブルシューティングこの記事は、CENTOSシステムでHDFを構成する際に発生する問題を解決するのに役立つことを目的としています。次の手順に従ってトラブルシューティングを行ってください。Java環境の確認:Java_home環境変数が正しく設定されていることを確認してください。 /etc/profileまたは〜/.bashrcファイルに次のものを追加します:exportjava_home =/path/to/your/javaexportpath = $ java_home/bin:$ pathexecute source/etc/exprofirまたはsource〜/.bashrcを構成します。 Hadoop

Centosでgitlabデータベースを選択する方法 Centosでgitlabデータベースを選択する方法 Apr 14, 2025 pm 05:39 PM

CENTOSシステムにGitLabをインストールして構成する場合、データベースの選択が重要です。 gitlabは複数のデータベースと互換性がありますが、PostgreSQLとMySQL(またはMariaDB)が最も一般的に使用されています。この記事では、データベースの選択要因を分析し、詳細なインストールと構成の手順を提供します。データベース選択ガイドデータベースを選択する際には、次の要因を考慮する必要があります。PostGreSQL:GitLabのデフォルトデータベースは強力で、スケーラビリティが高く、複雑なクエリとトランザクション処理をサポートし、大規模なアプリケーションシナリオに適しています。 MySQL/MariadB:Webアプリケーションで広く使用されている人気のあるリレーショナルデータベース、安定した信頼性の高いパフォーマンスを備えています。 MongoDB:NOSQLデータベース、専門

See all articles