RadarURL

Views 5503 Votes 0 Comment 0
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
회원정보의 회원사진에 관한 팁(정보 변경 시 기존파일 덮어쓰기, 탈퇴시 자동삭제)

회원가입 시 받은 사진은 icon 폴더 아래 member_숫자 형식의 이름으로 저장됩니다. 여기서 숫자는 time() 함수로 얻기 때문에 회원정보를 수정하면 새 파일이 만들어지게 됩니다.

회원사진 변경 시 기존의 파일을 덮어쓰기 위해서는 우선 파일이 다른 형식의 이름으로 저장되도록 해야 합니다. 저의 경우 member_"가입한 시간""회원아이디" 형식으로 바꾸었습니다. 중복될 일도 없고 다른 회원 사진의 파일명을 쉽게 알 수 없도록 말입니다.
먼저 회원사진의 변경은 다음 세 파일이 처리합니다. member_join_ok.php, member_modify_ok.php, admin_exec_member.php.
회원정보를 받는 변수가 파일마다 다르므로 각각 알맞게 수정하셔야 합니다.

member_join_ok.php 파일의 경우 간단하게

$path="icon/member_".$reg_date.$user_id.".".$kind[$n];

바꾸시면 됩니다. 다음 member_modify_ok.php 에서는

$path="icon/member_".$member[reg_date].$member[user_id].".".$kind[$n];

그리고 마지막 admin_exec_member.php 에서는 $path 부분을 아래와 같이 바꾸면 됩니다.

$m_data=mysql_fetch_array(mysql_query("select user_id, reg_date from $member_table where no='$member_no'"));
$path="icon/member_".$m_data[reg_date].$m_data[user_id].".".$kind[$n];

회원탈퇴시 자동으로 회원사진을 삭제하려면 member_out.php 와 admin_exec_member.php 를 수정하셔야 합니다.

member_out.php 에서

// 회원 정보를 얻어옴
$member=member_info();
$group_no = $member[group_no];
@z_unlink("icon/member_".$member[reg_date].$member[user_id].".jpg");
@z_unlink("icon/member_".$member[reg_date].$member[user_id].".gif");

admin_exec_member.php 에서는 회원정보를 $member_data 로 받으므로 다음과 같이 수정하셔야 합니다.

// 이름 그림, 아이콘, 이미지 박스 사용용량 파일 삭제
@z_unlink("icon/private_name/".$no.".gif");
@z_unlink("icon/private_icon/".$no.".gif");
@z_unlink("icon/member_image_box/".$no."_maxsize.php");
@z_unlink("icon/member_".$member_data[reg_date].$member_data[user_id].".jpg");
@z_unlink("icon/member_".$member_data[reg_date].$member_data[user_id].".gif");

회원가입시 jpg, gif 가 아닌 다른 형식의 파일을 받을 수 있도록 했다면 그 파일형식도 추가해 주셔야 합니다.

일단 예전에 회원사진에 관한 팁에 약간 이상이 생겨서 생각없이 지우고, 다시 써야지 했는데....
예전에 이상이 있던 저의 글을 보고, 고생을 하신 분이 계시다면 정말 죄송합니다.
모님께서 부탁을 하셔서 참고하였던 얼음님의 팁과 제가 올렸던 부분을 다시 정리해서 올렸습니다.
오늘 제가 올렸던 관리자모드에서 회원 삭제하는 부분은 이 글의 마지막 부분에 다시 정리하였으므로, 삭제하였습니다.
(그리고, 열라초보님 이렇게 고치시고...관리자모드에서 그림 삭제했는데 서버에 계속 남아있다면, 문제가 있는겁니다.
꼭 쪽지나 메신저로 연락주시구요. 혹시나 엡튀 클라이언트에서 리프레쉬 연타를 함 해보세요 ㅡㅡㅋ 넝담입니다으~ ^^)

다음부터는 확실하게 확인하고, 올리도록 하겠습니다. ㅡㅡㅋ

--------------------------------------------

