ホームページ  >  記事  >  バックエンド開発  >  PHPがポストデータを受信して​​mysqlに書き込む問題

PHPがポストデータを受信して​​mysqlに書き込む問題

WBOY
WBOYオリジナル
2016-06-23 13:47:241435ブラウズ

専門家に答えを求める: PHP はどのようにしてリモートポストから txt テキストコンテンツを受信し、同時にそれを mysql データベースに書き込むのでしょうか?コードを完成させてください!必要に応じてボーナスポイントも!
txt テキスト コンテンツ フィールドの形式:
学生 ID、学生の名前、学生のメールアドレス、学生のアドレス


ディスカッションへの返信 (解決策)

データ テーブル:

CREATE TABLE `student` (  `id` int(10) unsigned NOT NULL auto_increment,  `xid` varchar(20) NOT NULL,  `name` varchar(20) NOT NULL,  `email` varchar(100) NOT NULL,  `address` varchar(100) NOT NULL,  PRIMARY KEY  (`id`)) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;


postdemo.php
<?php// 连接数据库  $conn=@mysql_connect("数据库ip","帐号","密码")  or die(mysql_error());  @mysql_select_db('数据库名',$conn) or die(mysql_error());  $action = isset($_REQUEST['action'])? $_REQUEST['action'] : '';if($action=='add'){    $xid = isset($_POST['xid'])? mysql_escape_string($_POST['xid']) : '';    $name = isset($_POST['name'])? mysql_escape_string($_POST['name']) : '';    $email = isset($_POST['email'])? mysql_escape_string($_POST['email']) : '';    $address = isset($_POST['address'])? mysql_escape_string($_POST['address']) : '';    if($xid=='' || $name=='' || $email=='' || $address==''){        echo 'please input data';        exit();    }    $sqlstr = "insert into student(xid,name,email,address) values('".$xid."','".$name."','".$email."','".$address."')";    mysql_query($sqlstr) or die(mysql_error());    header('location:postdemo.php');}else{?><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head>  <meta http-equiv="content-type" content="text/html; charset=utf-8">  <title>demo</title> </head> <body>  <form name="form1" method="post" action="postdemo.php">  <p>学生id:<input type="text" name="xid"></p>  <p>学生名字:<input type="text" name="name"></p>  <p>学生邮箱:<input type="text" name="email"></p>  <p>学生地址:<input type="text" name="address"></p>  <p><input type="hidden" name="action" value="add"><input type="submit" name="b1" value="提交"></p>  </form> <?php    $sqlstr = "select * from student order by id";    $query = mysql_query($sqlstr) or die(mysql_error());    $result = array();    while($thread=mysql_fetch_assoc($query)){        $result[] = $thread;    }    if($result){        echo '<table>';        echo '<th>NO</th><th>学生id</th><th>学生名字</th><th>学生邮箱</th><th>学生地址</th>';        foreach($result as $row){            echo '<tr>';            echo '<td>'.$row['id'].'</td>';            echo '<td>'.$row['xid'].'</td>';            echo '<td>'.$row['name'].'</td>';            echo '<td>'.$row['email'].'</td>';            echo '<td>'.$row['address'].'</td>';            echo '</tr>';        }        echo '</table>';    } ?>   </body></html><?php}?>

ありがとう専門家回答では、txt テキストの内容がフォームによって送信されない箇所が 1 つあります。例:

投稿ファイル名: Good.txt
ファイルの内容:
001
Wang Jun
wangjun@ 126.com
山東省青島市浜海路2号

専門家の方、バックグラウンドの受信コードは変更されましたか?
php を使用して、good.txt ファイルのバックエンドへの投稿をシミュレートするにはどうすればよいですか?
よろしくお願いします

データが post メソッドを使用して送信されている限り、$_POST['変数名'] を使用して受信できます

<?php$content = file_get_contents('php://input');?>

ファイルのアップロードをシミュレートしますか?

なぜファイルを使用する必要があるのですか?

通常のマッチングを使用して、対応するデータを見つけます

txt ファイルをアップロードすると、サーバーが txt コンテンツをサーバーにインポートしますか?

