この記事では主に Vue の axios コンポーネントと PHP バックエンドの間でデータをやり取りする方法を紹介します。ある参考値がありますので、共有します。必要な友人は参考にしてください。
1. はじめに
axios は、ajax 技術を使用してバックグラウンドでデータを交換する vue プロジェクトのコンポーネントであり、vue の作者の推奨のもと、かなりの数の vue フロントエンド開発者が使用し始めました。しかし、実際の開発プロセスでは、フロントエンドから送信されたデータをバックエンドが受信できない場合があります。 PHP 言語開発の背景を例に挙げると、PHP のネイティブの事前定義変数 $_POST を受け取ることができません ( 解析に失敗したため )。この記事の目的は、フロントエンドとバックエンドのデータ相互作用を調査し、参考としてさまざまなソリューションを提供することです。
2. 現在、$_POST が受信できるデータ フォーム
フォーム データ
このデータ フォームは、実際には、id などのキーと値のペアです。 1、ある場合 複数のキーと値のペアのセットがあり、それらがネストされている場合、次のようなケースになります
role-name:ta role-desc:xxxxxxxxx id:2 cloud[cla]:001 cloud[cla_baijia]:001 cloud[cla_gongkai]:001 local[soft5]:001 local[soft6]:001 mgmt[mgmt-clouditems]:01
PHP サーバーが実際に受信するデータは次のようになります
role-name=ta&role-desc=xxxxxxxxx&id=2&cloud%5Bcla%5D=001&cloud%5Bcla_baijia%5D=001&cloud%5Bcla_gongkai%5D=001&local%5Bsoft-5%5D=001&local%5Bsoft-6%5D=001&mgmt%5Bmgmt-clouditems%5D=01
特に URL のパラメータに似ていますか?
このキーと値のペアのデータは QueryString と呼ばれます。ブラウザのネイティブ フォームがこのデータを送信すると、リクエスト ヘッダーは application/x-www-form-urlencoded # に設定されます。 ##。 QueryString は、PHP の $_POST
さらに、jQuery の ajax リクエストは受信データ フォームを決定し、暗黙的に param() メソッドを呼び出して json データを変換します。そのため、ユーザーは json データを直接提供するだけで、データをバックグラウンドに正常に送信できます。 param() メソッドを (手動で) 呼び出す機会はあまりありません。デフォルトで jq によって送信されるリクエスト ヘッダーも application/x-www-form-urlencoded ですが、ほとんどの場合、ユーザーが手動で設定する必要はありません。
application/json です。簡単に言うと、デフォルトでは json をバックエンドに渡し、QueryString には変換しません。 . .
3. 解決策1. フロントエンドはデータを QueryString に変換しますqs ライブラリを導入し、stringify メソッドを呼び出します<template> <p> <input> </p> </template> <script> import axios from "axios" import qs from "qs" var json={ "role-name": "ta", "role-desc": "xxxxxxxxx", "id": 2, "cloud": { "cla": "001", "cla_baijia": "001", "cla_gongkai": "001" }, "local": { "soft-5": "001", "soft-6": "001" }, "mgmt": { "mgmt-clouditems": "01" } }; export default { methods:{ post(){ axios.post("http://localhost/web/index.php/admin/login/login",json,{ //配置`transformRequest` ,在向服务器发送前,修改请求数据,axios会根据修改后的数据,自动设置请求头 transformRequest:[function(data){ return qs.stringify(data);//把数据转化为QueryString }] }).then(res=>{ console.log(res); }) } } } </script>2。 PHP バックエンドを使用する php://input は元のデータを取得しますフロントエンドを変更しないと、事前定義変数 $_POST を解析できないため、PHP バックエンドは php:/ のみを使用できます。 /input を使用して元のデータを取得し、それを目的のデータ形式に変換します。
PHP バックエンドがネイティブ開発を使用している場合は、各リクエストのデータを処理する関数をカスタマイズできます。
PHP バックエンドが特定のフレームワークを使用して開発されている場合、フレームワーク自体が php://input の処理をサポートしているかどうかによって異なります。簡単なテスト方法は、ソース コードの全文で php://input を検索することです。見つかった場合はサポートされていますが、そうでない場合はサポートされていないため、該当する処理コードを自分で拡張する必要があります。
実際の使用では、設定ファイル web.php
'components' => [ 'request' => [ 'parsers' => [ 'application/json' => 'yii\web\JsonParser' ], // 其他配置 ], //其他组件配置 ]を設定するだけで済みます。上記はフロントエンド処理とバックエンド処理の 2 つのソリューションであり、実際の状況に応じて選択できます上記は記事の全文です。皆様の学習にお役に立てれば幸いです。その他の関連コンテンツについては、PHP 中国語 Web サイトをご覧ください。 関連する推奨事項:
以上がvue の axios コンポーネントと PHP バックエンドでデータを交換する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

phpssionsStrackuserdataacrossmultiplepagerequestsusingauniqueidstoredinacookie.here'showtomanageetheemefectively:1)Startassession withsession_start()andstoredatain $ _ session.2)RegeneratesseSsessidafterloginwithsession_id(the topreventes_id)

PHPでは、次の手順を通じてセッションデータを繰り返すことができます。1。session_start()を使用してセッションを開始します。 2。$ _Sessionアレイのすべてのキー価値ペアを介してforeachループを反復します。 3.複雑なデータ構造を処理する場合、is_array()またはis_object()関数を使用し、print_r()を使用して詳細情報を出力します。 4.トラバーサルを最適化する場合、ページングを使用して、一度に大量のデータの処理を避けることができます。これにより、実際のプロジェクトでPHPセッションデータをより効率的に管理および使用するのに役立ちます。

このセッションは、サーバー側の状態管理メカニズムを介してユーザー認証を実現します。 1)セッションの作成と一意のIDの生成、2)IDはCookieを介して渡されます。3)サーバーストアとIDを介してセッションデータにアクセスします。

tostoreauser'snameInappession、starthessession withsession_start()、thensignthenameto $ _session ['username']。1)ousession_start()toinitializethessession.2)assighttheuser'snameto $ _ session ['username']

PHPSESSIONの障害の理由には、構成エラー、Cookieの問題、セッションの有効期限が含まれます。 1。構成エラー:正しいセッションをチェックして設定します。save_path。 2.Cookieの問題:Cookieが正しく設定されていることを確認してください。 3.セッションの有効期限:セッションを調整してください。GC_MAXLIFETIME値はセッション時間を延長します。

PHPでセッションの問題をデバッグする方法は次のとおりです。1。セッションが正しく開始されるかどうかを確認します。 2.セッションIDの配信を確認します。 3.セッションデータのストレージと読み取りを確認します。 4.サーバーの構成を確認します。セッションIDとデータを出力し、セッションファイルのコンテンツを表示するなど、セッション関連の問題を効果的に診断して解決できます。

session_start()への複数の呼び出しにより、警告メッセージと可能なデータ上書きが行われます。 1)PHPは警告を発し、セッションが開始されたことを促します。 2)セッションデータの予期しない上書きを引き起こす可能性があります。 3)session_status()を使用してセッションステータスを確認して、繰り返しの呼び出しを避けます。

PHPでのセッションライフサイクルの構成は、session.gc_maxlifetimeとsession.cookie_lifetimeを設定することで達成できます。 1)session.gc_maxlifetimeサーバー側のセッションデータのサバイバル時間を制御します。 0に設定すると、ブラウザが閉じているとCookieが期限切れになります。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

ホットトピック









