現在、PHPで簡易掲示板を作っています。
そこで、投稿一覧のページから編集ボタンを押した際に、ログインをしていれば、編集の画面に飛べて、ログインしていない場合は投稿一覧の画面に戻るような機能をつけたいと思っています。
投稿一覧が「admin.php」で編集画面が「edit.php」です。
しかし、「admin.php」上で、ログインした上で編集ボタンを押しても、もれなく「edit.php」から「admin.php」に戻されてしまいます。
うまくログインしている際は「edit.php」に留まって欲しいです。
ps.
session_start()を追加しました。
PHPマニュアルの使い方は分からず、まだ挙動の確認は出来てないです。
以下、「edit.php」のコードです。
php
1 2<?php 3 4var_dump($_SESSION); 5exit(); 6 7$comment_id = null; 8$mysqli = null; 9$sql = null; 10$res = null; 11 12$link= mysqli_connect("localhost","root","root","keijiban"); 13 14date_default_timezone_set('Asia/Tokyo'); 15 16** 17session_start(); 18 19$_SESSION[‘admin_login’] = true; 20 21** 22 23if( empty($_SESSION['admin_login']) || $_SESSION['admin_login'] !== true ) { 24 25 // ログインページへリダイレクト 26 header("Location: ./admin.php"); 27} 28 29 30 31if( !empty($_GET['comment_id'])&& empty($_POST['comment_id']) ) { 32 33 $comment_id = (int)htmlspecialchars($_GET['comment_id'], ENT_QUOTES); 34 35 // データベースに接続 36 $mysqli = new mysqli( "localhost","root","root","keijiban"); 37 38 // 接続エラーの確認 39 if( $mysqli->connect_errno ) { 40 $error_message[] = 'データベースの接続に失敗しました。 エラー番号 '.$mysqli->connect_errno.' : '.$mysqli->connect_error; 41 } else { 42 43 // データの読み込み 44 $sql = "SELECT * FROM comment WHERE id = $comment_id"; 45 $res = $mysqli->query($sql); 46 47 if( $res ) { 48 $arrayData = $res->fetch_assoc(); 49 } else { 50 51 // データが読み込めなかったら一覧に戻る 52 header("Location: ./admin.php"); 53 } 54 55 $mysqli->close(); 56 } 57 58} elseif( !empty($_POST['comment_id']) ) { 59 60 61 62} 63 64 65?> 66 67<!DOCTYPE html> 68<html lang="ja"> 69<head> 70<meta charset="utf-8"> 71<title>てりー掲示板 管理ページ(投稿の編集)</title> 72<style> 73 74.btn_cancel { 75 display: inline-block; 76 margin-right: 10px; 77 padding: 10px 20px; 78 color: #555; 79 font-size: 86%; 80 border-radius: 5px; 81 border: 1px solid #999; 82} 83.btn_cancel:hover { 84 color: #999; 85 border-color: #999; 86 text-decoration: none; 87} 88 89</style> 90</head> 91<body> 92<h1>てりー掲示板 管理ページ(投稿の編集)</h1> 93<?php if( !empty($error_message) ): ?> 94 <ul class="error_message"> 95 <?php foreach( $error_message as $value ): ?> 96 <li>・<?php echo $value; ?></li> 97 <?php endforeach; ?> 98 </ul> 99<?php endif; ?> 100<div class="container"> 101 102 <form method="post"> 103 <div class="form-group"> 104 <label for="form-mail">ユーザー名</label> 105 <input type="username" class="form-control" name="username" placeholder="てりー" value="<?php if( !empty($arrayData['username']) ){ echo $arrayData['username']; } ?>"> 106 </div> 107 <div class="form-group"> 108 <label for="exampleInputComment">コメント</label> 109 <input type="comment" class="form-control" name="comment" placeholder="自由に投稿!" value="<?php if( !empty($arrayData['comment']) ){ echo $arrayData['comment']; } ?>"> 110 </div> 111 <a class="btn_cancel" href="admin.php">キャンセル</a> 112 <button type="submit" class="btn btn-primary">更新</button> 113 <input type="hidden" name="comment_id" value="<?php echo $arrayData['id']; ?>"> 114 </form> 115 116</div> 117</body> 118</html>
回答2件
あなたの回答
tips
プレビュー