[X] Choose Font Here

Creating a simple PHP forum

forumဒီ POST ကေတာ့ 2009 ရဲ႕ ပထမဆုံး POST ပါ။ ကြၽန္ေတာ္ အလုပ္ေတြမ်ားေနလို႔ POST အသစ္မေရး

ႏိုင္တာကို ေတာင္းပန္ပါတယ္။ Site ထဲမွာ တစ္ေယာက္က Forum နဲ႔ ဆိုင္တဲ့ အေၾကာင္းေလး လာေမးသြားလို႔

ဒီ POST ကိုေရးဖို႔ idea ရသြားတာပါ။ PHP Based simple Forum တစ္ခုကို ဘယ္လို create လုပ္တယ္

ဆိုတာကို ကြၽန္ေတာ္သိသေလာက္ ရွင္းျပ မွာပါ။ ေျပာမယ္ ဆိုရင္ Forum ရဲ႕ skeleton လို႔ ေျပာႏိုင္ပါတယ္။

ဘာလို႔လည္း ဆိုရင္ ဘယ္ Forum ကိုပဲၾကည့္ၾကည့္ Basic Logic ကဒါပဲေလ။ အဲဒါကို ထပ္ျပီး

modify လုပ္ထားတာ ျဖစ္ပါတယ္။ Forum အေၾကာင္းေလး စလိုက္ၾကရေအာင္ Smile


Overview အေနနဲ႔ ေျပာမယ္ဆိုရင္ ဒီ php 5 files လိုပါတယ္။

In this tutorial create 5 files


1. create_topic.php
2. add_topic.php
3. main_forum.php
4. view_topic.php
5. add_answer.php

Steps ေတြကေတာ့

1. Create table name "forum_question" and "forum_answer" in database "test".
2. Create file create_topic.php.
3. Create file add_topic. php.
4. Create file main_forum.php
5. Create file view_topic.php
6. Create file add_answer.php




Step 1

အရင္ဆုံး လိုအပ္တဲ့ table ၂ ခုျဖစ္တဲ့ forum_question နဲ႔ forum_answer ကို create လုပ္ပါမယ္။ ဒါက table ပုံပါ။

 

DB

 

 

 

 

 

 

 

 

 

 

 

 

ဒါကေတာ့ sql script ျဖစ္ပါတယ္။

Table forum_question
CREATE TABLE `forum_question` (
`id` int(4) NOT NULL auto_increment,
`topic` varchar(255) NOT NULL default '',
`detail` longtext NOT NULL,
`name` varchar(65) NOT NULL default '',
`email` varchar(65) NOT NULL default '',
`datetime` varchar(25) NOT NULL default '',
`view` int(4) NOT NULL default '0',
`reply` int(4) NOT NULL default '0',
PRIMARY KEY (`id`)
) TYPE=MyISAM AUTO_INCREMENT=1 ;

Table forum_answer
CREATE TABLE `forum_answer` (
`question_id` int(4) NOT NULL default '0',
`a_id` int(4) NOT NULL default '0',
`a_name` varchar(65) NOT NULL default '',
`a_email` varchar(65) NOT NULL default '',
`a_answer` longtext NOT NULL,
`a_datetime` varchar(25) NOT NULL default '',
KEY `a_id` (`a_id`)
) TYPE=MyISAM;

 

Step 2

Forum ေတြမွာ topic ေတြကို create လုပ္ႏိုင္ပါတယ္။ အဲဒီ php script ကိုေရးပါမယ္။ topic create လုပ္တဲ့ html form ကို ပုံထဲမွာ

ၾကည့္ႏိုင္ပါတယ္။

topic create

 

 

 

 

 

 

 

 

 

 

 

 

simple ေလးပါပဲ textbox, textarea, submit button ေတြပဲပါ ပါတယ္။ submit ကို click လုပ္ရင္ေတာ့ form action အရ

add_topic.php ကို run ပါလိမ့္မယ္။ ဒါကေတာ့ create_topic.php ရဲ႕ code ပါ

 

<table width="400" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC">
<tr>
<form id="form1" name="form1" method="post" action="add_topic.php">
<td>
<table width="100%" border="0" cellpadding="3" cellspacing="1" bgcolor="#FFFFFF">
<tr>
<td colspan="3" bgcolor="#E6E6E6"><strong>Create New Topic</strong> </td>
</tr>
<tr>
<td width="14%"><strong>Topic</strong></td>
<td width="2%">:</td>
<td width="84%"><input name="topic" type="text" id="topic" size="50" /></td>
</tr>
<tr>
<td valign="top"><strong>Detail</strong></td>
<td valign="top">:</td>
<td><textarea name="detail" cols="50" rows="3" id="detail"></textarea></td>
</tr>
<tr>
<td><strong>Name</strong></td>
<td>:</td>
<td><input name="name" type="text" id="name" size="50" /></td>
</tr>
<tr>
<td><strong>Email</strong></td>
<td>:</td>
<td><input name="email" type="text" id="email" size="50" /></td>
</tr>
<tr>
<td> </td>
<td> </td>
<td><input type="submit" name="Submit" value="Submit" /> <input type="reset" name="Submit2" value="Reset" /></td>
</tr>
</table>
</td>
</form>
</tr>
</table>

 

