웹마스터 팁

개인쪽지발송!~

2009.06.23 09:44

noirzo

그룹쪽지 발송을 위해서 우선은 개인발송 테스트로 만든 소스 공유 합니다.

( 사실 ㅡ.ㅡ:: 이렇게 하면 안되는데 딱히 제로보드XE 구조를 몰라서 ;;;; )

 

아래의 소스를 message.php 저장을 하시고요!~

 

제로보드XE 설치폴더 밑에 저장하세요~ (아무곳이나 저장해도 상관 없을꺼예요)

 

그런다음에 http://주소/제로보드XE설치폴더/message.php 하시면 바로 해당 회원에게 쪽지 발송이 됩니다.

 

<?

/* 초기설정 (아래내역 작성하여 주세요) */

$admin_user = "";             //관리자 아이디를 입력하여 주세요
$dbhost = "localhost";             //호스트를 입력   
$dbid = "";               //접속계정
$dbpass = "";            //비밀번호
$dbname = "";              //DB네임
$xe_url = "/usr/local/apache_2.0.63/htdocs/slot/config/config.inc.php"; //config.inc.php 파일이 있는 절대경로(이건 제껄 예로 든거예요 저기서 slot 이 zbxe 설치폴더)


/* 제로보드XE 연동 */

 define('__ZBXE__',true);
 require_once($xe_url);
 $oContext = &Context::getInstance();
 $oContext->init();

 $user_id = $logged_info->user_id;

?>

 <meta http-equiv="content-type" content="text/html; charset=utf-8">

<?

 //관리자체크
 if($user_id!=$admin_user){

  echo "<script>alert('관리자만 접근이 가능 합니다.')</script>\n";
  exit;

 }

 

/* DB 접속 */

 $connect=mysql_connect($dbhost,$dbid,$dbpass);
 mysql_select_db($dbname, $connect);
 mysql_query("set names utf8", $connect); //문자셋 utf8 접속


/* 시간 */

 $regdate=time();

/* 함수 정의 */

//보내는회원, 받는회원, 제목, 내용, 발송시간
function message_send($sender_srl,$receiver_srl,$title,$content,$time){

 $i=2;
 $idate = date("YmdHis",$time);

 //테이블락
 mysql_query("lock tables xe_sequence write, lock tables xe_member_message write");

 //증가값 추가
 mysql_query("INSERT INTO xe_sequence (seq) VALUES (NULL),(NULL),(NULL);");
 
 //마지막 추가한 증가값 3개 가져옴
 $result = mysql_query("SELECT * FROM xe_sequence ORDER BY seq DESC LIMIT 0 , 3");

 //증가값 대입
 while ($row = mysql_fetch_object($result)) {

  $seq[$i] = $row->seq;
  $i--;

 }

 $seq[3] = $seq[0] * -1; //$seq[0] 동일
 $seq[4] = $seq[2] * -1; //$seq[2] 동일

 //메세지삽입
 mysql_query("INSERT INTO xe_member_message (message_srl ,related_srl ,sender_srl ,receiver_srl ,message_type ,title ,content ,readed ,list_order ,regdate) VALUES ($seq[0], 0, $sender_srl, $receiver_srl, 'R', '$title', '$content', 'N', $seq[3], '$idate');");

 mysql_query("INSERT INTO xe_member_message (message_srl ,related_srl ,sender_srl ,receiver_srl ,message_type ,title ,content ,readed ,list_order ,regdate) VALUES ($seq[1], $seq[0], $sender_srl, $receiver_srl, 'S', '$title', '$content', 'N', $seq[4], '$idate');");

 //락해제
 mysql_query("UNLOCK TABLES");

}

/* 개인 메세지 발송 (요기부터 작성하시면 됩니다) */

$title = "쪽지 테스트!!~";
$content = "흠냥!! ㅡ.ㅡ";

//보내는회원_srl, 받는회원_srl, 쪽지제목, 쪽지내용, 보내는시간(자동입력)
message_send(4,18343,$title,$content,$regdate);

echo "<script>alert('쪽지 발송 완료')</script>\n";

mysql_close($connect);

?>

 

위에 보시면 $title 변수에 제목을 넣어 주시고요, $content 변수에 내용을 넣어 주시면되요(태그포함)

 

message_send(4,18343,$title,$content,$regdate); <-- 이함수로 발송을 하거든요 ㅡㅡa

 

보시는 것 처럼 인수는 보내는회원_srl, 받는회원_srl, 쪽지제목, 쪽지내용, 보낸시간 입니다.

 

제목이랑, 내용은 작성이 가능하실줄 알고요, 시간은 그대로 두셔도 됩니다(발송시간을 변경 하고 싶으시면 ㅡㅡa 소스보고 수정을)

 

srl 궁금하실것 같으신데요

 

srl = id 랑 매치되는 고유 번호 인데요 ㅡㅡa 보통 쪽지 보내기 하면은 마지막 url 보시면 srl=번호 이렇게 되어 있습니다.

 

ㅡㅡa 아이디로 넣어서 함수에서 처리 할까 했는데 제가 하고 싶은건 그룹발송이라 일단은 그냥 대충 ;;;;

 

저렇게 하고 그냥 불러 오시면 바로 쪽지 발송이 가능 합니다.

 

 

제목 글쓴이 날짜
게시판 스킨에서 조회수, 추천수, 최근 수정일 외 항목도 정렬가능하게 하기 SMaker 2009.06.11
로그인 페이지 만드는 방법 [5] 산토 2009.06.12
외부문서에서 mms:// 태그 사용하기 [11] 아고라 2009.06.12
에디터 컴포넌트 목록이 안 나올 때 해결법 [2] SMaker 2009.06.14
layout.html에 접근 못하게막기. [8] Habile 2009.06.15
업데이트 후 Rewrite mod 사용이 안돼는 경우 [2] 겨우리851 2009.06.18
XE용 query xml 방식으로 일반 테이블도 접근 처리 하기 [1] 라르게덴 2009.06.18
확장변수 폼 디자인 하기 [14] file Diver 2009.06.21
게시판 메뉴에 새글 알림 표시 띄우기 [13] file 보거스내친구 2009.06.21
개인쪽지발송!~ noirzo 2009.06.23
로그인 후 그룹별로 다른 페이지로 가기 - 업데이트판 v1.5 [19] 무대포2 2009.06.24
쪽지 답글 보내기 원본 내용 삭제 절망린 2009.06.24
보낸 쪽지함에서 쪽지 내용 안에 회원 아이콘이 제대로 표시 되지 않을때.. 절망린 2009.06.24
페이지 제일 위로 바로가는 Top 버튼 [5] file 개돌 2009.06.26
로그인 & 파일 첨부 문제 [3] peter99 2009.06.29
이미지 리사이즈 적용이 안되는 경우 [4] 아고라 2009.06.30
확장변수에 회원정보를 넣어보자 [10] file 개돌 2009.06.30
지오피아 게임 제로보드 XE 연동 [5] file 다른사람 2009.06.30
달력형 리스트 입니다. [5] file 착한악마 2009.07.01
제로보드 매뉴얼 version 0.63 입니다. [16] file 윈매니아 2009.07.03