Как сделать сайт на php

Создание сайта с нуля Php и MySQL — пошагово для новичка

Основная часть <\p>

Важно! Как видно из исходного кода подключаются эти файлы при помощи команды:

require_once .

Рассмотрим каждый из подключаемых файлов в отдельности. Каждый из них отвечает за отдельную часть интернет-проекта. Их может быть любое количество. Все зависит от задач, которые интернет-проект будет выполнять. Рассмотрим эти файлы подробнее.

Head

Внимательный читатель заметил, что этого файла нет в схеме шаблона интернет-проекта. Давайте рассмотрим почему. В него прописываются мета-теги, подключаемые стили, фавикон и скрипты которые планируется использовать. Эта информация повторяется на каждой странице блога, поэтому логично вынести ее в отдельный файл. Он может выглядеть так:

Top

Рассмотрим, из чего состоит шапка созданного интернет-проекта. Обычно сюда добавляют логотип, способы связи, рекламу и прочее. Он может выглядеть так:

 
Название

Контактные данные

Реклама

Название Контактные данные Реклама<\p>

Левая колонка

В файле sidebar1.php, расположенном слева, поместите меню блога, ссылки на полезные для читателя материалы и рекламу. Он может иметь такой вид:

Меню

Ссылки на интересный контент

Реклама

Меню Ссылки на интересный контент Реклама<\p>

В файле сайтбара размещается информация которая отображается справа нашего макета. В нем тоже может располагаться меню, ссылки и популярные записи пользователей. Он выглядит так:

Метки

Ссылки на популярные материалы

Метки Ссылки на популярные материалы<\p>

Подвал сайта

Самая нижняя часть на странице называется footer.php. Она, так же, как и шапка, повторяется на всех страницах интернет-проекта. В нем разместите контактную информацию, копирайт, счетчик посещений, иконки соцсетей, ссылки на разделы интернет-проекта. Код может выглядеть так:

Ссылки на категории

Коды счетчиков

Ваши контакты

Ссылки на категории Коды счетчиков Ваши контакты<\p>

Вот так может выглядеть блог, написанный на php. Это простой вариант, потому что не предусматривает работу c БД, и называется модифицированной версией html-сайта.

Начинающий вебмастер подумает, а что еще посмотреть по этой теме? Рекомендую вам ознакомиться с интересными курсами Русакова, изучив которые вы сможете самостоятельно создавать движки для интернет-проектов и онлайн магазины.

Остались еще вопросы. Посмотрите эти видеоуроки.

Вывод

Используйте рекомендации, описанные выше, и вы сможете создать самостоятельно профессиональный интернет-проект. Рекомендую вам посетить портал программистов GeekBrains.ru где тоже есть много полезной информации.

Сегодня мы поговорили про создание блога на php с нуля. Многим может показаться что процесс создания динамического сайта очень сложен, но это не совсем так. Главное — желание и целеустремленность. Подписывайтесь на мою группу ВКонтакте, в ней тоже есть что посмотреть.

Источник: https://start-luck.ru/sozdanie-sayta/s-nulya-php.html

Создание PHP+MySQL сайта: от простого к сложному — шаг первый

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

Это процесс нелёгкий, требует определённых базовых знаний PHP и MySQL, но если его рассмотреть по пунктам — то можно составить своего рода «рабочий план», который пригодится при создании новых сайтов. Подготовим «ядро» и базу для проекта.

Вначале это будет обычный сайт визитка, но потом, добавляя функционал, его можна превратить во что угодно. Итак, приступим.

1. Подготовка базы данных. Создаём первую таблицу в БД MySQL

Создаём новую базу данных, например «mysite».

Лично я привык работать с кодировкой UTF-8, по-этому сразу оговорюсь: проследите, чтобы все текстовые файлы сайта, сама база, таблицы и поля таблиц были в одной кодировке.
В новой базе делаем таблицу.

Назовём её «pages». В этой таблице будут храниться статические страницы будущего сайта и информация о них. Таблица должна содержать следующие поля:

  • page_id — идентификатор страницы (SMALLINT, primary key, auto_increment);
  • page_alias — псевдоним страницы для строки адреса ЧПУ (VARCHAR, 255);
  • page_title — название страницы в окне браузера (VARCHAR, 255);
  • page_meta_d — мета описание страницы для тега meta description (VARCHAR, 255);
  • page_meta_k — мета ключевые слова для тега meta keywords (VARCHAR, 255);
  • page_h1 — заголовок страницы (VARCHAR, 255);
  • page_s_desc — краткое описание материала, например если материалы сайта будут в виде блога (TEXT);
  • page_content — основной текст страницы, который будет выводиться в центральную колонку сайта (TEXT);
  • page_publish — содержит «Y» — если страница опубликована, или «N» — если она скрыта (CHAR, по умолчанию «Y»).

Сразу после создания таблицы вставляем в неё значения для главной страницы сайта. В поле «page_alias» для главной страницы предлагаю вставить значение «home». Метатеги — соответственно тематике всего сайта. Таким же образом можно посоздавать другие страницы, например «О компании» с алиасом «about» и своими метатегами, или «Контакты» с алиасом «contacts» и т.д.

2. Создаём файл конфигурации сайта

В корневой папке сайта, которая должна быть пуста на данном этапе, создаём папочку «cfg», в ней с помощью .htaccess закрываем доступ директивой «deny from all». Создаём файл core.php следующего содержания:

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

В корневой папке также должны быть папки «css» и «images» для элементов дизайна. В файле /css/style.css — можно настроить стили по своему усмотрению.

7. Чистые ссылки и файл .htaccess

Для создания чистых ссылок я использую mod_rewrite с прямыми указаниями правил для каждого компонента отдельно, так как разбор адресной строки средствами самого контроллера считаю излишним функционалом. Содержимое .htaccess на данном этапе такое:

RewriteEngine On RewriteBase / RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !-f # ЗАПРЕЩЁННЫЕ ФАЙЛЫ RewriteRule .htaccess — [F] RewriteRule template.php — [F] # ПРАВИЛА mod_rewrite RewriteRule page/([a-z0-9_-]+)([/]{0,1}).htm$ index.php?option=page&alias=$1 [L]

В будущем мы будем дописывать правила для компонентов поиска, каталога, блога статей и т.д. Смысл один: преобразовать ссылки вида «mysite.com/index.php?option=pages&alias=about» в ссылку вида «mysite.com/pages/about.

Обратите внимание

htm» — смотрится довольно красиво. Старайтесь в разработке избегать массива $_GET в целях безопасности и не надеяться на него.

Целесообразно хранить в нём только параметры для главного контроллера (переменная $option) и для компонента (переменная $alias).

Также в каждой папке сайта «на всякий случай» создайте пустой файл index.html — это нужно для того, чтобы при обращении к каталогу через адресную строку ничего не отображалось.

Источник: https://habr.com/sandbox/14484/

Строим свою CMS на PHP и MySQL. Часть 1

  • Главная»
  • Уроки»
  • PHP»
  • Строим свою CMS на PHP и MySQL. Часть 1
  • Метки урока:
  • php
  • кодинг
  • web дизайн

Задача построения системы управления содержанием (CMS) может привести в замешательство новичка разработчика PHP.

Но не так страшен черт, как его малюют! В данной серии уроков мы построим простую, но полностью работоспособную систему с нуля.

В ходе процесса вы научитесь создавать базы и таблицы MySQL, работать с объектами, константами, включениями, сессиями и прочими инструментами PHP. Кроме того мы покажем, как отделять логику приложения от презентации и сделать код PHP более безопасным. А также вам откроется многое другое, полезное в деле создания собственной системы мечты.

Вы можете посмотреть работу готового приложения на странице демонстрации (с целью безопасности включен режим «только чтение», так что добавлять, изменять и удалять статьи не получится). Также можно скачать полный код PHP нашей меленькой CMS с переведенными комментариями.

Примечание: для изучения материалов уроков потребуется веб сервер Apache с установленным модулем PHP и сервер MySQL. Для работы на локальном компьютере можно воспользоваться одним из инструментов веб разработчика: XAMPP (на английском языке), Denwer, Open server или другим.

Функционал нашей CMS

Первым делом надо точно определиться, что будет делать наша CMS. Итак, вот список функций:

Клиентская часть:

  • Главная страница, на которой выводиться список последних 5 статей
  • Страница со списком всех статей
  • Страница просмотра отдельной статьи