Step 3

add_topic.php အေၾကာင္းဆက္ေရး ပါမယ္။ ဒီ php ကေတာ့ create_topic.php ကေနျပီး pass လုပ္လိုက္တဲ့ Data ေတြကို

forum_question table ထဲ Insert ခ်တဲ့ php script ျဖစ္ပါတယ္။

 

<?php
$host="localhost"; // Host name
$username=""; // Mysql username
$password=""; // Mysql password
$db_name="test"; // Database name
$tbl_name="forum_question"; // Table name

// Connect to server and select database.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");

// get data that sent from form
$topic=$_POST['topic'];
$detail=$_POST['detail'];
$name=$_POST['name'];
$email=$_POST['email'];

$datetime=date("d/m/y h:i:s"); //create date time

$sql="INSERT INTO $tbl_name(topic, detail, name, email, datetime)VALUES('$topic', '$detail', '$name', '$email', '$datetime')";
$result=mysql_query($sql);

if($result){
echo "Successful<BR>";
echo "<a href=main_forum.php>View your topic</a>";
}
else {
echo "ERROR";
}
mysql_close();
?>

 

Step 4

main_forum.php ဆိုတာကို ဆက္ျပီး လုပ္ပါမယ္။ ဒီ php ကေတာ့ ရွိျပီးသား topic ေတြကို list အေနနဲ႔ ျပထားတာပါ။ forum_question

table ကို ဖတ္ျပီး looping နဲ႔ ျပန္ျပတာ ျဖစ္ပါတယ္။ ေနာက္ topic အသစ္ create လုပ္ခ်င္ရင္ "Create New Topic" ကို Click လိုက္ပါ။

ေအာက္က ပုံေလးကို ၾကည့္ရင္ ပို ရွင္းပါ လိမ့္မယ္။

forum_show

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

main_forum.php ရဲ႕ code ပါ။

 

<?php
$host="localhost"; // Host name
$username=""; // Mysql username
$password=""; // Mysql password
$db_name="test"; // Database name
$tbl_name="forum_question"; // Table name

// Connect to server and select databse.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");

$sql="SELECT * FROM $tbl_name ORDER BY id DESC";
// OREDER BY id DESC is order result by descending
$result=mysql_query($sql);
?>
<table width="90%" border="0" align="center" cellpadding="3" cellspacing="1" bgcolor="#CCCCCC">
<tr>
<td width="6%" align="center" bgcolor="#E6E6E6"><strong>#</strong></td>
<td width="53%" align="center" bgcolor="#E6E6E6"><strong>Topic</strong></td>
<td width="15%" align="center" bgcolor="#E6E6E6"><strong>Views</strong></td>
<td width="13%" align="center" bgcolor="#E6E6E6"><strong>Replies</strong></td>
<td width="13%" align="center" bgcolor="#E6E6E6"><strong>Date/Time</strong></td>
</tr>

<?php
while($rows=mysql_fetch_array($result)){ // Start looping table row
?>
<tr>
<td bgcolor="#FFFFFF"><? echo $rows['id']; ?></td>
<td bgcolor="#FFFFFF"><a href="view_topic.php?id=<? echo $rows['id']; ?>"><? echo $rows['topic']; ?></a><BR></td>
<td align="center" bgcolor="#FFFFFF"><? echo $rows['view']; ?></td>
<td align="center" bgcolor="#FFFFFF"><? echo $rows['reply']; ?></td>
<td align="center" bgcolor="#FFFFFF"><? echo $rows['datetime']; ?></td>
</tr>

<?php
// Exit looping and close connection
}
mysql_close();
?>
<tr>
<td colspan="5" align="right" bgcolor="#E6E6E6"><a href="create_topic.php"><strong>Create New Topic</strong> </a></td>
</tr>
</table>

 


Step 5

ဒီ Step ကေတာ့ view_topic.php ကို create လုပ္မွာ ျဖစ္ပါတယ္။ ဒီေကာင္က နည္းနည္း ႐ႉပ္တယ္ဗ်။ ကြၽန္ေတာ္ တတ္ႏိုင္သေလာက္