1차적으로 '얼음'님께서 올리신 '회원정보의 회원사진에 관한 팁(정보 변경 시 기존파일 덮어쓰기, 탈퇴시 자동삭제)'를 참고하였습니다.
http://www.nzeo.com/bbs/zboard.php?id=cgi_tip&page=1&sn1=&divpage=1&sn=on&ss=on&sc=off&keyword=얼음&select_arrange=headnum&desc=asc&no=4533 [새창에서 열기]

적용을 하고 사용을 하다보니 약간의 문제점이 발견되었는데....
회원들이 항상 jpg나 gif로 ...일관되게 사진을 올리지는 않습니다. 사진을 삭제하는 부분에 보시면, 서버에서 삭제하는 부분은 없고,
db에서 사진 파일의 경로만 지워주더군요. 그래서, 뜻하지 않게 사진을 올렸던 회원이 현재 사진을 사용하지 않는다고 해도 디렉토리에는
항상 사진파일이 남아있게 되더군요. 또, gif와 jpg 두개의 포맷을 하나씩 올리셨던 분들은 항상 그림 파일이 두개가 됩니다.
만약, 그림의 포맷을 더 많이 허용하는 분들은 엄청나게 많은 파일이 쌓이게 되겠지요.
(말이 어렵습니다 ㅡㅡㅋ 제가 봐도 이해가 안되네요 ㅡㅡㅋ)

고쳐줄 파일은 admin/admin_exec_member.php와 member_modify_ok.php 2개 입니다.
(그 이전에 저는 얼음님의 팁에 따라 어느 정도 수정을 가한 상태입니다. 특히 파일이름 설정하는 부분 등등...)

-----------------------------------------
member_modify_ok.php
-----------------------------------------
if($del_picture) {
        @mysql_query("update $member_table set picture='' where no='$member[no]'") or Error("사진 자료 업로드시 에러가 발생하였습니다");
}

위의 부분을 찾아서 아래와 같이 두 라인을 추가해줍니다.

if($del_picture) {
        @z_unlink("icon/member_photo/member_".$member[user_id]."_".$member[reg_date].".jpg");  // <--- 이 부분 삽입
        @z_unlink("icon/member_photo/member_".$member[user_id]."_".$member[reg_date].".gif");  // <--- 이 부분 삽입
        @mysql_query("update $member_table set picture='' where no='$member[no]'") or Error("사진 자료 업로드시 에러가 발생하였습니다");
}

----------------------- (사진 파일의 경로와 파일 명은 제가 현재 사용하는 형태로 바꿨습니다.)

또, 아래의 부분을 찾아서 두 줄을 삽입해 줍니다.
if($picture_name) {
        @z_unlink("icon/member_photo/member_".$member[user_id]."_".$member[reg_date].".jpg");  // <--- 이 부분 삽입
        @z_unlink("icon/member_photo/member_".$member[user_id]."_".$member[reg_date].".gif");  // <--- 이 부분 삽입
        if(!is_uploaded_file($picture)) Error("정상적인 방법으로 업로드 해주세요");
        if(!eregi(".gif",$picture_name)&&!eregi(".jpg",$picture_name)) Error("사진은 gif 또는 jpg 파일을 올려주세요");
        $size=GetImageSize($picture);
        if($size[0]>200||$size[1]>200) Error("사진의 크기는 200*200이하여야 합니다");
        $kind=array("","gif","jpg");
        $n = $size[2] ;
        // $path="icon/member_".time().".".$kind[$n];
        $path="icon/member_photo/member_".$member[user_id]."_".$member[reg_date].".".$kind[$n];
        if(!move_uploaded_file($picture,$path)) Error("사진 업로드가 제대로 되지 않았습니다");
        @mysql_query("update $member_table set picture='$path' where no='$member[no]'") or Error("사진 자료 업로드시 에러가 발생하였습니다");
        }


------------------------------------------
admin/admin_exec_member.php
------------------------------------------

만약에 얼음님의 팁대로 하셨다면, 아래 부분과 같을 겁니다.

