Hanut сказал:Если в phpMyAdmin вы видите крякозыбры - значит именно они и записаны в БД, следовательно скриптом их вывести можно только в виде крякозябров.
Если вводить информацию через phpmyadmin, то кодировка сохраняется как cp1251, и остается до тех пор пока я не пропускаю скрипт работы с этой таблицей через браузер. Скрипт записи и вывода такой:
<?php
include_once 'functions.php';
if(!isset($_SESSION['user']))
die("<br><br>Вы обязаны войти на сайт, чтобы просматривать эту страницу");
$user = $_SESSION['user'];
echo "<h3>Редактирование вашего профиля</h3>";
if(isset($_POST['text']))
{
$text = sanitizeString($_POST['text']);
$text = preg_replace('/\s\s+/', ' ', $text);
$query = "SELECT * FROM profiles WHERE user='$user'";
if (mysql_num_rows(queryMysql($query)))
{
queryMysql("UPDATE profiles SET text='$text' where user='$user'");
}
else
{
$query = "INSERT INTO profiles VALUES('$user','$text')";
queryMysql($query);
}
}
else
{
$query = "SELECT * FROM profiles WHERE user='$user'";
$result = queryMysql($query);
if(mysql_num_rows($result))
{
$row = mysql_fetch_row($result);
$text = stripslashes($row[1]);
}
else $text = "";
}
$text = stripslashes(preg_replace('/\s\s+/', ' ', $text));
if(isset($_FILES['image']['name']))
{
$saveto = "userimg/$user.jpg";
move_uploaded_file($_FILES['image']['tmp_name'], $saveto);
$typeok = true;
switch($_FILES['image']['type'])
{
case "image/gif": $src = imagecreatefromgif($saveto); break;
case "image/jpeg": $src = imagecreatefromjpeg($saveto); break;
case "image/png": $src = imagecreatefrompng($saveto); break;
default: $typeok = false; break;
}
if($typeok)
{
list($w, $h) = getimagesize($saveto);
$max = 100;
$tw = $w;
$th = $h;
if($w > $h && $max < $h)
{
$th = $max / $w * $h;
$tw = $max;
}
elseif ($h > $w && $max < $h)
{
$tw = $max / $h * $w;
$th = $max;
}
elseif ($max < $w)
{
$tw = $th = $max;
}
$tmp = imagecreatetruecolor($tw, $th);
imagecopyresampled($tmp, $src,0, 0, 0, 0, $tw, $th, $w, $h);
imageconvolution($tmp, array ( // улучшение резкости изображения
array(-1, -1, -1),
array(-1, 16, -1),
array(-1, -1, -1)
), 8, 0);
imagejpeg($tmp, $saveto);
imagedestroy($tmp);
imagedestroy($src);
}
}
echo <<<_END
<script>
function preview()
{
if(document.getElementById('showprofile').style.display == 'none'){
document.getElementById('showprofile').style.display = 'block';
}else{
document.getElementById('showprofile').style.display = 'none';
}
}
</script>
<form method='post' action='myprofile.php' enctype='multipart/form-data'>
Введите или отредактируйте сведения и загрузите изображение.<br>
<textarea name='text' cols='40' rows='3'>$text</textarea><br>
<br>
Изображение: <input type='file' name='image' size='14' maxlength='32'>
<input type='submit' value='Сохранить информацию'>
</form>
<br><br>
<hr style='width: 98%; float:left;'>
<br>
<img src='images/preview.png' onmouseover='this.src="images/preview2.png"' onmouseout='this.src="images/preview.png"' onclick="preview()">
<br>
<hr style='width: 98%; float:left;'>
<div id="showprofile">
_END;
showProfile($user);
echo "</div>";
?>
<?php //functions.php
header('Content-Type: text/html; charset=cp1251');
require 'login.php';
$appname = "Class105";
mysql_connect($dbhost, $dbuser, $dbpass) or die(mysql_error());
mysql_query('SET NAMES cp1251');
mysql_query("SET CHARACTER SET 'cp1251'");
mysql_select_db($dbname) or die (mysql_error());
function sanitizeString($var) // уничтожает потенциально вредоносный код и теги из информации введенной пользователем
{
$var = strip_tags($var);
$var = htmlentities($var);
$var = stripslashes($var);
return mysql_real_escape_string($var);
}
function showProfile($user) //отображает миниатюрные аватары пользователей и краткую информацию "Обо мне", если таковая имеется
{
if (file_exists("userimg/$user.jpg"))
echo "<img src='userimg/$user.jpg' border='1' align='left'>";
$result = queryMysql("SELECT * FROM profiles WHERE user='$user'");
if (mysql_num_rows($result))
{
$row = mysql_fetch_row($result);
echo stripslashes($row[1]) . "<br clear=left><br>";
}
}
?>