Hacking_study/개발과제

6주차_(3) 회원 게시판 글 검색

jin_li 2023. 5. 31. 00:43
개발 순서

게시글 리스트 페이지에 검색 폼 추가 > 검색 처리 코드 추가

 

게시글 리스트 페이지에 다음과 같이 코드를 추가했다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <link rel="stylesheet" href="member2.css">
    <title>회원게시판</title>
</head>
<body>
    <h2>회원 게시판</h2>
        <div class="list">
            <!--게시글 검색 폼-->
            <form class="search-form" method="GET" action="">
                <input name ="search_keyword" type="text" placeholder="검색어를 입력하세요">
                <button type="submit">검색</button>
            </form>
            <table>
                <thead>
                    <tr>
                        <th>번호</th>
                        <th>제목</th>
                        <th>작성자</th>
                        <th>등록일</th>
                    </tr>
                </thead>
                <tbody>
                <?php
                    $conn = mysqli_connect("localhost""""""");
                    $sql = "SELECT * FROM memberboard order by board_num desc";
 
                    // 게시글 검색을 위한 추가 코드
                    $search_keyword = $_GET['search_keyword'] ?? '';
                    if (!empty($search_keyword)) {
                        $sql = "SELECT * FROM memberboard WHERE title LIKE '%$search_keyword%' OR username LIKE '%$search_keyword%' order by board_num desc";
                    }
 
                    $result = mysqli_query($conn$sql);
                    $total_record = mysqli_num_rows($result);
 
                    for ($i=0$i<$total_record$i++) {
                        mysqli_data_seek($result$i);
                        $row = mysqli_fetch_assoc($result);
 
                        $num = $row["board_num"];
                        $title = $row["title"];
                        $name = $row["username"];
                        $date = $row["wr_date"];
 
                        echo "<tr>";
                        echo "<td>{$num}</td>";
                        echo "<td><a href='member_view.php?num={$num}'>{$title}</a></td>";
                        echo "<td>{$name}</td>";
                        echo "<td>{$date}</td>";
                        echo "</tr>";
                    }
                    mysqli_close($conn);
                    ?>
                </tbody>
            </table>
    </div>
 
    <div class="buttons">
        <button onclick="location.href='member_list.php'">목록</button>
        <button onclick="location.href='member_form.php'">글쓰기</button>
    </div>
 
</body>
</html>
cs

 

12~15, 31~34 번 코드가 추가된 코드이다.

검색폼에 입력한 값에 대해 GET으로 받아와서, 입력값이 있으면 31~34번 코드에 의해 like 쿼리문이 실행된다.


31번 줄 맨 뒤의  ?? 부분은 입력값이 없는 경우 에러를 방지하기 위한 것으로, $_GET['search_keyword'] 값이 존재하지 않거나 null이라면 $search_keyword 변수에 빈 문자열('')을 할당한다.

 

 

 

(우) search_keyword 파라미터에 입력값을 받고 있음을 확인할 수 있다.