if($picture_name) {
        if(!is_uploaded_file($picture)) Error("정상적인 방법으로 업로드하여 주십시요");
        if(!eregi(".gif",$picture_name)&&!eregi(".jpg",$picture_name)) Error("사진은 gif 또는 jpg 파일을 올려주세요");
        $size=GetImageSize($picture);
        if($size[0]>320||$size[1]>200) Error("사진의 크기는 320*200이하여야 합니다");
        $kind=array("","gif","jpg");
        $n=$size[2];
        // $path="icon/member_".time().".".$kind[$n];
        $m_data=mysql_fetch_array(mysql_query("select user_id, reg_date from $member_table where no='$member_no'"));
        $path="icon/member_photo/member_".$m_data[user_id]."_".$m_data[reg_date].".".$kind[$n];
        @move_uploaded_file($picture,$path);
        @chmod($path,0707);
        @mysql_query("update $member_table set picture='$path' where no='$member_no'") or Error("사진 자료 업로드시 에러가 발생하였습니다");
}

------------------------
기존의 $path 부분이 $m_data; $path; <- 이렇게요.

어쨌든, 저 위의 부분 가장 위에 member_modify.php처럼 두 줄을 삽입하고, $m_data로 쿼리해오는 부분을 위치 이동 시켜줍니다.

$m_data=mysql_fetch_array(mysql_query("select user_id, reg_date from $member_table where no='$member_no'")); //<-- 위치 이동
if($picture_name) {
        @z_unlink("icon/member_photo/member_".$m_data[user_id]."_".$m_data[reg_date].".jpg");  // <--- 이 부분 삽입
        @z_unlink("icon/member_photo/member_".$m_data[user_id]."_".$m_data[reg_date].".gif");  // <--- 이 부분 삽입
        if(!is_uploaded_file($picture)) Error("정상적인 방법으로 업로드하여 주십시요");
        if(!eregi(".gif",$picture_name)&&!eregi(".jpg",$picture_name)) Error("사진은 gif 또는 jpg 파일을 올려주세요");
        $size=GetImageSize($picture);
        if($size[0]>320||$size[1]>200) Error("사진의 크기는 320*200이하여야 합니다");
        $kind=array("","gif","jpg");
        $n=$size[2];
        // $path="icon/member_".time().".".$kind[$n];
        $path="icon/member_photo/member_".$m_data[user_id]."_".$m_data[reg_date].".".$kind[$n];
        @move_uploaded_file($picture,$path);
        @chmod($path,0707);
        @mysql_query("update $member_table set picture='$path' where no='$member_no'") or Error("사진 자료 업로드시 에러가 발생하였습니다");
}

--------------------------


자...이제 관리자 모드에서도 회원들의 그림을 삭제하도록 하겠습니다.
일단, admin/admin_modify_member.php에서 삭제를 할 수 있는 체크박스를 하나 만듭니다.

그림이 표시되는 input을 찾아서 아래와 같이 삭제체크박스를 하나 넣어줍니다.
------------------------------------------
admin/admin_modify_member.php
------------------------------------------
<? if($group_data[use_picture]) { ?>
  <tr height=22 align=center>
     <td bgcolor=#a0a0a0 align=right style=font-family:Tahoma;font-size:8pt;font-weight:bold;>사진  </td>
     <td align=left bgcolor=#e0e0e0> <input type=file name=picture size=37 maxlength=255 class=input style=border-color:#b0b0b0>
                 <? if($member_data[picture]) echo" <input type=checkbox name=del_picture value=1> 삭제<br><img src='$member_data[picture]' border=0><br>"; ?>

     </td>
  </tr>
<? } ?>
--------------------------

이제는 admin/admin_exec_member.php에서 $del_picture를 하나 만들어주면 됩니다.
위에서 위치이동한
$m_data=mysql_fetch_array(mysql_query("select user_id, reg_date from $member_table where no='$member_no'"));
이 문장 밑에 아래의 소스를 붙이시면 됩니다.

------------------------------------------
admin/admin_exec_member.php
------------------------------------------
// 회원의 소개 사진 삭제
if($del_picture) {
        @z_unlink("icon/member_photo/member_".$m_data[user_id]."_".$m_data[reg_date].".jpg");
        @z_unlink("icon/member_photo/member_".$m_data[user_id]."_".$m_data[reg_date].".gif");
        @mysql_query("update $member_table set picture='' where no='$member_no'") or Error("사진 자료 업로드시 에러가 발생하였습니다");
}
------------------------------------------
주의하실 것은 member_modify_ok.php에서는 $member[]으로 받아왔으나, admin_exec_member.php에서는 안된다는 것입니다.
(예전에 제가 그냥 저렇게 썼다가 ㅡㅡㅋ) $member[]를 $m_data[]로 바꾸어 주세요.

