С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
-3 / 0 / 1
Регистрация: 22.01.2016
Сообщений: 309
1

Иероглифы в базе данных

04.02.2016, 15:20. Показов 782. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте.А почему в базу данных отправляют иероглифы???
Страницы отображаются корректно, а в базе данных "каряки"
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.02.2016, 15:20
Ответы с готовыми решениями:

На 7 иероглифы как иероглифы а на XP вместо них квадраты
В программе есть Caption состоящий из китайских иероглифов, на семерке все нормально, а вот на XP...

иероглифы в базу данных
Парни, проблема в иероглифах в базу данных при вводе в текстовом блоке русских букв, запись в базу...

Доступ к базе данных на базе хранимых процедур MySQL из php
Добрый день возник вопрос по доступ к базе данных на базе хранимых процедур MySQL из php Из файла...

Записи в базе данных, как встать на последнюю запись в базе после открытия?
Есть два вопроса. Во-первых - как встать на последнюю запись в базе после открытия? И...

6
162 / 161 / 66
Регистрация: 28.06.2015
Сообщений: 576
04.02.2016, 15:35 2
Скорее всего кодировка бд не верная. Или кодировка запросов.
В первом случае изменить кодировку бд на utf-8 general ci
Во втором явно указать кодировку запросов (зависит от драйвера который используете) пример:
PHP
1
$mysqli->set_charset("utf8")
0
-3 / 0 / 1
Регистрация: 22.01.2016
Сообщений: 309
04.02.2016, 15:48  [ТС] 3
В базе все верно, вот страница:

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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<? 
include ("lock.php");
 