Серверная часть:

  • Вход/выход для администратора
  • Список всех статей
  • Добавление новой статьи
  • Редактирование существующей статьи
  • Удаление существующей статьи

Каждая статья имеет собственный заголовок, резюме и дату публикации.

Планирование работ

Для создания нашей CMS нужно сделать следующие шаги

  1. Создать базу данных
  2. Создать таблицу articles
  3. Сделать файл конфигурации
  4. Построить класс Article
  5. Написать скрипт клиентской части index.php
  6. Написать скрипт серверной части admin.php
  7. Создать шаблон клиентской части
  8. Создать шаблон серверной части
  9. Создать таблицу стилей и логотип системы

Примечание: на страницах уроков приводится код для нашей CMS готовый к копированию в ваши текстовые файлы. Если у вас нет желания создавать файлы самостоятельно, то можно скачать архив с исходниками, в котором содержатся все нужные папки и файлы.

Шаг 1. Создаем базу данных

На первом шаге нужно создать базу данных MySQL для хранения содержания. Можно сделать так:

  1. Запускаем программу клиент  mysql Открываем окно терминала и набираем команду

    mysql -u username -p

    После запроса введите пароль для доступа к MySQL.

    username — имя пользователя, который имеет полномочия для создания баз данных. В случае работы на локальном компьютере можно использовать root, хотя для безопасности всегда следует создавать пользователя с другим именем для решения задач администрирования.

  2. Создаем базу данных После метки mysql> вводим:

    create database cms;

    И нажимаем Enter.

  3. Выходим из программы клиента mysql После метки mysql> вводим:

    exit

    И нажимаем Enter.

Теперь у нас есть пустая база данных, в которой можно размещать таблицы и содержание.

Для решения такой задачи также можно воспользоваться инструментами для администрирования баз данных, таким как phpMyAdmin, cPanel или Plesk (если они установлены на вашем сервере). В некоторых случаях использование подобных инструментов является единственным доступным для пользователя инструментом для работы с базами данных (ситуация зависит от правил, установленных на вашем хостинге).

Наша простая CMS имеет единственную таблицу в базе данных: articles. В ней содержатся все статьи в нашей системе.

Создадим схему таблицы. Схема таблицы описывает типы данных, которые могут содержаться в таблице и информацию о ней.

Создаем текстовой файл tables.sql на жестком диске и добавляем в него следующий код:

