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

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

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

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

Q&A

解決済

2回答

2472閲覧

JSONデータのPOSTで空白処理の仕方

OY_hironet

総合スコア16

JSON

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

0グッド

0クリップ

投稿2017/09/13 02:07

JSONでデータをPOSTしてますが、空白の処理がうまくゆかず悩んでおります。
実環境は、C#からJSONでPHPを経由してDBを利用しております。
以下は検証のために作成したものです。
PHPのモデルで$stimeのところに時刻が入っており、日付との間にスペースがあります。
これが邪魔をしているのか、JSONにエンコードした時に、「time":"2017/09/13 」の後で改行されたようになります※1。
これを、POSTで送りますと受け側では、日付のところまでしかPOSTされないようです※2。
これを、すべて送れるようにする方法はございますでしょうか。
スペースを削除して送信しますと問題なく送信されます。

お知恵を拝借できればと思います。

よろしくお願いします。

送信側----------------------------------- $model = new stdClass(); $model->dno = 3090298; $model->dnu = 3090004; $model->code = 102; $model->stime = '2017/09/13 11:20:00'; $model->ccode = 2; $model->tco = 3090004; $model->ymd = '2017/09/13'; $s1 = json_encode($model); ※1 {"dno":3090298,"dnu":3090004,"code":102,"stime":"2017\/09\/13 11:20:00","ccode":2,"tco":3090004,"ymd":"2017\/09\/13"}" 受信側------------------------- ※2 string(69) "{"dno":3090298,"dnu":3090004,"code":102,"stime":"2017\/09\/13"

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

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

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

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

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

guest

回答2

0

PHP上で$s1を参照しても改行らしきものは入らないようですが
保険として$s1からstr_replaceで\rと\nを取り除いてみてはどうでしょか?

投稿2017/09/13 05:46

yambejp

総合スコア114761

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

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

OY_hironet

2017/09/13 07:10

有難うございました。 お教えいただいた方法では解決は出来なかったのですが、エンコードする前に、スペースを取ることで四苦八苦しておりましたので、エンコードした後に行うというヒントを頂き、 以下のようにしてみました。 送信側----------------------------- $s1 = json_encode($model); $s2 = str_replace(' ', '@',$s1); これでスペースには「@」が入り、無事、POSTすることができました。 受信側------------------------------ $jsonmodel = $_POST['model']; $aaa = str_replace('@',' ',$jsonmodel); $model = json_decode($aaa); 受信側では、デコードしてからstr_replaceを掛けてもダメでしたので、JSONのままstr_replaceを実施、 見るとやはり改行らしきものがあるのですが、そのまま、デコードを掛けると無事表示できました。 素人なのでもう少し、良い書き方があるのだとは思いますが、一応、これで思い通りの作業に進めそうです。 ありがとうございました。
guest

0

自己解決

送信側-----------------------------
$s1 = json_encode($model);
$s2 = str_replace(' ', '@',$s1);

これでスペースには「@」が入り、無事、POSTすることができました。

受信側------------------------------
$jsonmodel = $_POST['model'];
$aaa = str_replace('@',' ',$jsonmodel);
$model = json_decode($aaa);

投稿2017/09/18 01:12

OY_hironet

総合スコア16

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問