function show_form(){ 
        // подключаем файл с настройками подключения к БД 
        require '../inc/connect.php'; 
 
        //делаем запрос к БД, на данный момент на следующие две строчки не стоит обращать внимание, объясню их потом, посокльку на данном этапе они еще не используются. 
        $result = mysql_query("SELECT * FROM pages WHERE id = '".$_GET['id']."';", $link); 
        $row = mysql_fetch_array($result); 
?><!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<link rel="stylesheet" href="style.css">
</head>
<body>
    
<a href="/admin">Главная</a><br>
<a href="/admin/?id=new">Добавить новую страницу</a><br><hr>
<form action="" method="post">
Название страницы (title)<br>
<input class="area_message2" type="text" name="title" value="<?=htmlspecialchars(stripslashes($row['title']));?>" class="enter" size="79"><br><br>
Заголовок страницы (Meta - title)<br> 
<input class="area_message2" type="text" name="metatitle" value="<?=htmlspecialchars(stripslashes($row['metatitle']));?>" class="enter" size="79"><br><br>
Ключевые слова (Meta - keywords)<br> 
<input class="area_message2" type="text" name="metakeywords" class="enter" size="79" value="<?=htmlspecialchars(stripslashes($row['metakeywords']));?>"><br><br>
Описание (Meta - description)<br> 
<input class="area_message2" type="text" name="metadescription" class="enter" size="79" value="<?=htmlspecialchars(stripslashes($row['metadescription']));?>"><br><br>
Текст страницы<br>
<textarea class="area_message" name="body" rows="20" class="enter"><?=stripslashes($row['body']);?></textarea><br><br>
<input type="hidden" name="id" value="<?=$_GET['id'];?>"><input type="submit" value="сохранить" name="edit"> 
</form> 
 
</body>
</html>
 
<? 
} // функция show_form() закончилась 
function complete(){ 
      // подключаем файл с настройками подключения - это мы уже знаем. 
      require '../inc/connect.php'; 
 
      // делаем запрос к БД в котором пытаемся вытащить страничку с указаным id. На данный момент мы не сделали еще ни одной страницы, посему запрос вернет пустой ряд. 
      $result = mysql_query("SELECT * FROM pages WHERE id = '".$_POST['id']."';", $link); 
 
      // перекидываем данные из MySQL в пхпшный ассоциативный массив 
      $row = mysql_fetch_array($result); 
 
      // проверяем не пуст ли элемент массива id. Если пуст, значит вставляем наши данные в БД 
      if(empty($row['id'])) 
            $query = "INSERT INTO pages 
                     (body, 
                      title, 
                      metatitle, 
                      metakeywords, 
                      metadescription) 
                                      VALUES 
                            ('".mysql_real_escape_string($_POST['body'])."', 
                             '".mysql_real_escape_string($_POST['title'])."', 
                             '".mysql_real_escape_string($_POST['metatitle'])."', 
                             '".mysql_real_escape_string($_POST['metakeywords'])."', 
                             '".mysql_real_escape_string($_POST['metadescription'])."')"; 
      // а вот если не пуст, значит с этим id уже есть запись и в данном случае мы ее просто отредактируем 
      else 
            $query = "UPDATE pages SET 
                                     body = '".mysql_real_escape_string($_POST['body'])."', 
                                     title = '".mysql_real_escape_string($_POST['title'])."', 
                                     metatitle = '".mysql_real_escape_string($_POST['metatitle'])."', 
                                     metakeywords = '".mysql_real_escape_string($_POST['metakeywords'])."', 
                                     metadescription = '".mysql_real_escape_string($_POST['metadescription'])."' 
                     WHERE id = '".$_POST['id']."';"; 
 
      // непосредственно записываем наши данные в базу (до этого мы просто описывали, что надо сделать, а теперь делаем) 
      mysql_query($query, $link); 
 
      // ну и просто выводим крикливую надпись, что скрипт отработал 
      echo '<h3>Данные сохранены</h3>'; 
} 
function show_pages() { 
// добавляем javascript, который позволит перед удалением спросить пользователя, уверен ли он в этом. 
?> 
<script language='JavaScript1.1' type='text/javascript'> 
<!-- 
function Delete(N) 
{ 
     if(confirm("Удалить запись?")) 
     { 
                 parent.location='?del='+N; 
     } 
     else 
     { 
       return false; 
     } 
} 
--> 
</SCRIPT> 
<? 
        require '../inc/connect.php'; 
        echo ' 
<a href="?id=new">Добавить страницу</a><br><hr>'; 
        echo ' 
<table cellspacing="1" cellpadding="2" bgcolor="#1F2760"> 
<tr bgcolor="#B0ADC3"> 
  <td colspan="2"> 
     <b>Название страницы</b> 
  </td> 
</tr>'; 
        $result = mysql_query("SELECT * FROM pages ORDER BY id;", $link); 
        while($row = mysql_fetch_array($result)){ 
               echo ' 
<tr bgcolor="#ffffff"> 
  <td> 
     <a href="?id='.$row['id'].'">'.stripslashes($row['title']).'</a> 
  </td> 
  <td> 
     <a href="#" title="Страница будет удалена без восстановления" OnClick="Delete('.$row['id'].')">удалить</a> 
  </td> 
</tr>'; 
         // добавили ячейку с ссылкой на удаление и не забыли вставить colspan="2" у заглавной ячейки 
         // думаю вы заметили, что в тексте ссылки мы заменили $row{'id'] на $row['title'] и добавили обработку функцией stripslashes() 
        } 
        echo ' 
</table>'; 
 
} 
function delete_pages(){ 
        require '../inc/connect.php'; 
        $query = "DELETE FROM pages WHERE id = '".$_GET['del']."';"; 
        mysql_query($query, $link); 
        echo '<h3>Данные удалены</h3>'; 
} 
if($_GET['del']) delete_pages(); 
if($_POST['edit']) complete(); // если была нажата кнопочка "отправить", которая именуется edit - тогда вызываем функию complete() 
if($_GET['id']) show_form(); // если мы нажали на ссылку в функции show_pages(), то значит мы передали в переменную $_GET['id'] тот самый id, который нас интересует. Поэтому в этом слчае вызываем форму редактирования нашей странички. 
else show_pages(); // ну, а если мы не выбрали определенный id - запускаем нашу функцию выбора id. 
?>
0
162 / 161 / 66
Регистрация: 28.06.2015
Сообщений: 576
04.02.2016, 16:13 4
Не стал подробно рассматривать ваш код, вот после подключения напишите:
PHP
1
2
3
mysql_connect(****); // Ваше подключение к бд
mysql_set_charset( 'utf8' );
mysql_query ("SET NAMES utf8");
1
-3 / 0 / 1
Регистрация: 22.01.2016
Сообщений: 309
04.02.2016, 16:39  [ТС] 5
Спасибо большое
0
162 / 161 / 66
Регистрация: 28.06.2015
Сообщений: 576
04.02.2016, 16:40 6
Получилось?
0
-3 / 0 / 1
Регистрация: 22.01.2016
Сообщений: 309
04.02.2016, 21:18  [ТС] 7
Да да, все четко.Спасибо еще раз.
0
04.02.2016, 21:18
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.02.2016, 21:18
Помогаю со студенческими работами здесь

Чтение файла: иероглифы вместо данных
Открываю файл вот таким кодом stringw strbuff; int numbytes = 0; long HTTPBUFLEN = 1000L; ...

Иероглифы при работе с базой данных!
Здравствуйте! На главной странице есть 2 текста - первый который был прописан в HTML коде, а...

передача данных USART + DMA и непонятные иероглифы
Всем привет! Есть проблема с передачей данных с МК на ПК через USORT + DMA. Ранее все работало...

Иероглифы при экспорте данных из таблицы StringGrid в файл
Пишу программу, выполняющую расчёты по заданным в программе формулам, используя данные, которые...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
Использование GraphQL в Go (Golang)
InfoMaster 08.01.2025
Go (Golang) является одним из наиболее популярных языков программирования, используемых для создания высокопроизводительных серверных приложений. Его архитектурные особенности и встроенные. . .
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru