- ベストアンサー
フォーム 付随データ 表示
恐れ入ります。 Mysql に保存されているデータに対し、 Perlから情報を送信します。 特定のコードをフォームに入力すると、そのコードに付随したMySQL上のレコードの情報が inputフィールドの表示されるようにしたいのですが、 方法はありますでしょうか? 例) フォームに3232と入力 その他inputフィールドに、 ---- 花 ---- バラ ---- 2000円 ---- 在庫30 ---- のように、自動的に表示されるイメージです。 よろしくお願いします。
- みんなの回答 (7)
- 専門家の回答
質問者が選んだベストアンサー
こんにちは。 すみません、動いたようですね。 >これを、javascriptから送信されたpro_noを00001部分に代入しようとしていますが、うまくいきません。 >perlにはお詳しくないとのお話でしたが、 >$.post ( >'get.cgi', >{ cd: 'C' + pro_no }, >の部分の意味を教えていただけないでしょうか。 >perl側で受け取れるか試してみたいと思います。 cd:'C'+pro_noはパラメータ名がcdで入力されたコードの先頭に'C'を付加してpost送信しています。 'C'を付加したのは私のJSONデータのコードにCが入っている為ですので付けなくて良いです。 { cd: pro_no }でOKです。 基本的なperlの書き方しかわからないのでちょっと勉強してみました。 cdというパラメータ名でPOSTしていますので $code = $form -> param('cd'); (多分これで取れます・・・) で$codeに送信されたコードが入ります。 それをSQLの条件にくっつけてあげればOKです。 直接くっつけるだけだとセキュリティ上問題がありますのでその辺は考慮しておいてください。 (prepare使っているから平気かな?)
その他の回答 (6)
- LancerVII
- ベストアンサー率51% (1060/2054)
こんにちは。 私の環境では今の形式で動作確認できています。 JSONは基本的にunicodeが良いです。 文字コード変換は http://kawa.at.webry.info/200801/article_6.html この辺を参考にしてみてください。 また直接get.cgiを呼んでみて {"bunrui":"野菜","pro_kana":"ヤサイ","pro_no":"0001","pro_name":"トマト","num":"2","a_price":"200","c_price":"120","pro_lot":"430"} 本当に上記の形式で表示されているか確認してください。 もし [{"bunrui":"野菜","pro_kana":"ヤサイ","pro_no":"0001","pro_name":"トマト","num":"2","a_price":"200","c_price":"120","pro_lot":"430"}] の形式([]で囲まれている)場合は配列として扱われてしまいますので前後の[]を消すかJavaScriptで取得する際に json[0].pro_nameとする必要があります。
お礼
ありがとうございます。大変参考になりました。
- LancerVII
- ベストアンサー率51% (1060/2054)
こんにちは。 次に頂いたソースですと、構文が間違っております。 転記ミスなら良いのですが。 (インデントの為、全角空白使っているのでコピペでは動きません) これを直した上で大事なこと忘れていました。 JSONを出力するCGIのヘッダに print "Content-type: application/json; charset=UTF-8;\n\n"; を指定してあげないとうまく動かないかもしれません。 JSONであるというヘッダを付加します。 ==== 頂いたソース <script type="text/javascript"> $().ready ( function() { $('#id-form input.pro_no').keyup ( function() { var $obj = $(this).parent().parent(); var pro_no = $(this).val(); $obj.find('span.msg').html ( '' ); if ( pro_no.length === 5 ) { $.post ( 'get.cgi', { cd: 'C' + pro_no }, function ( json ) { $obj.find('input.pro_name').val ( json.pro_name ); $obj.find('input.pro_lot').val ( json.pro_lot ); $obj.find('input.pro_kana').val ( json.pro_kana ); ); } }); }); </script> ==== 正 $().ready ( function() { $('#id-form input.pro_no').keyup ( function() { var $obj = $(this).parent().parent(); var pro_no = $(this).val(); $obj.find('span.msg').html ( '' ); if ( pro_no.length === 5 ) { $.post ( 'get.cgi', { cd: 'C' + pro_no }, function ( json ) { $obj.find('input.pro_name').val ( json.pro_name ); $obj.find('input.pro_lot').val ( json.pro_lot ); $obj.find('input.pro_kana').val ( json.pro_kana ); } ); } }); });
お礼
できました!! 文字コードを揃えたら、しっかり表示できました。 ありがとうございます。 現在、MySQL側で、便宜的にwhereで00001コードのレコードのみを表示する形で成功しています。 これを、javascriptから送信されたpro_noを00001部分に代入しようとしていますが、うまくいきません。 perlにはお詳しくないとのお話でしたが、 $.post ( 'get.cgi', { cd: 'C' + pro_no }, の部分の意味を教えていただけないでしょうか。 perl側で受け取れるか試してみたいと思います。 よろしくお願いします。
補足
get.cgi -------------------------- #!/usr/bin/perl use CGI; use DBI; use JSON; $user = '*****'; $passwd = '*****'; $form = CGI->new; print "Content-type: application/json; charset=UTF-8;\n\n"; $db = DBI->connect('DBI:mysql:*****:localhost', $user, $passwd, {RaiseError => 0, PrintError => 1}); if(!$db){ print "SQL失敗\n"; exit; } $sql = "select num, pro_no, pro_name, pro_kana, pro_lot, bunrui, a_price, c_price from product where pro_no like '%00001%' "; //←便宜上、1レコードのみを表示しています。 $sth = $db->prepare($sql); if(!$sth->execute){ print "SQL失敗\n"; exit; } my $json = '['; while ( my $ref = $sth->fetchrow_hashref() ){ $json .= (JSON->new->encode($ref).', '); $json =~ s/,.$//s; $json .= ']'; } print $json; $sth->finish; $db->disconnect; ------------------------ javascript 側 ------------------------ print qq! <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <meta http-equiv="Content-Script-Type" content="text/javascript" /> <meta http-equiv="Content-Style-Type" content="text/css" /> <title>【OKWave回答サンプル集】フォーム付随データ表示</title> <script type="text/javascript" src="https://www.google.com/jsapi"></script> <script type="text/javascript">google.load('jquery','1');</script> <script type="text/javascript"> $().ready ( function() { $('#id-form input.pro_no').keyup ( function() { var $obj = $(this).parent().parent(); var pro_no = $(this).val(); $obj.find('span.msg').html ( '' ); if ( pro_no.length === 5 ) { $.post ( 'get.cgi', { cd: 'C' + pro_no }, function ( json ) { $obj.find('input.pro_name').val ( json.pro_name ); $obj.find('input.pro_lot').val ( json.pro_lot ); $obj.find('input.pro_kana').val ( json.pro_kana ); } ); } }); }); </script> </head> <body> <h1>フォーム付随データ表示(q7550852)</h1> <h2>サンプル</h2> <form id="id-form"> <table> <thead> <tr> <th>商品コード</th><th>商品名</th><th>単価</th><th>在庫数</th> </tr> </thead> <tbody> <tr> <td><input type="text" name="pro_no[]" class="pro_no" maxlength="5" /></td> <td><input type="text" name="pro_name[]" class="pro_name" readonly="readonly" /></td> <td><input type="text" name="pro_lot[]" class="pro_lot" readonly="readonly" /></td> <td><input type="text" name="pro_kana[]" class="pro_kana" readonly="readonly" /></td> <td><span class="msg"></span></td> </tr></table>!; ------------------- としていますが、動作しません。 MySQL側ではEUC-JPでデータを出す仕組みになっています。 文字コードの問題なのでしょうか。文字化けしても動作すれば良いのですが、原因が分かりません。 全角スペースは全て削除しました。 get.cgi側で取得している、pro_no = 00001のレコードを、 list.cgi 側のpro_noフィールドに打ち込んで動作させようとしています。 よろしくお願いします。
- LancerVII
- ベストアンサー率51% (1060/2054)
こんにちは。 PerlだろうがPHPだろうがJavaであろうが、返ってくるデータがJSON形式のものであればサーバ側の処理は何でもよいので多分参考にはならないと思います。 今、補足いただいていたソースを良く見てみたら、SQLにて全件取得していませんか? cdというパラメータで商品コードが送信されますのでそれと対になるデータ1件でないとダメです。 (ダメというのは今回の作りの場合であって全てにおいてという意味ではないです) 一覧(入力画面)・・・list.cgi 情報取得用・・・get.cgi こうした場合、一覧(入力画面)にデータ取得用のJavaScriptを記述します。 get.cgiは入力された商品コードに対するJSONデータを返すのみです。(1件) また今回のサンプルJavaScriptではJSONの形式が {"status":"OK","data":{"name":"\u308a\u3093\u3054","zaiko":10,"tanka":200}} でないと動きません。 違う形式にする場合はJavaScriptの変更が必要です。 1件この形式で返ってきたとしたら {"bunrui":"野菜","pro_kana":"ヤサイ","pro_no":"0001","pro_name":"トマト","num":"2","a_price":"200","c_price":"120","pro_lot":"430"} function ( json ) { $obj.find('input.pro_name').val ( json.pro_name ); } こうなります。 var status = json.status; とか var data = json.data; ステータスがOKのチェック等はいりません。 あくまで私が設計したJSONで返ってきた場合の処理ですのでstatusとかチェックしたい場合はJSONにstatusの項目を入れてあげる必要があります。
補足
ご丁寧なご返信ありがとうございます。 {"bunrui":"野菜","pro_kana":"ヤサイ","pro_no":"0001","pro_name":"トマト","num":"2","a_price":"200","c_price":"120","pro_lot":"430"} として、get.cgiにて取得できました。 print $json;として表示されたものです。 この文字列を、list.cgi上でのjavascriptに読ませることが出来ていない模様です。 何か変数の中に代入するのでしょうか。 list.cgiの中には、 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <meta http-equiv="Content-Script-Type" content="text/javascript" /> <meta http-equiv="Content-Style-Type" content="text/css" /> <title>【OKWave回答サンプル集】フォーム 付随データ 表示</title> <script type="text/javascript" src="https://www.google.com/jsapi"></script> <script type="text/javascript">google.load('jquery','1');</script> <script type="text/javascript"> $().ready ( function() { $('#id-form input.pro_no').keyup ( function() { var $obj = $(this).parent().parent(); var pro_no = $(this).val(); $obj.find('span.msg').html ( '' ); if ( pro_no.length === 5 ) { $.post ( 'get.cgi', { cd: 'C' + pro_no }, function ( json ) { $obj.find('input.pro_name').val ( json.pro_name ); $obj.find('input.pro_lot').val ( json.pro_lot ); $obj.find('input.pro_kana').val ( json.pro_kana ); ); } }); }); </script> <style type="text/css"> table { } input.pro_no { width: 60px; } input.pro_name { width: 80px; } input.pro_lot { width: 60px; } input.pro_kana { width: 30px; } span.msg { font-size: 0.8em; color: #f00; } </style> </head> <body> <h1>フォーム 付随データ 表示(q7550852)</h1> <h2>サンプル</h2> <form id="id-form"> <table> <thead> <tr> <th>商品コード</th><th>商品名</th><th>単価</th><th>在庫数</th> </tr> </thead> <tbody> <tr> <td><input type="text" name="pro_no[]" class="pro_no" maxlength="5" /></td> <td><input type="text" name="pro_name[]" class="pro_name" readonly="readonly" /></td> <td><input type="text" name="pro_lot[]" class="pro_lot" readonly="readonly" /></td> <td><input type="text" name="pro_kana[]" class="pro_kana" readonly="readonly" /></td> <td><span class="msg"></span></td> </tr> </table> と記述しています。 よろしくお願いします。
- LancerVII
- ベストアンサー率51% (1060/2054)
こんにちは。 最近のperlには明るくないので具体的なアドバイスが出来ないのですが、一覧を表示するcgiとJSONを出力するcgiは別に用意します。 (list.cgiで一覧を表示しコード入力時に呼び出すのがread.cgiとか) Ajaxを利用しなくても出来ますよ。 コードを入力されたら通常のsubmitを行って商品コードから商品名等を読み込んで一覧表示に埋め込んであげれば出来ます。
お礼
ありがとうございます。 恐れ入りますが、phpでの記述がありましたら、 教えていただけないでしょうか。 私はphpには詳しくないのですが、なんとかヒントがあればと思います。 よろしくお願いいたします。
補足
[{"bunrui":"野菜","pro_kana":"ヤサイ","pro_no":"0001","pro_name":"トマト","num":"2","a_price":"200","c_price":"120","pro_lot":"430"}, {"bunrui":"酒","pro_kana":"サケ","pro_no":"0002","pro_name":"ビール","num":"3","a_price":"30000","c_price":"15000","pro_lot":"340"}, {"bunrui":"健康食品","pro_kana":"ケンショク","pro_no":"0003","pro_name":"グルコサミン","num":"5","a_price":"1000","c_price":"350","pro_lot":"233"}] perlで出力したJSONは以上になります。 ご教授いただいたjavascriptの書かれたファイルをedi2.cgiとし、 JSON出力用としてget.cgiにしましたが、JSONファイルを読み込めていないようです。 よろしくお願いします。
- tumeno
- ベストアンサー率41% (5/12)
よく郵便番号から住所を自動入力するのと同じ処理だと思います。 (javascriptからPHP等を呼び出し、jsonp形式でデータを受け取ってinput欄に埋め込む) 参考urlを記しておきます。
- 参考URL:
- http://zipaddr.com/
お礼
ありがとうございます。大変参考になりました。
補足
恐れ入ります。 ファイルを見てみましたが、難解すぎてわかりませんでした。
- LancerVII
- ベストアンサー率51% (1060/2054)
こんにちは。 perlでのDB接続、取得は出来ているとしたらJSONモジュールを利用してJSONを出力し、そのJSONを取得して表示の実行をしてあげればお望みの機能が実現できると思います。 Ajaxを簡単に扱うためにjQueryを利用して作ってみました。 サーバ側はPHPで作っていますが、JSONを出力するというのは同じです。 ==== 動作サンプル http://hppg.moe.hm/okwave/qa/q7550852/ 商品コードは0001~0004が有効になっています。 商品コードに0001と入力すると商品名等のデータが反映されます。 参考にしてみてください。
お礼
「edit.cgi」の中に、以下を記述しています。 use CGI; use DBI; use JSON; $user = '****'; $passwd = '****'; $form = CGI->new; print "Content-type: text/html\n\n"; print qq!<html><head> <LINK href="./all2.css" rel="stylesheet" type="text/css"> <meta http-equiv="Content-Type" content="text/html; charset=EUC-JP"> <script type="text/javascript" src="https://www.google.com/jsapi"></script> <script type="text/javascript">google.load('jquery','1');</script> <script type="text/javascript"> $().ready ( function() { $('#id-form input.pro_no').keyup ( function() { var $obj = $(this).parent().parent(); var pro_no = $(this).val(); $obj.find('span.msg').html ( '' ); if ( pro_no.length === 5 ) { $.post ( 'edit.cgi', { cd: 'C' + pro_no }, function ( json ) { var status = json.status; if ( status === 'OK' ) { var data = json.data; $obj.find('input.pro_name').val ( data.pro_name ); $obj.find('input.pro_kana').val ( data.pro_kana ); if ( data.pro_kana === 0 ) $obj.find('span.msg').html ( '在庫を確認してください。' ); } else { $obj.find('span.msg').html ( '商品データが存在しません。' ); } } ); } }); }); </script> </head>!; # DBに接続 $db = DBI->connect('DBI:mysql:****:localhost', $user, $passwd, {RaiseError => 0, PrintError => 1}); if(!$db){ print "接続失敗\n"; exit; } # SQL実行 $sql = "select num, pro_no, pro_name, pro_kana, pro_lot, bunrui, a_price, c_price from product"; $sth = $db->prepare($sql); if(!$sth->execute){ print "SQL失敗\n"; exit; } @rec = $sth->fetchrow_array; if(!@rec){ print "データが削除されています。\n"; exit; } print "<form id=id-form action=./update.cgi method=post>\n"; print qq! <table border="1" cellspacing="0" align=center><tr> <td colspan=2>登録</td></tr><tr>!; my $JSON = '['; while ( my $ref = $sth->fetchrow_hashref() ){ $JSON .= (JSON->new->encode($ref).', '); } $JSON =~ s/,.$//s; $JSON .= ']'; print $JSON; print qq! <td id=fo>製品番号</td> <td><input type=text name=pro_no[] class=pro_no></td></tr><tr> <td>製品名</td>\ <td><input type=text name=pro_name[] class=pro_name></td></tr><tr> <td>製品カナ</td> <td><input type=text name=pro_kana[] class=pro_kana></td></tr><tr>!; print "<input type=hidden name=num value=" . $form->param('num') . ">\n"; print "<td align=right colspan=2><input type=submit value=更新></tr>\n"; print "</form></table>\n"; # ステートメントハンドルクリア $sth->finish; # DB切断 $db->disconnect; print "</body></html>\n"; としていますが、実行されません。 よろしくお願いします。
補足
ありがとうございます。まさにこれを探していました。 しかし、JSONについてまったく知識が無く、 Perl上でどのように書いたら良いのかが分かりません。 サーバー上ではCPANでJSONをインストール済みです。 また、Ajaxを使わなければ、実行は不可能なのでしょうか、 ご教授いただけたらと思います。
お礼
ご返信おそくなりました。動きました! ありがとうございます。cdという名前で送信されていたのですね。 perl側で受け取って、where句で限定したら、しっかり表示されました。 本当にご丁寧にありがとうございました。