前提・実現したいこと
いつもお世話になっております。
PHPとHTMLを使っているのですが、
入力内容の確認ボタンを押すと、PHPで指定したsubmitボタンが押された時の処理を行いかつ次の画面(ここでいうとindex2.php)にPOSTで変数を送りたい。
該当のソースコード
php
1<?php 2session_start(); 3 // データベース接続 4 $dbUrl = parse_url(getenv('DATABASE_URL')); 5 $db['host'] = $dbUrl['host']; 6 $db['user'] = $dbUrl['user']; 7 $db['pass'] = $dbUrl['pass']; 8 $db['dbname'] = ltrim($dbUrl['path'], '/'); // データベース名 9 $dsn = sprintf('pgsql:host=%s;dbname=%s',$db['host'],$db['dbname']); 10 11 12try{ 13 $pdo = new PDO($dsn,$db['user'],$db['pass']); 14 15 $sql = "SELECT * FROM sample01"; 16 17 $res = $pdo->query($sql); 18 19 20}catch (PDOException $e){ 21 exit(mb_convert_encoding($e->getMessage(),'UTF-8','SJIS-win')); 22} 23 24$pdo = null; 25 26 // submitが押された時の処理 27 if(isset($_POST['submit'])){ 28 29 //ここでしたいのはnameの重複チェックですが 30 //エラーが出てまして未完成です 31 //DBと接続 32 $pdo = new PDO($dsn,$db['user'],$db['pass']); 33 //SQL文を準備 34 $sql = "SELECT * FROM sample3 WHERE name = :name"; 35 //インジェクション対策 36 $stmt = $pdo->prepare($sql); 37 //バインドする 38 $stmt->bindParam(':name', $ans[0]); 39 //SQLを実行 40 $stmt->execute(); 41 42 $user = $stmt->fetch(); 43 44 $_SESSION['name'] = $ans[0]; 45 46 47 header("Location: index2.php"); 48 } 49?> 50 51<!DOCTYPE html> 52<html lang="ja"> 53<head> 54 <meta charset="utf-8"> 55 <title>PHP TEST</title> 56</head> 57<body> 58 <form method="POST" action=""> 59 <table> 60 <?php foreach( $res as $value ): ?> 61 <tr> 62 <p> 63 <td> 64 <?php print htmlspecialchars($value[Question],ENT_QUOTES, "UTF-8"); ?> 65 </td> 66 <td> 67 : 68 </td> 69 <td> 70 <input type="text" name="ans[]" value=""> 71 <input type="hidden" name="res[]" value="<?php echo $value[Question] ?>"> 72 </td> 73 </p> 74 </tr> 75 <?php endforeach; ?> 76 </table> 77 <input type="submit" name="submit" value="入力内容を確認" /> 78 </form> 79</body> 80</html> 81
発生している問題・エラーメッセージ
1、
「入力内容を確認」ボタンを押したら、phpで指定したsubmitが押された時の処理を行う前にindex2.phpに画面遷移してしまう。
2、
試したこと
1、
処理が行われる前に画面遷移してしまう。ので
2、
jQuery
1$('button').on('click',function(e){ 2 e.preventDefault(); 3 $.ajax({ 4 ・・・略 5})
調べるとこれを使うと出たが、PHPではなくjQueryという別の言語みたい??
回答3件
あなたの回答
tips
プレビュー