ရွင္းေအာင္ေရး ေပးပါမယ္။ Forum ရဲ႕ သေဘာတရား မွာ topic ေတြထဲက ကိုသိတဲ့ topic ကို ျပန္ျပီး ေျဖခ်င္တယ္ ဆိုရင္ topic ကို

click လိုက္။

ဥပမာ user က "Topic A" ကို click လိုက္တယ္ ဆိုရင္ program က လုပ္ေပးရ မွာက "Topic A" ကို ေျဖထားတဲ့ answer

ေတြကို ဆြဲထုတ္ျပီး list နဲ႔ ျပေပးရမယ္။ "Topic A" အတြက္ view counter ကို တစ္တိုး ေပးရပါမယ္။ ေအာက္က ပုံကေတာ့

view_topic.php မွာ ရွိတဲ့ life cycle ေလးပါ။

forum_create_topic

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

mockup_viewtopic_forum1

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

mockup_viewtopic_forum2

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

mockup_viewtopic_forum3

 

 

 

 

 

 

 

 

 

 

 

 

 

view_topic.php ရဲ႕ coding ပါ။

 

<?php
$host="localhost"; // Host name
$username=""; // Mysql username
$password=""; // Mysql password
$db_name="test"; // Database name
$tbl_name="forum_question"; // Table name

// Connect to server and select databse.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");

// get value of id that sent from address bar
$id=$_GET['id'];

$sql="SELECT * FROM $tbl_name WHERE id='$id'"; //user click လိုက္တဲ့ topic ကိုရွာျပီးျပတာ ျဖစ္ပါတယ္။
$result=mysql_query($sql);

$rows=mysql_fetch_array($result);
?>
<table width="400" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC">
<tr>
<td><table width="100%" border="0" cellpadding="3" cellspacing="1" bordercolor="1" bgcolor="#FFFFFF">
<tr>
<td bgcolor="#F8F7F1"><strong><? echo $rows['topic']; ?></strong></td>
</tr>

<tr>
<td bgcolor="#F8F7F1"><? echo $rows['detail']; ?></td>
</tr>

<tr>
<td bgcolor="#F8F7F1"><strong>By :</strong> <? echo $rows['name']; ?><strong>Email : </strong><? echo $rows['email'];?></td>
</tr>

<tr>
<td bgcolor="#F8F7F1"><strong>Date/time : </strong><? echo $rows['datetime']; ?></td>
</tr>
</table></td>
</tr>
</table>
<BR>
<?php
$tbl_name2="forum_answer"; // Switch to table "forum_answer"

$sql2="SELECT * FROM $tbl_name2 WHERE question_id='$id'";

//forum_answer table ထဲကေန ရွိထားျပီး သား အေျဖေတြကို ဆြဲထုတ္ျပ တာျဖစ္ပါတယ္။
$result2=mysql_query($sql2);

while($rows=mysql_fetch_array($result2)){
?>
<table width="400" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC">
<tr>
<td><table width="100%" border="0" cellpadding="3" cellspacing="1" bgcolor="#FFFFFF">
<tr>
<td bgcolor="#F8F7F1"><strong>ID</strong></td>
<td bgcolor="#F8F7F1">:</td>
<td bgcolor="#F8F7F1"><? echo $rows['a_id']; ?></td>
</tr>
<tr>
<td width="18%" bgcolor="#F8F7F1"><strong>Name</strong></td>
<td width="5%" bgcolor="#F8F7F1">:</td>
<td width="77%" bgcolor="#F8F7F1"><? echo $rows['a_name']; ?></td>
</tr>
<tr>
<td bgcolor="#F8F7F1"><strong>Email</strong></td>
<td bgcolor="#F8F7F1">:</td>
<td bgcolor="#F8F7F1"><? echo $rows['a_email']; ?></td>
</tr>
<tr>
<td bgcolor="#F8F7F1"><strong>Answer</strong></td>
<td bgcolor="#F8F7F1">:</td>
<td bgcolor="#F8F7F1"><? echo $rows['a_answer']; ?></td>
</tr>
<tr>
<td bgcolor="#F8F7F1"><strong>Date/Time</strong></td>
<td bgcolor="#F8F7F1">:</td>
<td bgcolor="#F8F7F1"><? echo $rows['a_datetime']; ?></td>
</tr>
</table></td>
</tr>
</table><br>

<?
}

$sql3="SELECT view FROM $tbl_name WHERE id='$id'"; //view hit ကို control လုပ္တဲ့ ေနရာပါ။
$result3=mysql_query($sql3);

$rows=mysql_fetch_array($result3);
$view=$rows['view'];

// if have no counter value set counter = 1
if(empty($view)){
$view=1;
$sql4="INSERT INTO $tbl_name(view) VALUES('$view') WHERE id='$id'";
$result4=mysql_query($sql4);
}