fdipzone 専門家の皆様、こんにちは。明確に説明していなかったので再整理します。txt ファイルはフォームで送信されませんが、リモート クライアントは txt ファイルを投稿し、mysql データベースに書き込みます。

例: 投稿ファイル名: Good.txt、ファイル内容
001
Wang Jun
wangjun@126.com
No. 2 Binhai Road, Qingdao City, Shandong Province

リモートクライアントは、good.txt ファイルを直接投稿するため、 、送信してください データには変数名はなく、直接文字列になっていますが、$_POSTでは受け取れないのでしょうか?

ファイルストリーミング?

次の例では、PHP ポスト ファイル フロー、ファイル フローの受信、ファイル フローの分析、データベースへの書き込みの 4 つのステップを完了します
1.conn.php はデータベースへの接続に使用されます
2.list.php は次の目的で使用されますデータベーステーブルのレコードを表示します
3. add.php はストリームファイルを受信し、分析してデータベースに書き込むために使用されます
4.post.ph はストリームファイルを送信するために使用されます
5.good.txt ファイルはコンテンツを送信するために使用されます

001王军wangjun@126.com山东省青岛市滨海路2号

上記のファイルはルート ディレクトリに配置されており、http://localhost/filename を使用してアクセスできると仮定します。

まずデータベースを作成します
CREATE TABLE `student` (  `id` int(10) unsigned NOT NULL auto_increment,  `xid` varchar(20) NOT NULL,  `name` varchar(20) NOT NULL,  `email` varchar(100) NOT NULL,  `address` varchar(100) NOT NULL,  PRIMARY KEY  (`id`)) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;



conn.php
<?php// 连接数据库  $conn=@mysql_connect("数据库host","帐号","密码")  or die(mysql_error());  @mysql_select_db('数据库名',$conn) or die(mysql_error());  ?>



list.php
<?phprequire "conn.php";?><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head>  <meta http-equiv="content-type" content="text/html; charset=utf-8">  <title>demo</title> </head>  <body>  <?php    $sqlstr = "select * from student order by id";    $query = mysql_query($sqlstr) or die(mysql_error());    $result = array();    while($thread=mysql_fetch_assoc($query)){        $result[] = $thread;    }     if($result){        echo '<table>';        echo '<th>NO</th><th>学生id</th><th>学生名字</th><th>学生邮箱</th><th>学生地址</th>';        foreach($result as $row){            echo '<tr>';            echo '<td>'.$row['id'].'</td>';            echo '<td>'.$row['xid'].'</td>';            echo '<td>'.$row['name'].'</td>';            echo '<td>'.$row['email'].'</td>';            echo '<td>'.$row['address'].'</td>';            echo '</tr>';        }        echo '</table>';    }  ?>    </body></html>



add.php
<?phprequire "conn.php";$tmpfile = 'tmp.txt'; // 临时文件,用于保存接收到的文件流$content = $GLOBALS['HTTP_RAW_POST_DATA'];if(empty($content)){      $content = file_get_contents('php://input');}file_put_contents($tmpfile, $content, true);  $file = file_get_contents($tmpfile);$data = explode(chr(10), $file); // 分解成数组$xid = mysql_escape_string($data[0]);$name = mysql_escape_string($data[1]);$email = mysql_escape_string($data[2]);$address = mysql_escape_string($data[3]);$sqlstr = "insert into student(xid,name,email,address) values('".$xid."','".$name."','".$email."','".$address."')";    mysql_query($sqlstr) or die(mysql_error());header('location:list.php');?>



post.php
<?php$data = file_get_contents('good.txt'); // 要发送的文件$opts = array(	'http' => array(		'method' => 'POST',		'header' => 'content-type:application/x-www-form-urlencoded',		'content' => $data	));$context = stream_context_create($opts);$url = 'http://localhost/add.php'; // 接收的urlfile_get_contents($url, false, $context);?>


手順は次のとおりです次に、http://localhost/post.php にアクセスします
次に、http://localhost/list.php にアクセスします
list.php が Good.txt ファイルの内容を表示できれば、post.php が成功するたびに成功したことになります。実行すると、データテーブルにエントリが追加されます。

fdipzone 専門家の回答は非常に役に立ちます。最初に試して、後でポイントを与えます。

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