使用PHP制作新闻系统的思路

  • A+
所属分类:PHP编程

我们可以用新闻系统来存储新闻,我们可以对新闻进行添加、删除等操作,这样减少了大家的工作量,为什么不实验一下。

首先,建立一个表。

  1. create table news (
  2. n_id int(255) not null auto_increment,
  3. n_date datetime not null,
  4. news text not null,
  5. primary key(n_id)
  6. );

第二步,设置你的登陆信息

  1. $database_user_name="root";
  2. $database_password="";
  3. $database_name="news";
  4. $time_offset="0";

第三步,让我们把后面程序用到的东西作成函数,节省篇幅啊!

  1. function connect_db()
  2. {
  3. // connects to the database
  4. global $database_user_name, $database_password;
  5. $db=mysql_connect("localhost",$database_user_name,$database_password);
  6. return $db;
  7. }
  8. function db_name()
  9. {
  10. // returns the name of the database
  11. global $database_name;
  12. $db_name=$database_name;
  13. return $db_name;
  14. }
  15. function get_now()
  16. {
  17. // gets current date and time
  18. $db=connect_db();
  19. $db_name=db_name();
  20. mysql_select_db($db_name,$db);
  21. $sql="select now() as now";
  22. $result=mysql_query($sql,$db);
  23. $myrow=mysql_fetch_array($result);
  24. $now=$myrow["now"];
  25. return $now;
  26. }

第四步,让我们考虑如何将新闻显示出来

//上面已经定义的函数库...

//表格的定义......

  1. <center><FONT SIZE=5 FACE="'georgia',verdana,Arial,Lucida Sans,Gill Sans">$title ";
  2. if ($admin==1)
  3. {
  4. echo " Admin ";
  5. }
  6. echo " - News</font>
  7. </td></tr>
  8. ";
  9. $db=connect_db();
  10. $db_name=db_name();
  11. mysql_select_db($db_name,$db);
  12. if ($show_news_sub)
  13. {
  14. $show_news = $show_news_sub;
  15. }
  16. if (!ereg("([0-9]{".strlen($show_news)."})",$show_news))
  17. {
  18. $show_news="ALL";
  19. }
  20. if (strtoupper($show_news)=="ALL")
  21. {
  22. $sql="select date_format(n_date,'%m/%d/%Y') as n_date, date_format(n_date,'%H:%i') as n_time ,news , n_date as date from news order by date desc";
  23. }
  24. else
  25. {
  26. $link="<a href=$REQUEST_URL?show_news_sub=ALL><FONT SIZE=-2  FACE="'georgia',verdana,Arial,Lucida Sans,Gill Sans">All news</font></a>";
  27. $sql="select date_format(n_date,'%m/%d/%Y') as n_date, date_format(n_date,'%H:%i') as n_time , news , n_date as date from news order by n_date desc limit $show_news";
  28. }
  29. $result=mysql_query($sql,$db);
  30. $num_rows=mysql_num_rows($result);
  31. if($num_rows!=0)
  32. {
  33. echo "
  34. ";
  35. while($myrow=mysql_fetch_array($result))
  36. {
  37. $date=$myrow["n_date"];
  38. $time=$myrow["n_time"];
  39. $news=$myrow["news"];
  40. $n_id=$myrow["n_id"];
  41. if (strtoupper($show_date)=="Y" && strtoupper($show_time)=="Y")
  42. {
  43. $show=$date." ".$time;
  44. }
  45. else if (strtoupper($show_date)=="Y" && strtoupper($show_time)!="Y")
  46. {
  47. $show=$date;
  48. }
  49. if (strtoupper($show_date)!="Y" && strtoupper($show_time)=="Y")
  50. {
  51. $show=$time;
  52. }
  53. $cleannews=(nl2br($news));
  54. <TD align=left><FONT SIZE=-2  FACE="'verdana',Arial,Lucida Sans,Gill Sans">$show<br>$cleannews</font</TD>
  55. ";
  56. }
  57. echo "
  58. ";
  59. }
  60. if ($admin==1)
  61. {
  62. echo "
  63. <center><a href=admin/index.php><FONT SIZE=-2 FACE="'verdana',Arial,Lucida Sans,Gill Sans">返回</font></a></center>
  64. ";
  65. }
  66. if ($link)
  67. {
  68. echo "<center><br><br>$link</center>";
  69. }

说明:省略了格式方面的标签,这样看起来思路清晰些,你可要加上啊