inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

php 회원가입 db 질문 드립니다.

399

김지현

작성한 질문수 1

0

Fatal error: Uncaught Error: Undefined class constant 'MYSQL_ATTR_INIT_COMMAND' in C:\Apache24\htdocs\dbcon.php:8 Stack trace: #0 C:\Apache24\htdocs\index.php(2): include() #1 {main} thrown in C:\Apache24\htdocs\dbcon.php on line 8.
 
APM 환경에서 php로 회원가입을 구현하고 싶은데 위와 같은 오류가 뜹니다.
오류 문장에 언급된 php 파일 첨부합니다.. 찾아봐도 잘 안 나오고 뭐가 문제인지 모르겠습니다.
ㅇ위에서 말한 line 8은 아래입니다. 오래 붙잡았는데도 도저히 모르겠습니다.. 도와주시면 감사하겠습니다.
 
 $options = array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8');
 
dbcon.php
<?php

    $host = 'localhost';
    $username = '';
    $password = '';
    $dbname = 'userdb';

   $options = array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8');
   
    try {

        $con = new PDO("mysql:host={$host};dbname={$dbname};charset=utf8",$username, $password);
    } catch(PDOException $e) {

        die("Failed to connect to the database: " . $e->getMessage());
    }


    $con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $con->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);

    if(function_exists('get_magic_quotes_gpc') && get_magic_quotes_gpc()) {
        function undo_magic_quotes_gpc(&$array) {
            foreach($array as &$value) {
                if(is_array($value)) {
                    undo_magic_quotes_gpc($value);
                }
                else {
                    $value = stripslashes($value);
                }
            }
        }
 
        undo_magic_quotes_gpc($_POST);
        undo_magic_quotes_gpc($_GET);
        undo_magic_quotes_gpc($_COOKIE);
    }
 
    header('Content-Type: text/html; charset=utf-8');
    session_start();
?>
 
index.php
 
<?php
    include('dbcon.php');
    include('check.php');

    if(is_login()){

        if ($_SESSION['user_id'] == 'admin' && $_SESSION['is_admin']==1)
            header("Location: admin.php");
        else
            header("Location: welcome.php");
    }
?>

<!DOCTYPE html>
<html>
<head>
    <title>로그인 예제</title>
    <link rel="stylesheet" href="bootstrap/css/bootstrap1.min.css">
</head>


<body>

<div class="container">

    <h2 align="center">로그인</h2><hr>
    <form class="form-horizontal" method="POST">
        <div class="form-group" style="padding: 10px 10px 10px 10px;">
            <label for="user_name">아이디:</label>
            <input type="text" name="user_name"  class="form-control" id="inputID" placeholder="아이디를 입력하세요."
                required autocomplete="off" readonly onfocus="this.removeAttribute('readonly');" />
        </div>
        <div class="form-group" style="padding: 10px 10px 10px 10px;">
            <label for="user_password">패스워드:</label>
            <input type="password" name="user_password" class="form-control" id="inputPassword" placeholder="패스워드를 입력하세요."
                required  autocomplete="off" readonly onfocus="this.removeAttribute('readonly');" />
        </div>
        <div class="checkbox">
            <label><input type="checkbox"> 아이디 기억</label>
        </div>
        </br>
        <div class="from-group" style="padding: 10px 10px 10px 10px;" >
            <button type="submit" name="login" class="btn btn-success">로그인</button>
            <a class="btn btn-success" href="registration.php" style="margin-left: 50px">
            <span class="glyphicon glyphicon-user"></span>&nbsp;등록
            </a>
        </div>
        </br>
    </form>
</div>
</body>
</html>


<?php

    $login_ok = false;

    if ( ($_SERVER['REQUEST_METHOD'] == 'POST') and isset($_POST['login']) )
    {
        $username=$_POST['user_name'];  
        $userpassowrd=$_POST['user_password'];  

        if(empty($username)){
            $errMSG = "아이디를 입력하세요.";
        }else if(empty($userpassowrd)){
            $errMSG = "패스워드를 입력하세요.";
        }else{
           

            try {

                $stmt = $con->prepare('select * from users where username=:username');

                $stmt->bindParam(':username', $username);
                $stmt->execute();
               
            } catch(PDOException $e) {
                die("Database error. " . $e->getMessage());
            }

            $row = $stmt->fetch();  
            $salt = $row['salt'];
            $password = $row['password'];
           
            $decrypted_password = decrypt(base64_decode($password), $salt);

            if ( $userpassowrd == $decrypted_password) {
                $login_ok = true;
            }
        }

       
        if(isset($errMSG))
            echo "<script>alert('$errMSG')</script>";
       

        if ($login_ok){

            if ($row['activate']==0)
                echo "<script>alert('$username 계정 활성이 안되었습니다. 관리자에게 문의하세요.')</script>";
            else{
                    session_regenerate_id();
                    $_SESSION['user_id'] = $username;
                    $_SESSION['is_admin'] = $row['is_admin'];

                    if ($username=='admin' && $row['is_admin']==1 )
                        header('location:admin.php');
                    else
                        header('location:welcome.php');
                    session_write_close();
            }
        }
        else{
            echo "<script>alert('$username 인증 오류')</script>";
        }
    }
?>
 
 

apache mysql db php 서버

답변 0

유튜브 시연 영상 추가 기능 강의 업로드 계획

0

15

1

DB 설계와 JPA 관련 질문입니다

0

23

1

관리자 페이지 질문

0

21

1

드랍 테이블로 지운 ordes에 대해서 질문

0

27

1

문제 풀이 1번 질문

0

31

1

twitterdb 연결이 안돼요

1

30

2

Kafka Cluster 구성도 질문

0

24

1

아주 작은 정오표 전달드립니다.

0

59

2

mysql워크벤치를 실행할때마다 오류가 뜹니다. 해결 방법좀 가르켜주세요.

0

53

1

실제로 작은 기업에서 기획 롤

1

30

1

이제 인프런에서 강의 더 안산다. 후져....

0

47

2

order_product 까마귀발

0

45

2

소스코드 어디서 다운받아요?

0

63

5

답을언제쯤받아볼수있나요

0

57

2

공통 코드 , 계층 구조 질문

1

40

1

프로젝트가 없어요..

0

63

2

구글 서치콘솔 도메인 소유권 확인 실패

0

47

2

소스코드 빈 파일 문의드려요

0

49

2

[DB설계] 탈퇴 유저의 구독 정보 유지 및 이메일 마스킹 관련 질문입니다.

0

55

1

자연키 vs 대리키 실무질문

0

28

1

SQL 기본 문법

0

48

2

프로젝트 의존 관계

0

53

2

1:N 관계에서 중간테이블 (연관엔티티)

0

58

2

뉴스페이퍼 싱글템플릿 모바일 화면 디자인 질문

0

43

2