DROP TABLE IF EXISTS articles; CREATE TABLE articles ( id smallint unsigned NOT NULL auto_increment, publicationDate date NOT NULL, # Когда статья опубликована title varchar(255) NOT NULL, # Полный заголовок статьи summary text NOT NULL, # Резюме статьи content mediumtext NOT NULL, # HTML содержание статьи PRIMARY KEY (id) );

Выше приведенный код определяет схему таблицы articles. Он написан на SQL, языке для создания и манипулирования базами данных в MySQL (и во многих других системах).

Разберем выше приведенный код

  1. Создаем таблицу articles Выражение DROP TABLE IF EXISTS articles удаляет любую существующую таблицу articles  (вместе с данным — осторожно!). Мы выполняем данную операцию чтобы в базе не было двух таблиц с одинаковыми именами. Выражение CREATE TABLE articles ( ) создает новую таблицу articles. Код, размещенный в скобках, определяет структуру данных в таблице…
  2. Определяем для каждой статьи уникальный ID Теперь можно определять структуру таблицы. Таблица состоит из набора полей (также их называют столбцами). Каждое поле содержит опредленный тип информации о статье. Сначала мы создаем поле id. Оно имеет тип smallint unsigned (без знаковое маленькое целое), то есть число от 0 до 65,535. Таким образом, наша CMS может содержать до 65,535 статей. Также для него определяется атрибут NOT NULL, который означает, что поле не может быть пустым (null). Данное свойство существенно облегчает труд разработчика. Добавляем атрибут auto_increment, который указывает MySQL назначать новое, уникальное значение для поля id при создании записи. Итак, первая статья будет иметь id  1, вторая — id  2, и так далее. Мы будем использовать уникальные значения как указатели на статью при выводе и редактировании в CMS.
  3. Добавляем поле publicationDate Следующая строка создает поле publicationDate, которое хранит дату публикации каждой статьи. Данное поле имеет тип date, соответствующий значениям дат.
  4. Добавляем поле title Теперь создаем поле title, в котором размещается заголовок. Оно имеет тип varchar(255), то есть может хранить строку длиной до 255 символов.
  5. Добавляем поля summary и content Последние два поля 2, summary и content, содержат резюме статьи (краткое описание материала) и HTML содержание соответственно. Резюме имеет тип text (то есть, может состоять из 65,535). А поле content имеет тип mediumtext (то есть может содержать до 16,777,215).
  6. Добавляем основной ключ Последняя строка в выражении CREATE TABLE определяет ключ для таблицы. Ключ также называют индексом, и он служит для быстрого поиска данных в таблице за счет некоторого увеличения требующегося пространства для хранения. Мы определяем поле id как PRIMARY KEY. Каждая таблица может содержать единственный PRIMARY KEY, так как данный ключ уникально определяет каждую запись в таблице. Кроме того, с помощью данного ключа MySQL очень быстро находит нужную запись.

Теперь у нас есть схема таблицы и ее нужно загрузить в MySQL для создания структуры. Самый простой способ — открыть окно терминала, перейти к папке с файлом tables.sql и запустить следующую команду:

mysql -u username -p cms < tables.sql

…где username — имя пользователя MySQL, а cms — имя базы данных, которую мы создали на шаге 1.

Вводите пароль пользователя после запроса, и MySQL загрузит и выполнит код из файла tables.sql, создав таблицу articles в базе данных cms.

Также можно воспользоваться инструментами для администрирования баз данных, таким как phpMyAdmin, cPanel или Plesk (если они установлены на вашем сервере).

Важно

Теперь  у нас есть база данных и мы готовы разрабатывать код PHP. Начнем с создания файла конфигурации для хранения различных установок для нашей CMS. Данный файл будет использоваться остальными скриптами нашей системы.

Первым делом создаем папку cms в папке веб сервера. Она будет содержать все файлы нашей CMS.

В папке cms создаем файл config.php и копируем в него следующий код:

Разберем код подробно:

  1. Выводим ошибки в браузере Строка ini_set() устанавливает режим вывода сообщений об ошибках в браузере. Отличная опция для отладки кода, но на готовом проекте данную опцию надо отключить ( установить значение false) для безопасности ресурса.
  2. Устанавливаем временную зону Так как наша CMS будет использовать функцию PHP date(), нужно указать временную зону сервера для PHP (иначе PHP будет генерировать предупреждение). В примере установлена зона «Australia/Sydney» — поменяйте на свою.
  3. Устанавливаем детали доступа к базе данных Затем определяем константу DB_DSN, которая указывает PHP, где искать базу данных MySQL. Параметр dbname должен соответствовать имени базы данных нашей CMS (cms). Также мы будем хранить имя пользователя MySQL и пароль, которые используются для доступа к базе данных CMS в константах DB_USERNAME и DB_PASSWORD. Установите правильные значения в данных константах, которые соответствуют вашим настройкам.
  4. Устанавливаем пути Мы устанавливаем 2 пути в нашем файле конфигураций: CLASS_PATH, который указывает на место хранения файлов классов, и TEMPLATE_PATH, который указывает на место хранения шаблонов  HTML. Оба пути указываются относительно верхнего каталога cms.
  5. Устанавливаем количество статей, выводимых на главной странице HOMEPAGE_NUM_ARTICLES управляет максимальным количеством заголовков статей, которые выводятся на главной странице. Мы установили 5, но можно легко увеличить или уменьшить значение.
  6. Устанавливаем имя и пароль администратора Константы ADMIN_USERNAME и ADMIN_PASSWORD содержат данные регистрации для администратора нашей CMS.
  7. Включаем класс Article Так как файл класса Article (мы его создадим позже) требуется во всех скриптах нашего приложения, добавим его здесь.
  8. Создаем обработчик исключительных ситуаций В завершение определяем handleException() — простую функцию для обработки исключений PHP, которые могут генерироваться при выполнении кода. Данная функция выводит общее сообщение об ошибке и записывает данные об ошибке в журнал веб сервера. Такая функция способствует улучшению безопасности системы за счет обработки исключений PDO, которые могут выводить имя пользователя и пароль на странице. После определения функции handleException(), мы устанавливаем ее как обработчик исключений PHP, вызывая функцию set_exception_handler().

    Такой обработчик исключений сделан для упрощения материалов урока. «Правильный» способ для обработки исключений для перехвата всех вызовов PDO в  Article.php заключается в использовании блоков try … catch.

  9. В реальных проектах лучше помещать config.php где-нибудь за пределами корневого каталога веб сайта, так как в файле содержатся имена и пароли. Обычно код PHP невозможно просмотреть в браузере, но иногда из-за неправильной конфигурации веб сервера код становится доступным.

    Вы можете использовать функцию hash() для хэширования паролей и хранить в config.php хэши, вместо текстовых паролей. Затем при регистрации пользователя можно опять воспользоваться функцией hash() для кодирования введенного пароля и сравнения результата с сохраненным в  config.

    php хэшем.

В следующем уроке мы построим основной класс нашего приложения — Article.

  • Когда речь идёт о безопасности веб-сайта, то фраза «фильтруйте всё, экранируйте всё» всегда будет актуальна. Сегодня поговорим о фильтрации данных.
  • Обеспечение безопасности веб-сайта — это не только защита от SQL инъекций, но и протекция от межсайтового скриптинга (XSS), межсайтовой подделки запросов (CSRF) и от других видов атак. В частности, вам нужно очень осторожно подходить к формированию HTML, CSS и JavaScript кода.
  • Expressive 2 поддерживает возможность подключения других ZF компонент по специальной схеме. Не всем нравится данное решение. В этой статье мы расскажем как улучшили процесс подключение нескольких модулей.

Источник: https://ruseller.com/lessons.php?id=1582

8 веских причин сделать сайт на PHP

CodeNet / Языки программирования / PHP

Автор: Руслан Богданов
26 августа 2008 года

В наше время многие пользователи Интернета превращаются в его строителей. Насмотревшись на чужие сайты, простой интернетчик начинает задумываться и о собственном «офисе» в этом мегаполисе.

Но как? В какой программе? На каком языке?

Именно на последний вопрос даёт развёрнутый ответ эта статья.

А поскольку Вы её читаете, то видимо тоже заинтересованы в создании своего сайта.

На HTML (это простой язык разметки и оформления содержания сайта) можно написать несложный сайт-визитку или домашнюю страничку. Но хорошим сайтам свойственно расти, и для чего-то более сложного (и доходного!) Вам непременно понадобится более сложный язык.

Так что рано или поздно Вам придётся переводить свой уже готовый сайт на новый язык. Не лучше ли сделать это с самого начала?

Для этого Вам как нельзя лучше подойдёт язык PHP. Давайте рассмотрим его со всех сторон:

1. Это очень простой язык и хорошо совмещается с другими языками программирования

Язык PHP (англ. PHP: Hypertext Preprocessor — «PHP: Препроцессор Гипертекста») действительно прост для изучения и понимания, особенно для тех, кто уже сделал свой небольшой сайт на HTML или на худой конец проходил на уроках информатики Паскаль или Бейсик.

В то же время это весьма мощный язык программирования. Он разработан для создания сайтов любой степени сложности. На нём можно написать как сайт-визитку, так и целый интернет-магазин.

В основу PHP легли языки C, Java и Perl. Он поддерживает обмен данными практически между всеми языками, на которых пишутся сайты.

2. С ним очень легко начать

Для начала достаточно просто дать всем файлам расширение .php вместо .htm или .html. И даже если в них не будет ни одной команды PHP, они всё равно будут работать.

Команды PHP Вы можете добавлять по мере изучения языка.

Это также поможет в будущем не потерять ссылки на Ваш сайт с других сайтов. Ведь если, к примеру, на чужом сайте стоит ссылка на Вашу страницу

http://www.bestfree.ru/article/webdesign/ssi.html ,

а Вы решите поменять её расширение на .php:

http://www.bestfree.ru/article/webdesign/ssi.php ,

то посетитель, нажавший на первую ссылку, не сможет попасть на эту страницу, поскольку у неё будет уже другое имя.

Поэтому лучше заранее дать всем страницам расширение php.

3. PHP легко встраивается в HTML

Вставки PHP легко можно добавить в существующий HTML-код в любом его месте. Например, используя подобную конструкцию

Источник: http://www.codenet.ru/webmast/php/8-php.php

Создание сайта PHP (с нуля, через фриланс) — сколько стоит создать сайт на php с нуля

К вашим услугам 2607 веб-мастеров в категории «По языкам программирования», специализирующихся на услуге «PHP». Выберите лучшее предложение, основываясь на 63508 отзывах об исполнителях раздела «Сайт под ключ» на YouDo

Получить предложениялучшие цены от веб-мастеров

на сайты

Поиск веб-мастеров
Прайс на По языкам программирования
Типовые услуги веб-мастеров

Наши преимущества

Только проверенные исполнители

Все исполнители YouDo проходят проверку администрацией сервиса, а так же имеют достоверные отзывы от других заказчиков

Быстро и удобно

Совет

Уже через несколько минут после публикации задания вы начнете получать предложения от заинтересованных веб-мастеров YouDo.

Создание сайта на PHP стоит доверить частному специалисту или компании, которая зарегистрирована на Юду. Исполнители Юду качественно и быстро справятся с поставленной перед ними задачей. Разработать сайт для компаний, занимающихся производством различной продукции, или интернет-магазинов с нуля для них не составит труда, мастера Юду имеют большой опыт работы.

Стоимость создания сайтов на PHP у исполнителей Юду на 20-25% ниже, чем в специализированных фирмах вашего города. Обусловлено это тем, что мастера, зарегистрированные на YouDo, не пользуются посредническими услугами и не арендуют офисные помещения.

Работы, выполняемые мастерами Юду

На YouDo можно найти организацию или частного специалиста, занимающегося созданием веб-ресурсов. Они выполнят ваш заказ в кратчайшие сроки. К преимуществам сотрудничества с исполнителями Юду можно отнести возможность получить профессиональную консультацию по интересующим вопросам, доступную цену качественных услуг.

У веб-мастеров с опытом, зарегистрированных на Юду, можно заказать:

  • создание сайта на PHP с нуля
  • подключение домена, регистрацию персональной информации вашей компании
  • наполнение ресурса актуальным и качественным текстовым и графическим материалом, редактирование контактов на главной странице
  • ведение корпоративных ресурсов
  • изменение структуры каталога

Специалисты создадут новый контент в сжатые сроки. Регулярное общение с разработчиком позволит своевременно вносить коррективы.

Последовательность разработки интернет-ресурсов

Создание сайта на PHP мастерами YouDo производится в несколько этапов:

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

Опытные разработчики, найти которых можно на Юду, быстро создадут простой динамический, одностраничный или корпоративный сайт со сложным дизайном с помощью удобного конструктора. Специалисты YouDo правильно настроят и запустят ваш ресурс.

Сколько стоит сделать шаблон?

Расценки на работы, выполняемые веб-мастерами, которые зарегистрированы на Юду, можно увидеть в прайс-листах, размещенных на сайте в профилях исполнителей. Точная стоимость создания сайта любого вида будет известна после согласования деталей сотрудничества с мастером YouDo.

Стоимость выполнения вашего заказа зависит от:

  • квалификации специалиста и его рейтинга на Юду
  • объема задач (создание одностраничного ресурса, сайта-визитки, портфолио)
  • срока выполнения задания
  • сложности дизайн-проекта

Мастера YouDo могут написать уникальные качественные тексты или отредактировать уже имеющуюся информацию, сделать каталог, научить вас пользоваться конструктором на PHP.

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

Сложный и креативный дизайн, разработанный опытными специалистами Юду, позволит привлечь внимание потенциальных клиентов вашей фирмы.

Цена подбора хостинговой площадки, полноценной поддержки ресурса, создания контента, предлагаемая специалистами YouDo, невысока. Создание сайта на PHP лучше доверить мастерам Юду.

Источник: http://freelance.youdo.com/turnkey/proglang/php/

Как сделать добавление новостей на сайте при помощи MVC и PHP

           

                               

  •                    

       

Создать новость

   

            Заголовок*

        Дата*

        Загрузить изображение*

        Автоматический Url*
*.

html

       
       

   

Теперь переходим в папку controllers и создаем файл NewsController.php.

В файле создаем класс NewsContoller, в классе пишем метод для отрисовки и обработки полей с нашей формы:

При нажатии кнопки на форме получаем введенные в поля данные методом POST и записываем их в переменные. Проверяем введено ли название новости:

public function actionAdd() {     if (isset($_POST['submit']))     {         $title = $_POST['title'];         $date = $_POST['date'];         $img_url = $_FILES['img_url']['name'];         $tmp_name_img = $_FILES['img_url']['tmp_name'];         $url = $_POST['url'];         $html = $_POST['html'];         $errors = false;         if (!$url) $errors[] = 'Введите название новости вручную';

Если после получения данных введенных в формы у нас не возникло ошибок, то переходим непосредственно к добавлению самих новостей.

Обратите внимание

У нас есть две функции добавления новости. Первая функция add_news выполняет добавление новости, если картинка не была выбрана. Если же картинка выбрана, то используется функция createNewsImg:

        if ($errors == false)         {             $url = $url.'.html';             if($img_url == null)             {                 $img_url = 'no_photo.png';                 News::add_news($title, $date, $img_url, $url, $html);                 header(«Location: /add_news»);             }             else             {                 News::createNewsImg($title, $date, $img_url, $tmp_name_img, $url, $html);                 header(«Location: /add_news»);             }         }     }     require_once(ROOT . '/views/site/add_news.php');     return true; }

Затем нам следует описать функции, которые добавляют новости в базу данных:

Функция add_news добавляет введенные в поля данные, в таблицу базы данных:

public static function add_news($title, $date, $img_url, $url, $html) {     $db = Db::getConnection();     $sql = 'INSERT INTO news (title, date, img_url, url, html) VALUES (:title, :date, :img_url, :url, :html)';     $result = $db->prepare($sql);     $result->bindParam(':title', $title, PDO::PARAM_STR);     $result->bindParam(':date', $date, PDO::PARAM_STR);     $result->bindParam(':img_url', $img_url, PDO::PARAM_STR);     $result->bindParam(':url', $url, PDO::PARAM_STR);     $result->bindParam(':html', $html, PDO::PARAM_STR);     return $result->execute(); }

Функция createNewsImg. Эта функция срабатывает тогда, когда в форме была выбрана картинка. С помощью функции downloadImg (ее мы разбирали в статье по загрузке картинок),  она загружает картинку на сервер, записывает в базу данных данные с формы и имя загруженного файла:

public static function createNewsImg($title, $date, $img_url, $tmp_name_img, $url, $html) {     $img_url1 = Page::downloadImg($img_url, $tmp_name_img);     echo $img_url1;     $db = Db::getConnection();     $sql = 'INSERT INTO news (title, date, img_url, url, html) VALUES (:title, :date, :img_url, :url, :html)';     $result = $db->prepare($sql);     $result->bindParam(':title', $title, PDO::PARAM_STR);     $result->bindParam(':date', $date, PDO::PARAM_INT);     $result->bindParam(':img_url', $img_url1, PDO::PARAM_STR);     $result->bindParam(':url', $url, PDO::PARAM_STR);     $result->bindParam(':html', $html, PDO::PARAM_STR);     return $result->execute(); }

Источник: https://goodnets.ru/Web_programmirovanie/MVC/Kak_sdelaty_dobavlenie_novostey_na_sayte_pri_pomoschi_MVC_i_PHP.html

Урок 2. Создаём первую страницу на PHP. Операторы вывода


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

Поздравляю — это большой шаг!

О PHP скажу коротко — этот язык программирования используется по всему миру и на нём можно создавать сайты всех уровней сложности, от сайтов-визиток до крупных порталов. Думаю, уже для многих не секрет, что крупнейшие социальные сети facebook.

com (с нуля на php) и vk.com (движок на php) были написаны на языке PHP. Так что делаем выводы и начинаем работу!)