// count more value
$addview=$view+1;
$sql5="update $tbl_name set view='$addview' WHERE id='$id'";
$result5=mysql_query($sql5);

mysql_close();
?>
<BR>
<table width="400" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC">
<tr>
<form name="form1" method="post" action="add_answer.php">

// form submit လုပ္ရင္ add_answer.php ဆိုတဲ့ php ကိုေခၚ ျပီး insert လုပ္ပါ လိမ့္မယ္။
<td>
<table width="100%" border="0" cellpadding="3" cellspacing="1" bgcolor="#FFFFFF">
<tr>
<td width="18%"><strong>Name</strong></td>
<td width="3%">:</td>
<td width="79%"><input name="a_name" type="text" id="a_name" size="45"></td>
</tr>
<tr>
<td><strong>Email</strong></td>
<td>:</td>
<td><input name="a_email" type="text" id="a_email" size="45"></td>
</tr>
<tr>
<td valign="top"><strong>Answer</strong></td>
<td valign="top">:</td>
<td><textarea name="a_answer" cols="45" rows="3" id="a_answer"></textarea></td>
</tr>
<tr>
<td> </td>
<td><input name="id" type="hidden" value="<? echo $id; ?>"></td>
<td><input type="submit" name="Submit" value="Submit"> <input type="reset" name="Submit2" value="Reset"></td>
</tr>
</table>
</td>
</form>
</tr>
</table>

 

Step 6

ေနာက္ဆုံးအဆင့္ add_answer.php ကို create လုပ္ပါမယ္။ add_answer.php ကေတာ့ user ကေျဖလိုက္တဲ့ answer ေတြကို

insert လုပ္ဖို႔ရယ္၊ reply လုပ္တဲ့ အေရအတြက္ ကို count လုပ္ဖို႔ ပါ။ ဒါကေတာ့ coding ပါ။

 

<?php
$host="localhost"; // Host name
$username=""; // Mysql username
$password=""; // Mysql password
$db_name="test"; // Database name
$tbl_name="forum_answer"; // Table name

// Connect to server and select databse.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");

// Get value of id that sent from hidden field
$id=$_POST['id'];

// Find highest answer number.
$sql="SELECT MAX(a_id) AS Maxa_id FROM $tbl_name WHERE question_id='$id'";
$result=mysql_query($sql);
$rows=mysql_fetch_array($result);

//Reply ကို update ခ်ခ်င္လို႔ answer table က id ကို max ရွာျပီး တစ္ တိုးတဲ့ ေနရာပါ။
// add + 1 to highest answer number and keep it in variable name "$Max_id". if there no answer yet set it = 1
if ($rows) {
$Max_id = $rows['Maxa_id']+1;
}
else {
$Max_id = 1;
}

// get values that sent from form
$a_name=$_POST['a_name'];
$a_email=$_POST['a_email'];
$a_answer=$_POST['a_answer'];

$datetime=date("d/m/y H:i:s"); // create date and time

// Insert answer //insert ခ်တဲ့ ေနရာပါ။
$sql2="INSERT INTO $tbl_name(question_id, a_id, a_name, a_email, a_answer, a_datetime)VALUES('$id', '$Max_id', '$a_name', '$a_email', '$a_answer', '$datetime')";
$result2=mysql_query($sql2);

if($result2){
echo "Successful<BR>";
echo "<a href='view_topic.php?id=".$id."'>View your answer</a>";

// If added new answer, add value +1 in reply column
$tbl_name2="forum_question";
$sql3="UPDATE $tbl_name2 SET reply='$Max_id' WHERE id='$id'"; //Reply ကို control လုပ္တဲ့ ေနရာပါ။
$result3=mysql_query($sql3);

}
else {
echo "ERROR";
}

mysql_close();
?>

 

Ref: http://www.phpeasystep.com/workshopview.php?id=12

 

တျခား PHP Post ေတြအားလုံး ကို ႏွစ္သက္ရာ ေရြးဖတ္ ခ်င္တယ္ဆိုရင္ ဒီ Link ေလးကို Click လိုက္ပါ။

 

 

 
Comments (0)
Write comment
Your Contact Details:
Comment:
[b] [i] [u] [url] [quote] [code] [img]   
:D:angry::angry-red::evil::idea::love::x:no-comments::ooo::pirate::?::(
:sleep::););)):0
Security
Please input the anti-spam code that you can read in the image.

Login Form

Categories Table View

JoomlaWatch Stats 1.2.9 by Matej Koval

Facebook Share

Share on facebook

Accordion FAQ

mod_joomtouch

Version Iphone

Version Iphone by JoomTouch