Главная > MySQL | OpenServer | PHP | Базы данных | Сервера > Open Server, создание домена, базы данных и простого приложения на php

Open Server, создание домена, базы данных и простого приложения на php

23.01.2013 270 комментариев » Просмотры: 166 382
 

В этом посте я опишу, настройку домена, создание базы данных, и простого скрипта с использованием Open Server - платформы WAMP для веб разработчика. Итак поехали..

Давайте создадим новый тестовый домен, базу данных и подключимся к ней. Для этого, нажимаем правой кнопкой на флажок в трее, выбираем пункт "Папка с сайтами", открывается папка, в которой хранятся все данные по нашим доменам.

По-умолчанию путь этой директории: C:\Progr\OpenServer\domains\

Папка с доменами

Папка с доменами

Те кто работал до этого на Denwer-e не должны испытать трудностей с пониманием структуры. Тем кто не работал объясню: это корневая папка, в которой хранятся другие папки, название которых совпадает с именем домена по которому мы будем заходить.

Например, сразу после установки Open Server, мы можем зайти по адресу http://localhost

Проверка работы Open Server-а

Проверка работы Open Server-а

Так вот, скрипты которые запустятся, находятся именно в папке:
C:\Progr\OpenServer\domains\localhost\

Папка со скриптами домена localhost

Папка со скриптами домена localhost

 

Теперь мы хотим создать домен http://itrem, так же хотим создать базу itrem, подключиться к ней и выполнить какие-нибудь SQL команды.

Поехали по-порядку:

а) Создаем папку C:\Progr\OpenServer\domains\itrem\, она будет являться нашим доменом, т.е. http://itrem

Добавляем папку itrem

Добавляем папку itrem

б) В ней создаем файл index.php открываем его в редакторе, например в Notepad++, который можно запустить из контекстного меню Open Server-а, раздела "Офис"

Запуск Notepad++

Запуск Notepad++

и пишем в нем следующий, проверочный код

Создаем index файл в папке домена

Создаем index файл в папке домена

в) Перезапускаем сервер

Перезапуск Open Server-а

Перезапуск Open Server-а

в случае успешного запуска, в разделе "Мои сайты", вы увидите наш сайт itrem

Список доступных доменов

Список доступных доменов

Если же Вам не удалось увидеть список сайтов после проделанных манипуляций, попробуйте следующий вариант запуска: Open server, ограничение на работу с файлом hosts

г) Проверяем работу сайта в броузере, заходим по адресу: http://itrem

Проверка работы домена itrem в броузере

Проверка работы домена itrem в броузере

Обратите внимание, что в некоторых броузерах (например Chrome) необходимо задавать адрес включая название протокола ( т.е. http://itrem, а не itrem) иначе он просто перекинет вас на поиск гугла, с именем домена в качестве ключевого слова.

д) Входим в phpmyadmin.

Он находится по адресу: http://localhost/openserver/phpmyadmin/index.php (так же он доступен из контекстного меню OpenServer-а, пункт "Дополнительно>PhpMyAdmin")

Запуск phpMyAdmin

Запуск phpMyAdmin

Для авторизации используем такие данные:

  • пользователь/пароль = root / -пустой пароль-
  • пользователь/пароль = mysql / mysql

Можно использовать оба варианта, но я бы рекомендовал второй, а именно mysql/mysql, т.к. для супер пользователя не применяются некоторые настроенные конфиги, например не устанавливается автоматически  кодировка соединения с базой, поэтому при его использовании нужно дополнительно, в скриптах писать, что-то типа: mysql_query('SET NAMES "utf8"') либо использовать php функцию: mysql_set_charset('utf8').

Связанно это с тем, что суперпользователям не устанавливается кодировка, через параметр init-connect, который обычно прописывается в секции [mysqld], конфигурационного файла my.cnf (подробнее тут: 10.1.5. Configuring the Character Set and Collation for Applications). В данный момент именно так настроен OpenServer.

Так же, я писал пост, про то, как убрать авторизацию на совсем, пост тут: Openserver, phpmyadmin автовход

е) Создаем базу itrem

Создаем таблицу в phpMyAdmin

Создаем таблицу в phpMyAdmin

ж) Создаем таблицу messages

Создаем таблицу messages

Создаем таблицу messages

следующим шагом, указываем какие нам нужны поля (часть столбцов, я пропустил там оставляем значения по-умолчанию)

Создание структуры таблицы messages

Создание структуры таблицы messages

нажимаем Сохранить.

Если Вам проще будет выполнить SQL код (на вкладке SQL) можете просто его скопировать отсюда:

ж) пишем такой код, в файл C:\Progr\OpenServer\domains\itrem\index.php

