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

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

新規登録して質問してみよう
ただいま回答率
85.48%
JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

1回答

417閲覧

json_encodeについて

atushi

総合スコア5

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

2クリップ

投稿2022/04/16 07:20

編集2022/04/17 03:57

質問させてください。
やりたいことはPHPでJsonを書き出すなんですが、
json_encodeでNULLが返ってきます。

参照URL

HTML側

コードPHP側

<?php // 画面から送られたきた値 $id = filter_input(INPUT_POST, 'id'); $idd = filter_input(INPUT_POST, 'idd'); $list = array("id" => $id, "name" => $idd, "hoge" => "ほげ" ); // 明示的に指定しない場合は、text/html型と判断される header("Content-type: application/json; charset=UTF-8"); //JSONデータを出力 echo json_encode($list, JSON_UNESCAPED_UNICODE); exit;/* */

コードJavascript側

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <!-- jQueryの読み込み (これがないと動かないよ) --> <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script> <title>Ajax Sample1</title> </head> <body> ID : <input type="text" id="id" /> ID : <input type="text" id="idd" /> <button id="btn">SEND</button> <div><br></div> <div id="res">戻り値が表示される</div> <script> $(function(){ // ボタンがクリックされたら $("#btn").on("click", function(event){ // 入力されたID値を取得 id = $("#id").val(); idd = $("#idd").val(); $.ajax({ type: "POST", url: "ajax.php", data: { "id":id, "idd":idd}, dataType : "json" }).done(function(data){ console.log(data) <!--console--> $("#res").text(data.id+' : '+data.name+' : '+data.hoge); }).fail(function(XMLHttpRequest, textStatus, error){ alert(error); }); }); }); </script> </body> </html>

ページ側では反映されているのでこちらどの様にしてPHP側の
エンコード(NULL)を解消させるかお教えいただけないでしょうか?
私、PHPが初心者で申し訳ございません。

PHP側でも、JSONを取得したいのですがお教えいただきたく存じます。

こちらconsoleのスクリーンショットになります。
イメージ説明

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2022/04/16 08:20

送信してる側もURLではなくソースコードで質問本文に提示してください。 Chrome拡張(PostMan)でAPIとして実行してみましたが、そちらもNULLになるのでおそらくPHP側の問題です。
m.ts10806

2022/04/16 08:22

ただ、ちなみに提示されたコードでローカルにて実行しましたがちゃんと返ってきました。 aaa : bbb : ほげ
m.ts10806

2022/04/16 08:23

PHPが質問本文に提示されたそのままではないとかでは?
atushi

2022/04/16 10:02

ありがとうございます。 PHPがほぼ素人なもので、申し訳ございません。 javascriptのコードを追記いたしました。 いろいろと調べているのですが、 $id = filter_input(INPUT_POST, 'id');の filter_inputが問題ではないかというところまで来たのですが、 filter_inputをグローバル変数からローカル変数に変更の仕方などを探っております。
m.ts10806

2022/04/16 10:11 編集

filter_input(INPUT_POST, 'id'); の中にグローバル変数も何も変数がないです。 第一引数は定数。 ただ、いずれにしてもPHPもHTMLも提示のコードで入力値が返ってきてました。 ちなみにdoneにて変数dataをconsole.log()するとどうなりますか? あと、INPUT_GETにしてブラウザからajax.php?id=aaa&idd=bbbのようにアクセスしたらどうなりますか? 問題切り分けのための検証コードです。
atushi

2022/04/16 12:44

ありがとうございます。console自体は問題なく動いてました。 こちらが結果となります。 Objecthoge: "ほげ"id: "aaa"name: "aaa"[[Prototype]]: Object >INPUT_GETにしてブラウザからajax.php?id=aaa&idd=bbbのようにアクセスしたらどうなりますか? こちらに関しても問題なくでした。
m.ts10806

2022/04/17 00:03

コンソールの画面キャプチャいただけますか? こちらの手元で動いている以上はコード自体に間違いがあるようには思えませんが、「こちらが結果となります」と提示された中にiddがないのは不思議なので(一部だけ切り取られているような気がしないでもない)
atushi

2022/04/17 02:37 編集

すいません、わたくしがPHP側でnameにしてしまってました。 console画像を追加いたしました。
m.ts10806

2022/04/17 02:49

これはどこに書いたconsole.logですか?
m.ts10806

2022/04/17 03:02

質問本文のコードを更新してください
atushi

2022/04/17 03:58

申し訳ございません。書いたのはdoneの後になります。 }).done(function(data){ console.log(data) <!--console--> $("#res").text(data.id+' : '+data.name+' : '+data.hoge); }).fail(function(XMLHttpRequest, textStatus, error){ alert(error); });
atushi

2022/04/17 03:58

上記のコードに追加しております。
m.ts10806

2022/04/17 05:27

全角スペース入ってますが、エラー出ませんか?
m.ts10806

2022/04/17 05:28

console.log(data)[ ]<!--console--> [] のところ
guest

回答1

0

現状質問本文に提示されているコードでhtml、PHPともコピペで実行しましたが、結果はちゃんと出てるように見えます。
firefox
イメージ説明
Chrome
イメージ説明

HTML側のリンクで提示されているコードは同じ要素に対して.text()が実行されていて後のものに上書きされてるんだろうな、というのは分かります。
(いろいろ検証に書かれたのだとは思いますが)

投稿2022/04/17 05:35

m.ts10806

総合スコア80850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問