에궁...제가 설명을 다 잘했나 모르겠네요.
다시 한번 제가 올렸던 엉성한 팁을 보고 고생하셨던 분들...정말 죄송합니다.

이런 일 없도록 다음부터는 철저하게 확인해보고 올리겠습니다.

좋은 하루되시길.....


이제서야 걸음마를 배우는 초보이지만,
열심히 배워서 스스로 걸을 수 있도록 노력하겠습니다.
- 닭 -  

출처 : http://www.nzeo.com/bbs/zboard.php?id=cgi_tip&page=2&sn1=&divpage=1&sn=off&ss=on&sc=off&keyword=사진&select_arrange=headnum&desc=asc&no=4664 [새창에서 열기]
?

공부 게시판

공부에 도움되는 글을 올려주세요.

List of Articles
No. Category Subject Author Date Views
Notice [공지] 공부 게시판 입니다. 처누 2003.08.18 928086
2473 웹서버,WAS http를 https로 리다이렉트하는 여러가지 방법 new JaeSoo 2025.09.10 0
2472 웹서버,WAS SSL인증서 없이 HTTPS에서 HTTP로 되돌리기 new JaeSoo 2025.09.10 2
2471 웹서버,WAS [SSL] win-acme, Let's encrypt로 무료 SSL 인증서 발급 new JaeSoo 2025.09.10 0
2470 웹서버,WAS [SSL] Windows 10에서 Let's Encrypt로 SSL 인증서 무료 발급받기 new JaeSoo 2025.09.10 0
2469 웹서버,WAS 무료로 https SSL/TLS 인증서를 발급받을 수 있는 인증 기관 new JaeSoo 2025.09.10 0
2468 웹서버,WAS 아파치 서버에 https SSL 인증서 적용하는 방법 (apache httpd) new JaeSoo 2025.09.10 0
2467 웹서버,WAS 아파치2(Apache2) SSL HTTPS 적용하기 new JaeSoo 2025.09.10 0
2466 웹서버,WAS 아파치 웹서버에 멀티 도메인에 대한 80, 443 포트 설정하는 방법 newfile JaeSoo 2025.09.10 0
2465 소프트웨어 Google Photo 대신 Immich를 써보자 file JaeSoo 2025.08.07 126
2464 연애 남자 혹은 여자 진국 팁 JaeSoo 2025.07.24 116
2463 기타 MBTI검사 16가지 유형 “간단 명료”하게 정리! file JaeSoo 2025.07.01 132
2462 소프트웨어 [사진관리] PhotoPrism vs LibrePhoto 비교 소감 JaeSoo 2025.05.19 14
2461 네트워크 MDF실, TPS실, EPS실 이게 뭘까? file JaeSoo 2025.04.15 33
2460 업무 알아두면 좋은 직장인 용어 정리 file JaeSoo 2025.04.15 37
2459 건강 감기·독감·코로나19의 차이점, 신촌연세병원과 함께 알아봅시다. file JaeSoo 2025.01.08 29
2458 생활 집주인이 전세 보증금을 돌려주지 않을 때 JaeSoo 2024.11.29 26
2457 자동차 자전거 타이어 종류 및 추천 2편 (승차감 타이어, 국토종주!) JaeSoo 2024.10.15 53
2456 자동차 오도바이 센타 사장들은 어떤 브랜드를 싫어하고 좋아할까? [출처] 오도바이 센타 사장들은 어떤 브랜드를 싫어하고 좋아할까?|작성자 바이크신 file JaeSoo 2024.10.15 78
2455 윈도우즈 윈도우 자동 로그온 설정이 보이지 않을 때 조치사항 JaeSoo 2024.08.16 203
2454 모바일 갤럭시S22 시리즈에서 SKT LTE 무제한 핫스팟 쓰는 방법! (SKT LTE 요금제만 해당!) JaeSoo 2024.08.12 234
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 124 Next
/ 124


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너