Обратите внимание на кодировку файла, она должна быть "UTF-8 без BOM", проверить в Notepad++ это можно в верхнем меню, в разделе "Кодировки". При создании этого поста, я попался в эту ловушку, и долго не мог понять в чем проблема, подробнее тут: Openserver, MySQL, Notepad++ и пропадающая кириллица

Лучше использовать MySQLi, но в большинстве учебников пишут про работу именно с старыми MySQL функциями, поэтому тут используем именно такой код. Ознакомиться с MySQLi после изучения MySQL функций, можно, например тут: MySQLi раскладываем все по полочкам. У кого будет желание, перепишите этот скрипт на MySQLi, выложите на pastebin и пришлите мне ссылочку в комментарии - добавлю в пост с указанием вашего авторства :).

з) проверяем в броузере

Тестовый скрипт в броузере

Тестовый скрипт в броузере

На этом наш маленький тест закончился: мы создали новый домен, базу данных, таблицу в ней, а так же написали скрипт, который работает с этой базой данных.

Урааа!!!!!

--[добавлено 10.02.2014]--

Записал небольшое видео к данному уроку,  смотреть "на весь экран":

--[добавлено 03.08.2016]--

Добавил пост с скриншотами всех вкладок одной из последних версия Openserver: Список вкладок Openserver

Автор: | Теги: , ,

Важно

У нас заработал ФОРУМ. Все вопросы, которые не касаются статьи, а так же вопросы по конкретно вашему случаю нужно задавать и обсуждать именно там, в разделе "Помощь пользователям".

270 комментариев

