設定 EYNY 為首頁  |  加入我的最愛
伊莉討論區
熱門搜尋: 海角七號  囧男孩  柯南  神奇寶貝  戰慄的樂譜  周杰倫  防毒  鷹眼 


休閒聊天
學術文化
感情感性
興趣交流
家庭事務
旅遊交流
飲食交流
家族門派
貼圖分享
動漫交流
音樂世界
美容打扮
潮流資訊
影視娛樂
電玩遊戲
連線遊戲
網絡遊戲
交易廣場
下載分享
BT下載區
CB下載區
電腦資訊
數碼產品
手機交流
網站事務
體育運動
時事新聞
上班一族
博彩娛樂
成人話題


 
標題: [求助] 有PHP高手嗎 最近在搞PHP聊天
angelevil

Rank: 1
幼兒生(0/200)
潛水  
UID 1644437
精華 0
積分 87
帖子 98
潛水 1179 米
閱讀權限 10
註冊 2007-6-26
發表於 2007-10-8 11:28 PM  資料 文集 短消息 
伊莉部落格伊莉交友伊莉聊天伊莉相簿

有PHP高手嗎 最近在搞PHP聊天

[顯示] [隱藏]
最近在寫聊天室 遇到兩個問題
第一個問題 怎麼寫 都無法寫出 如果沒有輸入訊息 訊息還是會被送出

第二個問題 只要按下 [重整] 之前輸入的訊息 並不會不見 而是會重複po上去

第三個 如果我要讓輸出的 資訊 是有表格的 我應該在哪個程式段 改呢

我架設的地點 http://210.208.58.59/gamebk2
程式碼 chat.php (我有省略一些不重要的了)
<?
if(!$chatname) {
print_form();
exit;
};

foreach ($online_array as $user_on) {
$fields = explode(",",$user_on);

if( $fields[0] < $lasttenmin ){
break;
}
if( $fields[1] == "$chatname\n" ){
break;
}

$updated .= $user_on;
}

$updated .= "$rightnow\,$chatname\n";
$online = stripslashes($updated);

$chatname = htmlspecialchars($chatname);
$message = htmlspecialchars($message);
$new_message = "<font color=00008B><b>$time</b><font color=FF0000 ><b>$chatname</b> $from_ip $dod $level $bob :<font color=\"$myfont\"> $message<p>\n </font>";

$header = "<html><head>".
"<meta http-equiv=\"pragma\" content=\"no-cache\">".
"<meta name=\"robots\" content=\"noindex\"></head>".
"<body bgcolor=\"#ffffff\" text=\"#000000\"><p>".
"<embed src=\"alert.wma\" width=2 height=0 autostart=true loop=false> <noembed> <bgsound src=\"alert.wma\" loop=none> </noembed>\n";

$footer = "</body>"."</html>";

$open_file = fopen("messages.htm", "w");
fputs($open_file, $header);
fputs($open_file, stripslashes($new_message));
fputs($open_file, $old_messages);
fputs($open_file, $footer);
fclose($open_file);

$open_file = fopen("history.htm", "w");
fputs($open_file, $header);
fputs($open_file, stripslashes($new_message));
fputs($open_file, $old_history);
fputs($open_file, $footer);
fclose($open_file);

print_form_nameset();

function print_form()
{
global $chatname;
global $PHP_SELF;
echo <<<FORM1
<link href="css.css" rel="stylesheet" type="text/css" />
</head>
<body bgcolor="#cccccc" text="#000000">

<table width="100%" border="0" cellspacing="0" cellpadding="0">
<tr>
<td >
<form name="chat" method="post" action="$PHP_SELF" >
[ 瀏覽完整內容請先註冊或登入會員。]

頂部
alpe

Rank: 2Rank: 2
小學生(200/1000)
潛水  
UID 1117501
精華 0
積分 571
帖子 500
潛水 362 米
閱讀權限 20
註冊 2007-4-18
發表於 2007-10-16 01:09 AM  資料 文集 短消息 
伊莉部落格伊莉交友伊莉聊天伊莉相簿

Q1.
ans:
$message != '';
or javascript

Q2.
... ... ... ... javascript

Q3.
ans. 取消, 不過會被人家玩 javascript injection, html  injection
$message = htmlspecialchars($message);

頂部
skyretch

Rank: 1
幼兒生(0/200)
潛水  
UID 2681970
精華 0
積分 127
帖子 72
潛水 54 米
閱讀權限 10
註冊 2007-10-31
發表於 2007-11-10 01:05 PM  資料 文集 短消息 
維克斯討論區

Q1. Submit前用JS作check到php在做一次check,檢查是不是空值就行了

Q2.print_form前清一次變數 或在print_form用JS清掉input的value

頂部
 




當前時區 GMT+8, 現在時間是 2008-10-13 05:04 PM

    本论坛支付平台由支付宝提供
携手打造安全诚信的交易社区 Powered by Discuz! 5.0.0  © 2001-2006 Comsenz Inc.
Processed in 0.078053 second(s), 6 queries , Gzip enabled

清除 Cookies - 聯繫我們 - 廣告查詢 [威旭代理] - 伊莉討論區 - Archiver
重要聲明:本討論區是以即時上載留言的方式運作,伊莉討論區對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。伊莉討論區有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿撰寫粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。