ホームページ >バックエンド開発 >PHPチュートリアル >PHP は HTML フォーム データを取得しますが、MySQL データベースに書き込むことができません

PHP は HTML フォーム データを取得しますが、MySQL データベースに書き込むことができません

WBOY
WBOYオリジナル
2016-06-23 14:28:35884ブラウズ

mysql データベース フォーム

PHP を使い始め、書籍データベースを作成しようとしていますが、データベースの書き込みにいくつかの問題があります
一般インターフェイス モジュール
<!DOCTYPE html><html>	<head>		<title>		图书录入数据处理 - 藏书		</title>		<meta charset="utf-8">		<link rel="stylesheet" href="add.css">	</head>	<body>		<div id="header">			<h2 id="guidinghead">			核准预览数据			</h2>		</div>		<div id="container">		<?php			/*载入预定义页面*/			include 'definevar.php';			/*全局变量*/			include 'isbn10to13.php';			/*ISBN-10与ISBN-13转换*/			include 'code2loc.php';			include 'code2lang.php';			include 'code2clssys.php';			include 'code2punit.php';			/*代码??信息转换函数组*/			echo 'ISBN-13 国际标准书号:' . $isbn . '<br />';			echo 'CIP 图书在版编目:' . $cip . '</p>' . '<p>正书名:' . $title . '<br />副书名:' . $subtitle . '<br />丛书名:' . $series . '</p>';			$creator1loc = code2loc($creator_loc_id1);			echo '<p>作者1:[' . $creator1loc . ']' . $creator_1 . '<br />';			$creator2loc = code2loc($creator_loc_id2);			echo '作者2:[' . $creator2loc . ']' . $creator_2 . '</p>';			$publoc = code2loc($publoc_id);			echo '<p>由' . $publoc . '的' . $publisher . '出版<br />';			$language = code2lang($lang_id);			echo '此' . $language . '发行版本为' . $edit_date . '第' . $edit_no . '版 ' . $version_date . '第' . $version_no . '次印刷</p>';			echo '<p>关键词组1:' . $subj_key_1 . '?' . $subj_key_2 . '?' . $subj_key_3 . '<br />';			$clssys1 = code2clssys($clssys_id_1);			echo '关键词组2:' . $subj_key_4 . '?' . $subj_key_5 . '?' . $subj_key_6 . '<br />';			$clssys1 = code2clssys($clssys_id_1);			echo $clssys1 . '分类号:' . $class_no_1 . '<br />';			$clssys2 = code2clssys($clssys_id_2);			echo $clssys2 . '分类号:' . $class_no_2 . '</p>';			$priceunit = code2punit($punit_id);			echo '<p>价格 ' . $price . $priceunit . ' &middot; 藏本数量 ' . $amount . ' &middot; 相关图书ISBN ' . $rlt_isbn . '</p>';			echo '<p>备注信息' . $noteinfo . '</p>';						echo '<h3>数据库写入信息</h3>';			include 'insert.php'; /*载入写入数据库模块*/		?>		<object type='image/svg+xml' data='bcgen/getbc.php?code=<?php echo $isbn; ?>'></object><br />		<ul>			<li><a href="http://book.douban.com/isbn/<?php echo $isbn; ?>/">《<?php echo $title ?>》在豆瓣上的页面</a></li>			<li><a href="http://www.amazon.cn/s/field-keywords=<?php echo $isbn; ?>">《<?php echo $title ?>》在亚马逊(中国网站)上的页面</a></li>		</ul>		</div>		<div id="bottom" name="bottom">		<a href="insert.php"><button>确认添加</button></a>		<input type="button" value="后退" onclick="javascript:history.back(1)" />		<p id="contact">Developed by SJHSTONE in 2014.</p>		</div>	</body></html>

データベース接続モジュール (dbconnect.php)
<?php	$dbc = mysqli_connect('localhost', 'mylibr', 'v3rubaGbdfSSTz88', 'libr')	  or die('无法链接到MySQL数据库');	mysqli_set_charset($dbc,'utf8');

データ書き込みモジュール ( insert.php)
<?php	/*初始连接数据库,连接变量$dbc*/	include 'dbconnect.php';		/*开始写入请求*/	$query1 = "INSERT INTO libr_metacode (meta_isbn, meta_cip) VALUES ('$isbn', '$cip')";	$result = mysqli_query($dbc,$query1)	  or die('无法写入数据块1');	$query2 = "INSERT INTO libr_title (meta_isbn, title, subtitle, series) VALUES ('$isbn', '$title', '$subtitle', $'series')";	$result = mysqli_query($dbc,$query2)	  or die('无法写入数据块2');	$query3 = "INSERT INTO libr_author (meta_isbn, creator, creator_id, creatorloc_id) VALUES ('$isbn', '$creator_1', '$creator_loc_id1')";	$result = mysqli_query($dbc,$query3)	  or die('无法写入数据块3');	/*作者2是否为空*/	if (!empty($creator_2)) {		$query4 = "INSERT INTO libr_author (meta_isbn, creator, creator_id, creatorloc_id) VALUES ('$isbn', '$creator_2', '$creator_loc_id2')";		$result = mysqli_query($dbc,$query4)		  or die('无法写入数据块4');	}	else {		echo '无写入的作者2信息,不写入数据块4';	}	mysqli_close($dbc);

$POST_[] グローバル変数から参照されるすべての値は、エコー時に正しく表示できます。
正常に接続して、13 桁の ISBN と 10 桁の CIP データを libr_metacode テーブルに書き込むことができます。
ただし、他のテーブルにデータを書き込むことはできません。

初期段階に含まれる 3 つのテーブル構造:
libr_metacode->meta_isbn char(13) 主键->meta_cip int(10)libr_title->meta_isbn char(13) 主键->title varchar(70)->subtitle varchar(50)->series varchar(30)libr_author (一对多)->rec_id int(5) 自动编号主键->creator varchar(30)->creatorloc_id int(3)


興味のある専門家は、http://sjhstone.name/book/sandbox.rar にアクセスして、ソース コードを参照して提案を得ることができます。パスワードは forcsdn (動作環境はローカル Windows) WampServer)

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

VALUES ('$isbn', '$cip')";

すべてエスケープ
addedlashes($isbn)
または
mysql_real_escape_string( $isbn)


または die('Unable to write data block 1'); のような形式を
または die('Unable to write data block 1' . mysqli_error($dbc)); に変更します。問題はどこにあるのかわかります


VALUES ('$isbn', '$cip')";

はすべてエスケープしてください
addslashes($isbn)
または
mysql_real_escape_string($isbn)

はすべてそうでない文字ですエスケープする必要があり、ローカルでのみテストされるため、当面はインジェクションを防ぐ必要はありません...
ありがとう!

のような形式を

または die('Unable to write data block 1'); のような形式に変更します

または die('Unable to write data block 1' . mysqli_error($dbc))
;問題は
このエラー修正関数をこれまで見たことがありません
ところで、参照用のコマンドの完全なリストはどこで見つけられますか

すべては PHP マニュアルに記載されています

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