Написать свой
  1. Инна Ответить
    25.07.2017 в 11:28 пп
    Добрый вечер!
    Помогите, пож-та, понять в чем проблема. В браузере почему-то не выполняются команды, которые задаются в редакторе, т.е. надпись 'Hello world", и другие команды, как в вашем примере отображается так:
    >?php //phpinfo(); echo '
    Hello,world!

    '; echo print '
    Hello!

    ' echo 'Здравствуйте!'; /* Многострочный комментарий */

    Пробовала переключать ctrl+U - выводится код страницы, как в редакторе, может это тоже какой-то "режим".
    Операции (сложения/вычитание и прочее) тоже не выполняет, просто выводит, как в редакторе, только за исключением html кодов, таких как , . Их выполняет. Не могу найти нигде решение этой проблемы.
    • Vitaliy Orlov
      Vitaliy Orlov Ответить
      26.07.2017 в 10:23 дп
      В приведенном примере, не верно открыт тег php скрипта, надо так (угловая кавычка в другую сторону):

      <?php
      echo 'Hello world';
  2. Евгений Ответить
    01.06.2017 в 7:22 дп
    Здравствуйте.Подскажите что очерёдность установки
    Оpen Server -phpmyadmin или наоборот? Я установил open_server_5_2_6_ultimate на диск С.Создалась папка.Запустил -нажимаю на вход -phpmyadmin- и вижу от это http://SSMaker.ru/d09a3820/ -Как это лечиться? скачал phpmyadmin последней версии распокавал в папку домена и не чего не происходит.Как запустить Оpen Server и phpmyadmin? В какую папку распаковывать phpmyadmin?
    • Vitaliy Orlov
      Vitaliy Orlov Ответить
      02.06.2017 в 9:32 дп
      Привет,
      1) В комплекте с openserver-ом уже идем phpmyadmin, дополнительно его ставить не обязательно
      2) Если же нужна установка, то просто создаешь домен и разархивируешь туда файл скачанный с сайта phpmyadmin. Там есть нюансы по натсройкам, но минимально уже все будет работать.
      3) Для того, чтобы открыть phpmyadmin который ставится с openserver, в трее нажми на значок Openserver и там посмотри, будет что-то типа "Tools" или "Инструменты"
      4) В случае ошибки, как на твоем скриншоте, нужно выбрать более новую версию php, делается это в настройках Openserver, на вкладке "Модули" (см картинку #3 тут)
  3. Давид Ответить
    29.05.2017 в 8:22 дп
    пожалуйста помогите,не могу понять почему функция header(Location)не работает,выдает ошибку: заголовок уже задан,но я нечего не прописывал.
    • Vitaliy Orlov
      Vitaliy Orlov Ответить
      29.05.2017 в 11:20 дп
      header можно использовать только ДО отправки какого-либо контента в браузер, т.е.:

      <?php
      echo '123';
      header(..)
      будет ошибка, надо делать так

      <?php
      // php код
      header(..)
      echo '123';
      если все и так по второму варианту, то проверь два момента: перед <?php не должно быть пробела и кодировка файла должна быть UTF-8 Without BOM или ASCII
      • Давид Ответить
        30.05.2017 в 9:29 дп
        дело в том что utf8 без вом выдает закарючки,вопросики,а utf 8 header не принимает,да и я все сделал как в видео,он все равно не хочет.
      • Давид Ответить
        30.05.2017 в 9:33 дп
        я даже проверил файл localhost,поменял надпись 'он работает' на другую он сразу начал выдавать ошибку,а в нем как раз пример php,в начале стоит header.
      • Давид Ответить
        30.05.2017 в 12:12 пп
        спс на этом примере получилось!!
      • Давид Ответить
        30.05.2017 в 12:13 пп
        utf8 без вом надо было
        • Vitaliy Orlov
          Vitaliy Orlov Ответить
          30.05.2017 в 12:17 пп
          Да, все правильно, "UTF-8 без BOM" (или на англ UTF-8 without BOM). Можешь в редакторе посмотреть, обычно можно поставить в опциях, создавать все новые файлы в UTF8 и открывать в UTF8. Например, есть такое в Notepad++. Один раз настраиваешь и все файлы создаются и открываются в правильном формате.
      • Давид Ответить
        30.05.2017 в 12:14 пп
        но в большом коде где много связок"include"почему то не получается
        • Vitaliy Orlov
          Vitaliy Orlov Ответить
          30.05.2017 в 12:20 пп
          возможно, где в инклудах, есть файл который либо выводит пробел, либо у него проблема с кодировкой - выход нужно искать где именно проблема, поочередно отключая или смотреть лог ошибок (или саму ошибку), там обычно пишется где был вывод сделан ранее.
          • Давид
            30.05.2017 в 12:27 пп
            создал отдельный файл setting.php туда закинул пароли базы данных,
            а в index.php прописал
            include_once 'setting.php';
            $CONNECT = mysqli_connect(HOST,USER,PASS,DB);а потом код предыдущий(header) выдает ошибку и отсылается почемуто на setting.php
          • Давид
            30.05.2017 в 1:02 пп
            очень странно,я нашел ошибку,все встало на свои места,просто не надо было setting отдельно ставить,функция include вызывала ошибку,пришлось пароли в index прописывать
          • Давид
            31.05.2017 в 1:23 пп
            а можете помочь,как сделать регистрацию на сайте через почту,на этом сервере??
          • Vitaliy Orlov
            Vitaliy Orlov
            02.06.2017 в 9:40 дп
            Я тебе вкратце напишу алгоритм:
            - делаешь табличку пользователей в базе, например с такой структурой: id, email, password, confirmed
            - делаешь форму регистрации
            - при отправке данных из формы:
            - - - создаешь пользователя в таблице, например: 1, test@test.com, abc, 0
            - - - формируешь письмо, в котором будет ссылка вида site.com/?confirm=$id&hash=$hash , $id - это номер в базе, хеш уникальный код, сгенерировать его можно например функцией md($id+$passowrd)
            - - - отправляешь письмо, например функцией mail
            - при переходе по ссылке, ищешь пользователя с указанным id, и сверяешь хеш. Если совпадает, значит почта подтверждена, меняешь в базе confirmed с 0 на 1

            Вот это краткий алгоритм. Демонстрационный пример, написать времени нет. И еще просьба, по таким вопросам писать на форум. Там будет твоя личная ветка, где будет удобнее задавать вопросы по разработке.
          • Давид
            03.06.2017 в 10:06 дп
            спасибо за помощь,буду знать теперь.
      • Давид Ответить
        30.05.2017 в 12:21 пп
        создаю страницу с регистрацией,мне надо сделать защиту от входа пустого логина и пороля, с помощью
        if ($p1 == 1) $p1 = 'ошибка';
        else if ($p1 == 2) $p1 = 'подсказка';
        else if ($p1 == 3) $p1 = 'информация';
        $_SESSION['message'] = ''.$p1.': '.$p2.'';
        exit(header('Location:'.$_SERVER['HTTP_REFERER']));
        но в последней строке ехит почему то выдает ошибку
  4. DobriyZhuk Ответить
    03.04.2017 в 5:56 пп
    Добрый день. Помогите, пожалуйста решить проблему. Установил OpenServer, флажок загорелся зеленый, кидаю любой сайт в корневую папку OpenServer или domains, сайты не открываются, пробовал по вашему примеру сделать пробный itrem, безуспешно. Выдается ошибка:
    Object not found!

    The requested URL was not found on this server. If you entered the URL manually please check your spelling and try again.

    If you think this is a server error, please contact the webmaster.

    Error 404

    localhost
    Apache
    Пробовал в hostе внемти данные сайты с ip 127.0.0.1 все равно безуспешно(((
  5. Евгений Ответить
    28.03.2017 в 9:58 пп
    Здравствуйте, дело в том что захожу через OS - Дополнительно - phpMyAdmin - і мне открывается только (http://127.0.0.1/openserver/phpmyadmin/index.php) а в нем единственное что показывает, так это только этот текст: PHP 5.5+ is required.
    Currently installed version is: 5.3.29
    . Подскажите пожалуйста как решить эту проблему..
    • Vitaliy Orlov
      Vitaliy Orlov Ответить
      29.03.2017 в 2:51 дп
      Зайди вот сюда Open Server, список вкладок. Найди там скриншот №3 (вкладка "Модули").
      Там есть выпадающий список "PHP", выбери там версию выше 5.5, сохрани настройки и перезагрузи опенсервер.
      P.S. В эти настройки, можно попасть, нажав на красный флажок в трее и выбрав пункт "Настройки".
  6. Сергей Ответить
    15.02.2017 в 1:56 пп
    Доброе время, Виталий.
    Не могу подключить базы ни одним способом, включая твой. Весь инет уже облазил.
    Все сделано как в статье выше, но выводит:
    Fatal error: Uncaught Error: Call to undefined function mysql_connect() in C:\OpenServer\domains\itrem\index.php:10 Stack trace: #0 {main} thrown in C:\OpenServer\domains\itrem\index.php on line 10
    Это как раз подключение $is_connected = @mysql_connect($db_host, $db_username, $db_password);
    Кроме Open Server нихрена не установлено. Может дополнительно чет поставить надо?
    Заранее признателен за помощь!
    • Vitaliy Orlov
      Vitaliy Orlov Ответить
      15.02.2017 в 4:48 пп
      В ошибке написано, что php не знает о функции mysql_connect. Всего скорее, это связанно с тем, что ты используешь версию php 7, а в нем данный набор функций удален навсегда. Исправить можно, либо выбрав версию php ниже 7 в настройках OpenServer-а, либо использовать современные функции, которые пришли на замену. Например, вместо mysql_connect использовать mysqli_connect.
  7. Алексей Ответить
    13.01.2017 в 6:35 дп
    У меня пишет разными закорючьками что делать?
    ����� ���������
    ���������
    �� ���� ����������� � ����� ������
    �� ���� ����� ���� ������
    • Vitaliy Orlov
      Vitaliy Orlov Ответить
      16.01.2017 в 8:26 пп
      1) Если это твоя страничка, измини в редакторе кодировку на UTF-8 Without BOM (например в Notepad++)
      2) Если не твоя страничка, тогда в браузере попробуй изменить кодировку на Windows-1251, UTF-8 или KOI8 всего скорее одна из них поможет.
      Затем, разберись почему страница не открывается в кодировке о которой думает браузер (чаще всего это UTF-8), возможно в странице отсутствует соответствующий meta тег (гугли "meta charset"), либо если это php скрипт, то неверно укзан заголовок (гугли "php header charset")
  8. Сергей Ответить
    09.01.2017 в 6:46 дп
    У меня при входе phpmyAdmin в браузере появляется надпись PHP 5.5+ is required.
    Currently installed version is: 5.3.29. Т.е. я не могу создать базу данных т.к. не появляется таблица с настройками
    • Vitaliy Orlov
      Vitaliy Orlov Ответить
      09.01.2017 в 5:30 пп
      Привет, есть несколько вариантов
      1) Если используешь Openserver, зайди в настройки и выбери версию PHP > 5.5
      2) Используй вместо phpmyadmin - Adminer (https://www.adminer.org):
      - Создаешь папку, например www/adminer/
      - Скачиваешь туда файлик с сайта и называешь его index.php
      - заходишь по адресу: site . com/adminer/index.php
      - вводишь имя пользователя базы и пароль
      3) Если пробуешь это сделать у себя на ПК и у тебя Windows, можешь скачать программу HeidiSQL(http://www.heidisql.com) и попробовать работать в ней.
  9. Александр Ответить
    01.11.2016 в 8:51 пп
    Был на форуме. Не понравилось. Поддержки нет. А вопрос то всего был как сделать свой сервер, вместо нескольких программ воспользоваться одним Open Server.
    • Vitaliy Orlov
      Vitaliy Orlov Ответить
      01.11.2016 в 9:35 пп
      На форуме, как и тут, я не отвечаю на просьбы написать мануал по интересующей тебя тематике. Попробуй поискать информацию самостоятельно, изучить готовые решения и реализации. Попробуй сам настроить. А вот когда столкнешься, с конкретной проблемой, тогда сформулируй её и создай тему, которая будет заключать в себе конкретный вопрос: описание того что ты хотел сделать, что сделал и где происходит ошибка и в чем она заключается.
  10. LILIYA Ответить
    15.08.2016 в 6:15 пп
    Наверное, я не в ту тему написала

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *

Разрешены HTML-теги: <a>, <code>, <i>, <em>, <strong>, <b>, <u>, <strike>