Код PHP отрабатывается на стороне сервера. То есть готовой страницы нет. Например, в коде дана команда собрать данные о том, сколько пользователей зарегистрировано на данный момент на сайте. Посетитель сайта нажимает на ссылку все пользователи. Он хочет получить динамические данные, то есть те, которые постоянно изменяются. После того, как подсчёт на сервере будет закончен, с сервера придут данные в виде сгенерированного HTML-кода страницы с количеством пользователей. В результате, после клика-запроса по ссылке, пользователь получает страницу. Если просмотреть код полученной страницы, то можно увидеть только HTML, а PHP-код будет недоступен для просмотра. Грубо говоря, PHP — это указания серверу по тому, как и из каких блоков сделать страницу.
PHP-код можно внедрять непосредственно в HTML. PHP-код встраивается в HTML-страницы при помощи угловых скобок и знака вопроса , однако можно ограничиться скобками со знаками вопроса . Нужно будет только изменить расширение файла, например, с .html на .php

Код PHP (файл index.php)

Демонстрация Скачать исходники
Результатом работы кода будет вывод обычного текста Привет, Мир!. Спросите зачем писать код php, чтобы вывести обычный текст? Оператор echo, о котором поговорим чуть позже, нужен не просто для вывода текста. Чаще echo используют для отображения результата работы какой-то функции, которая производила подсчёт или брала данные из БД (Что такое База данных?). То есть для отображения динамических данных.
Как Вы уже поняли, оператор echo нужен для вывода данных. Содержимое (в нашем случае пока только текст) берём в кавычки, а в конце ставим точку с запятой ; это обозначает конец работы оператора.

