Заходи
Гость

Хостинг

Статистика
Яндекс.Метрика Счетчик PR-CY.Rank
Онлайн всего: 1
Гостей: 1
Пользователей: 0

Ccылки

Свежак

Главная » 2013 » Март » 31 » Создаем PHP гостевую книгу
15:53
Создаем PHP гостевую книгу

Создаем PHP гостевую книгу


Я расскажу, как можно создать AJAX, PHP гостевую книгу  с собственным уникальным дизайном. Наши данные будут сохранены в базе данных SQL. Эта таблица будет содержать следующую информацию: имя отправителя, адрес электронной почты, гостевая книга записей, дата и время записи и IP отправителя. Конечно, мы будем использовать JQuery тоже (чтобы сделать его AJAXy). Одной из важных особенностей будет защита от спама (можно отправлять  и по почте не более одной записи каждые 10 минут)!  

СМОТРЕТЬ ДЕМО                       СКАЧАТЬ ИСХОДНИК


 Шаг 1. SQL

Нам нужно добавить одну таблицу в нашей базе данных (для хранения наших записей):

CREATE TABLE IF NOT EXISTS `s178_guestbook` (

  `id` int(10) unsigned NOT NULL auto_increment,

  `name` varchar(255) default '',

  `email` varchar(255) default '',

  `description` varchar(255) default '',

  `when` int(11) NOT NULL default '0',

  `ip` varchar(20) default NULL,

  PRIMARY KEY  (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8;

Шаг 2. PHP

Вот исходный код нашего основного файла:

guestbook.php

<?php

// disabling possible warnings

if (version_compare(phpversion(), "5.3.0", ">=")  == 1)

  error_reporting(E_ALL & ~E_NOTICE & ~E_DEPRECATED);

else

  error_reporting(E_ALL & ~E_NOTICE);

 

require_once('classes/CMySQL.php'); // including service class to work with database

 

// get visitor IP

function getVisitorIP() {

    $ip = "0.0.0.0";

    if( ( isset( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) && ( !empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) ) {

        $ip = $_SERVER['HTTP_X_FORWARDED_FOR'];

    } elseif( ( isset( $_SERVER['HTTP_CLIENT_IP'])) && (!empty($_SERVER['HTTP_CLIENT_IP'] ) ) ) {

        $ip = explode(".",$_SERVER['HTTP_CLIENT_IP']);

        $ip = $ip[3].".".$ip[2].".".$ip[1].".".$ip[0];

    } elseif((!isset( $_SERVER['HTTP_X_FORWARDED_FOR'])) || (empty($_SERVER['HTTP_X_FORWARDED_FOR']))) {

        if ((!isset( $_SERVER['HTTP_CLIENT_IP'])) && (empty($_SERVER['HTTP_CLIENT_IP']))) {

            $ip = $_SERVER['REMOTE_ADDR'];

        }

    }

    return $ip;

}

 

// get last guestbook records

function getLastRecords($iLimit = 3) {

    $sRecords = '';

    $aRecords = $GLOBALS['MySQL']->getAll("SELECT * FROM `s178_guestbook` ORDER BY `id` DESC LIMIT {$iLimit}");

    foreach ($aRecords as $i => $aInfo) {

        $sWhen = date('F j, Y H:i', $aInfo['when']);

        $sRecords .= <<<EOF

<div class="record" id="{$aInfo['id']}">

    <p>Record from {$aInfo['name']} <span>({$sWhen})</span>:</p>

    <p>{$aInfo['description']}</p>

</div>

EOF;

    }

    return $sRecords;

}

 

if ($_POST) { // accepting new records

 

    $sIp = getVisitorIP();

    $sName = $GLOBALS['MySQL']->escape(strip_tags($_POST['name']));

    $sEmail = $GLOBALS['MySQL']->escape(strip_tags($_POST['name']));

    $sDesc = $GLOBALS['MySQL']->escape(strip_tags($_POST['text']));

 

    if ($sName && $sEmail && $sDesc && $sIp) {

 

        // spam protection

        $iOldId = $GLOBALS['MySQL']->getOne("SELECT `id` FROM `s178_guestbook` WHERE `ip` = '{$sIp}' AND `when` >= UNIX_TIMESTAMP() - 600 LIMIT 1");

        if (! $iOldId) {

 

            // allow to add comment

            $GLOBALS['MySQL']->res("INSERT INTO `s178_guestbook` SET `name` = '{$sName}', `email` = '{$sEmail}', `description` = '{$sDesc}', `when` = UNIX_TIMESTAMP(), `ip` = '{$sIp}'");

 

            // drawing last 10 records

            $sOut = getLastRecords();

            echo $sOut;

            exit;

        }

    }

    echo 1;

    exit;

}

 

// drawing last 10 records

$sRecords = getLastRecords();

 

ob_start();

?>

<div class="container" id="records">

    <div id="col1">

        <h2>Guestbook Records</h2>

        <div id="records_list"></div>

    </div>

 

    <div id="col2">

        <h2>Add your record here</h2>

        <script type="text/javascript">

        function submitComment(e) {

            var name = $('#name').val();

            var email = $('#email').val();

            var text = $('#text').val();

 

            if (name && email && text) {

                $.post('guestbook.php', { 'name': name, 'email': email, 'text': text },

                    function(data){

                        if (data != '1') {

                          $('#records_list').fadeOut(1000, function () {

                            $(this).html(data);

                            $(this).fadeIn(1000);

                          });

                        } else {

                          $('#warning2').fadeIn(2000, function () {

                            $(this).fadeOut(2000);

                          });

                        }

                    }

                );

            } else {

              $('#warning1').fadeIn(2000, function () {

                $(this).fadeOut(2000);

              });

            }

        };

        </script>

 

        <form onsubmit="submitComment(this); return false;">

            <table>

                <tr><td class="label"><label>Your name: </label></td><td class="field"><input type="text" value="" title="Please enter your name" id="name" /></td></tr>

                <tr><td class="label"><label>Your email: </label></td><td class="field"><input type="text" value="" title="Please enter your email" id="email" /></td></tr>

                <tr><td class="label"><label>Comment: </label></td><td class="field"><textarea name="text" id="text" maxlength="255"></textarea></td></tr>

                <tr><td class="label">&nbsp;</td><td class="field">

                    <div id="warning1" style="display:none">Don`t forget to fill all required fields</div>

                    <div id="warning2" style="display:none">You can post no more than one comment every 10 minutes (spam protection)</div>

                    <input type="submit" value="Submit" />

                </td></tr>

            </table>

        </form>

    </div>

</div>

<?

$sGuestbookBlock = ob_get_clean();

 

?>

<!DOCTYPE html>

<html lang="en" >

    <head>

        <meta charset="utf-8" />

        <title>PHP guestbook | Script Tutorials</title>

 

        <link href="css/main.css" rel="stylesheet" type="text/css" />

        <!--[if lt IE 9]>

          <script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>

        <![endif]-->

        <script src="http://code.jquery.com/jquery-latest.min.js"></script>

    </head>

    <body>

       

        <footer>

            <h2>PHP guestbook</h2>

            <a href="http://www.script-tutorials.com/php-guestbook/" class="stuts">Back to original tutorial on <span>Script Tutorials</span></a>

        </footer>

    </body>

</html>

Когда мы открываем эту страницу мы увидим книгу, на левой стороне мы будем выводить список трех последних записей, в правой - форма размещения новых записей. 

Классы / CMySQL.php

Это мой собственный класс сервис для работы с базой данных.  База данных, расположенных в этом классе в несколько переменных, убедитесь, что вы будете в состоянии настроить эту базу данных.  Доступные в исходнике.

Шаг 3. CSS

Теперь - все используемые CSS стилеи:

CSS / main.css

*{

    margin:0;

    padding:0;

}

body {

    background-color:#fff;

    color:#fff;

    font:14px/1.3 Arial,sans-serif;

}

footer {

    background-color:#212121;

    bottom:0;

    box-shadow: 0 -1px 2px #111111;

    display:block;

    height:70px;

    left:0;

    position:fixed;

    width:100%;

    z-index:100;

}

footer h2{

    font-size:22px;

    font-weight:normal;

    left:50%;

    margin-left:-400px;

    padding:22px 0;

    position:absolute;

    width:540px;

}

footer a.stuts,a.stuts:visited{

    border:none;

    text-decoration:none;

    color:#fcfcfc;

    font-size:14px;

    left:50%;

    line-height:31px;

    margin:23px 0 0 110px;

    position:absolute;

    top:0;

}

footer .stuts span {

    font-size:22px;

    font-weight:bold;

    margin-left:5px;

}

 

.container {

    background: transparent url(../images/book_open.jpg) no-repeat top center ;

    color: #000000;

    height: 600px;

    margin: 20px auto;

    overflow: hidden;

    padding: 35px 100px;

    position: relative;

    width: 600px;

}

#col1, #col2 {

    float: left;

    margin: 0 10px;

    overflow: hidden;

    text-align: center;

    width: 280px;

}

#col1 {

    -webkit-transform: rotate(3deg);

    -moz-transform: rotate(3deg);

    -ms-transform: rotate(3deg);

    -o-transform: rotate(3deg);

}

#records form {

    margin:10px 0;

    padding:10px;

    text-align:left;

}

#records table td.label {

    color: #000;

    font-size: 13px;

    padding-right: 3px;

    text-align: right;

}

#records table label {

    font-size: 12px;

    vertical-align: middle;

}

#records table td.field input, #records table td.field textarea {

    background-color: rgba(255, 255, 255, 0.4);

    border: 0px solid #96A6C5;

    font-family: Verdana,Arial,sans-serif;

    font-size: 13px;

    margin-top: 2px;

    padding: 6px;

    width: 190px;

}

#records table td.field input[type=submit] {

    background-color: rgba(200, 200, 200, 0.4);

    cursor: pointer;

    float:right;

    width: 100px;

}

#records table td.field input[type=submit]:hover {

    background-color: rgba(200, 200, 200, 0.8);

}

#records_list {

    text-align:left;

}

#records_list .record {

    border-top: 1px solid #000000;

    font-size: 13px;

    padding: 10px;

}

#records_list .record:first-child {

    border-top-width:0px;

}

#records_list .record p:first-child {

    font-weight:bold;

    font-size:11px;

}


СМОТРЕТЬ ДЕМО               СКАЧАТЬ ИСХОДНИК


Источник урока

Заключение

Сегодня мы подготовили PHP гостевую книгу  для вашего сайта. Несомненно, что этот материал будет полезен для ваших собственных проектов. Удачи вам в вашей работе!

Категория: PHP | Просмотров: 9065 | Добавил: Wrecker | Рейтинг: 0.0/0
Всего комментариев: 0
Добавлять комментарии могут только зарегистрированные пользователи.
[ Регистрация | Вход ]
Поиск

Статьи
[Прогараммирование]
Как работает CSS?
[Прогараммирование]
ЛЕКЦИЯ. Язык Pascal
[Прогараммирование]
Статический анализ: ошибки в медиаплеере и безглючная аська
[Устронение ошибок систем]
Устранение неполадок при возникновении (синего экрана) Blue Screen Of Death (BSOD) (2)
[Операционные системы]
Особенности применения технологий Lotus Domino и Notes в современных информационных системах
[Менеджмент]
Факторы микросреды организации
[Прогараммирование]
Разработка ПО с открытыми исходными текстами как особый вид прикладной науки
[Прогараммирование]
ПОДПРОГРАММЫ. ПРОЦЕДУРЫ И ФУНКЦИИ
[Прогараммирование]
Строковый тип данных
[Прогараммирование]
Подпрограммы

Категории
HTML/CSS [21]
jQuery/JS [36]
PHP [4]
Для Ucoz [38]

Популярный софт
Iron Kaspersky Internet Security 2015
Kaspersky Internet Security 2015
Iron Virtual DJ
Virtual DJ
Iron SoundForge 11
SoundForge 11
Iron Alcohol 120
Alcohol 120
Iron Norton Internet Security 2014
Norton Internet Security 2014
Iron Loaris Trojan Remover
Loaris Trojan Remover

Жми

Copyright MyCorp © 2024Конструктор сайтов - uCoz