접속자현황에서 한글 깨지는 현상 수정 정보
접속자현황에서 한글 깨지는 현상 수정본문
adm/visit_list.php 를 아래의 코드로 수정하신 후 확인해 주십시오.
<?
$sub_menu = "200800";
include_once("./_common.php");
$sub_menu = "200800";
include_once("./_common.php");
auth_check($auth[$sub_menu], "r");
$g4[title] = "접속자현황";
include_once("./admin.head.php");
include_once("./visit.sub.php");
include_once("./admin.head.php");
include_once("./visit.sub.php");
$colspan = 5;
?>
?>
<table width=100% cellpadding=0 cellspacing=1 border=0>
<colgroup width=100>
<colgroup width=350>
<colgroup width=100>
<colgroup width=100>
<colgroup width=''>
<tr><td colspan='<?=$colspan?>' class='line1'></td></tr>
<tr class='bgcol1 bold col1 ht center'>
<td>IP</td>
<td>접속 경로</td>
<td>브라우저</td>
<td>OS</td>
<td>일시</td>
</tr>
<tr><td colspan='<?=$colspan?>' class='line2'></td></tr>
<?
//unset($br); // 브라우저
//unset($os); // OS
<colgroup width=100>
<colgroup width=350>
<colgroup width=100>
<colgroup width=100>
<colgroup width=''>
<tr><td colspan='<?=$colspan?>' class='line1'></td></tr>
<tr class='bgcol1 bold col1 ht center'>
<td>IP</td>
<td>접속 경로</td>
<td>브라우저</td>
<td>OS</td>
<td>일시</td>
</tr>
<tr><td colspan='<?=$colspan?>' class='line2'></td></tr>
<?
//unset($br); // 브라우저
//unset($os); // OS
$sql_common = " from $g4[visit_table] ";
$sql_search = " where vi_date between '$fr_date' and '$to_date' ";
if ($domain) {
$sql_search .= " and vi_referer like '%$domain%' ";
}
$sql_search = " where vi_date between '$fr_date' and '$to_date' ";
if ($domain) {
$sql_search .= " and vi_referer like '%$domain%' ";
}
$sql = " select count(*) as cnt
$sql_common
$sql_search ";
$row = sql_fetch($sql);
$total_count = $row[cnt];
$sql_common
$sql_search ";
$row = sql_fetch($sql);
$total_count = $row[cnt];
$rows = $config[cf_page_rows];
$total_page = ceil($total_count / $rows); // 전체 페이지 계산
if ($page == "") $page = 1; // 페이지가 없으면 첫 페이지 (1 페이지)
$from_record = ($page - 1) * $rows; // 시작 열을 구함
$total_page = ceil($total_count / $rows); // 전체 페이지 계산
if ($page == "") $page = 1; // 페이지가 없으면 첫 페이지 (1 페이지)
$from_record = ($page - 1) * $rows; // 시작 열을 구함
$sql = " select *
$sql_common
$sql_search
order by vi_id desc
limit $from_record, $rows ";
$result = sql_query($sql);
$sql_common
$sql_search
order by vi_id desc
limit $from_record, $rows ";
$result = sql_query($sql);
function is_utf8($str)
{
$len = strlen($str);
for($i = 0; $i < $len; $i++) {
$c = ord($str[$i]);
if ($c > 128) {
if (($c > 247)) return false;
elseif ($c > 239) $bytes = 4;
elseif ($c > 223) $bytes = 3;
elseif ($c > 191) $bytes = 2;
else return false;
if (($i + $bytes) > $len) return false;
while ($bytes > 1) {
$i++;
$b = ord($str[$i]);
if ($b < 128 || $b > 191) return false;
$bytes--;
}
}
}
return true;
}
{
$len = strlen($str);
for($i = 0; $i < $len; $i++) {
$c = ord($str[$i]);
if ($c > 128) {
if (($c > 247)) return false;
elseif ($c > 239) $bytes = 4;
elseif ($c > 223) $bytes = 3;
elseif ($c > 191) $bytes = 2;
else return false;
if (($i + $bytes) > $len) return false;
while ($bytes > 1) {
$i++;
$b = ord($str[$i]);
if ($b < 128 || $b > 191) return false;
$bytes--;
}
}
}
return true;
}
for ($i=0; $row=sql_fetch_array($result); $i++) {
$brow = get_brow($row[vi_agent]);
$os = get_os($row[vi_agent]);
$brow = get_brow($row[vi_agent]);
$os = get_os($row[vi_agent]);
$link = "";
$referer = "";
$title = "";
if ($row[vi_referer]) {
$referer = "";
$title = "";
if ($row[vi_referer]) {
$referer = get_text(cut_str($row[vi_referer], 255, ""));
$referer = urldecode($referer);
$referer = urldecode($referer);
if (strtolower($g4['charset']) == 'utf-8') {
if (!is_utf8($referer)) {
$referer = iconv('euc-kr', 'utf-8', $referer);
}
}
else {
if (is_utf8($referer)) {
$referer = iconv('utf-8', 'euc-kr', $referer);
}
}
if (!is_utf8($referer)) {
$referer = iconv('euc-kr', 'utf-8', $referer);
}
}
else {
if (is_utf8($referer)) {
$referer = iconv('utf-8', 'euc-kr', $referer);
}
}
$title = str_replace(array("<", ">"), array("<", ">"), $referer);
$link = "<a href='$row[vi_referer]' target=_blank title='$title '>";
}
$link = "<a href='$row[vi_referer]' target=_blank title='$title '>";
}
if ($is_admin == 'super')
$ip = $row[vi_ip];
else
$ip = preg_replace("/([0-9]+).([0-9]+).([0-9]+).([0-9]+)/", "\\1.♡.\\3.\\4", $row[vi_ip]);
$ip = $row[vi_ip];
else
$ip = preg_replace("/([0-9]+).([0-9]+).([0-9]+).([0-9]+)/", "\\1.♡.\\3.\\4", $row[vi_ip]);
if ($brow == '기타') { $brow = "<span title='$row[vi_agent]'>$brow</span>"; }
if ($os == '기타') { $os = "<span title='$row[vi_agent]'>$os</span>"; }
if ($os == '기타') { $os = "<span title='$row[vi_agent]'>$os</span>"; }
$list = ($i%2);
echo "
<tr class='list$list col1 ht center'>
<td>$ip</td>
<td align=left><nobr style='display:block; overflow:hidden; width:350;'>$link$title</a></nobr></td>
<td>$brow</td>
<td>$os</td>
<td>$row[vi_date] $row[vi_time]</td>
</tr>";
}
echo "
<tr class='list$list col1 ht center'>
<td>$ip</td>
<td align=left><nobr style='display:block; overflow:hidden; width:350;'>$link$title</a></nobr></td>
<td>$brow</td>
<td>$os</td>
<td>$row[vi_date] $row[vi_time]</td>
</tr>";
}
if ($i == 0)
echo "<tr><td colspan='$colspan' height=100 align=center>자료가 없습니다.</td></tr>";
echo "<tr><td colspan='$colspan' height=100 align=center>자료가 없습니다.</td></tr>";
echo "<tr><td colspan='$colspan' class='line2'></td></tr>";
echo "</table>";
echo "</table>";
$page = get_paging($config[cf_write_pages], $page, $total_page, "$_SERVER[PHP_SELF]?$qstr&domain=$domain&page=");
if ($page) {
echo "<table width=100% cellpadding=3 cellspacing=1><tr><td align=right>$page</td></tr></table>";
}
if ($page) {
echo "<table width=100% cellpadding=3 cellspacing=1><tr><td align=right>$page</td></tr></table>";
}
include_once("./admin.tail.php");
?>
?>
추천
4
4
댓글 8개
감사합니다 !!
관리자님 쎈스쟁이. 오타가 아니라 더더욱 고충이 느껴지는 ㅋㅋㅋ.
if ($b < 128 || $b > 191) return false;
$bytes--;
if ($b < 128 || $b > 191) return false;
$bytes--;
들여쓰기 말씀이신가요?
아니요 코드상에 ++은 (+.+);
--는 (-.-); 이렇게 보여서 드린말입니다. ㅎㅎ.
--는 (-.-); 이렇게 보여서 드린말입니다. ㅎㅎ.
한글 잘 나옵니다.
감사합니다.
환경이 너무 다양하니.. ㅡㅡ.
그냥 일반에서도 그렇지만 ㅜㅜ 감사해요