В программирование при создании первой страницы принято употреблять фразу Hello, World! — то есть Привет, мир! Именно её и используем. В примере не будем использовать html, так как это не обязательно.

Код PHP

3. страницы с php-кодом должны иметь соответствующее расширение: .php .phtml

Со следующих уроков мы разберём основы создания сайтов на php, в которых увидите все плюсы использования данного языка!

Спасибо за внимание!

Предыдущая статья
Что такое PHP Следующая статья
Урок 3. Переменные в PHP

Источник: http://tradebenefit.ru/kak-sozdat-php-stranicu-primer

Habik.net

(Человеко-Понятные Урлы) или SEF (англ. Search Engines Friendly url). Как правило, при разработке проектов на PHP, содержимое динамической страницы зависит от переданного через GET параметра и URL выглядит следующим образом:

yourdomain.com/index.php?id=201

в данной случае намного аккуратнее смотрелась бы ссылка вида:

yourdomain.com/201/

yourdomain.com/201.html

а ещё лучше:

yourdomain.com/name-page.html

Как это сделать? Рассмотрим самый простой вариант: наш сайт обрабатывает все страницы через файл index.php и содержимое страницы определяется только одной переменной – id. В таком случае механизм преобразования из /index.php?id=201 в /name-page.html будет иметь следущий вид:

1) Определяем существует ли запрашиваемый путь в реальности. Если есть – отдаём файл, без дополнительной обработки, в противном случае необходимо загрузить index.php, который обработает несуществующий ЧПУ. Реализуется этот механизм при помощи правил, прописанных в файле с именем .htaccess.

Файл .htaccess должен находиться в корневой директории. Создать и править .htaccess можно в обычном текстовом редакторе.

Содержимое файла .htaccess:

#ЧПУ

RewriteEngine On

RewriteBase /

RewriteCond %{REQUEST_FILENAME} !-f

RewriteCond %{REQUEST_FILENAME} !-d

RewriteRule . /index.php [L]

RewriteEngine On – разрешаем серверу преобразовывать URL.

RewriteBase / – устанавливаем базовый URL.

RewriteCond %{REQUEST_FILENAME} !-f – проверяем, что запрошенной директории не существует.

RewriteCond %{REQUEST_FILENAME} !-d – проверяем, что запрошенного файла не существует.

RewriteRule . /index.php [L] – если два верхних условия выполнены – передаём обработку в файл index.php

MySQL

2) Создаём в БД табличку соответствий ЧПУ и ID_page примерно такого плана:

SEF
varchar(255)
ID_page
int(11)
index 1
page 2
page-name 3

PHP

3) Содержимое файла index.php, из комментариев в коде ясно, как это работает.

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

Вот, в целом, и всё ;).

Источник: http://habik.net/kak-sdelat-chpu-dlya-sajta-na-php/

Ссылка на основную публикацию