首页 >后端开发 >php教程 >PHP书签系统案例

PHP书签系统案例

墨辰丷
墨辰丷原创
2018-06-05 14:45:262134浏览

本篇文章主要介绍PHP书签系统案例,感兴趣的朋友参考下,希望对大家有所帮助。

1、需求分析

首先,需要识别每个用户。应该有验证机制。
其次,需要保存单个用户的书签。用户应该能够添加和删除书签。
再次,需要根据对他们的了解,向用户建议他们可能感兴趣的站点。

2、解决方案2.1 系统流程图

2.2 PHPbookmark中的文件列表

3、实现数据库

create database bookmarks; 
use bookmarks; 
 
create table user ( 
 username varchar(16) primary key, 
 passwd char(40) not null, 
 email varchar(100) not null 
); 
 
create table bookmark ( 
 username varchar(16) not null, 
 bm_URL varchar(255) not null, 
 index (username), 
 index (bm_URL) 
); 
 
grant select, insert, update, delete 
on bookmarks.* 
to bm_user@localhost identified by 'password';

4、实现基本的网站4.1 login.php

<?php 
 
/** 
 * 包含系统登录表单的页面 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;);  //应用程序的包含文件集合 
   
  do_html_header(&#39;&#39;); //HTML标题 
   
  display_site_info();//HTML站点信息 
  display_login_form();//HTML登录信息 
   
  do_html_footer();  //HTML页脚 
?>

4.2 bookmark_fns.php

<?php 
 
/** 
 * 应用程序的包含文件集合 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;data_valid_fns.php&#39;); //确认用户输入数据有效的函数 
  require_once(&#39;db_fns.php&#39;); // 连接数据库的函数 
  require_once(&#39;user_auth_fns.php&#39;); //用户身份验证的函数 
  require_once(&#39;output_fns.php&#39;); //以HTML形式格式化输出的函数 
  require_once(&#39;url_fns.php&#39;);  //增加和删除书签的函数 
?>

5、实现用户身份验证5.1 register_form.php

<?php 
 
/** 
 * 系统中用户注册表单 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
  do_html_header(&#39;User Registration&#39;);  //HTML标题 
   
  display_registeration_form();  //输出注册表单 
   
  do_html_footer();  //HTML页脚 
?>

5.2 register_new.php

<?php 
 
/** 
 * 处理新注册信息的脚本 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
   
  //创建变量 
  $email = $_POST[&#39;email&#39;]; 
  $username = $_POST[&#39;username&#39;]; 
  $passwd = $_POST[&#39;passwd&#39;]; 
  $passwd2 = $_POST[&#39;passwd2&#39;]; 
 
  //开启会话 
  session_start(); 
   
  try 
  { 
    //检查表单是否填写满 
    if(!filled_out($_POST)) 
    { 
      throw new exception(&#39;You have not filled the form out correctly - please go back and try again.&#39;); 
    } 
     
    //检查邮件地址是否有效 
    if(!valid_email($email)) 
    { 
      throw new exception(&#39;That is not a vald email address. Please go back try again.&#39;); 
    } 
     
    //检查两次输入密码是否相同 
    if($passwd != $passwd2) 
    { 
      throw new exception(&#39;The passwords you entered do not match - please go back try again.&#39;); 
    } 
     
    //检查密码长度是否合格 
    if((strlen($passwd) < 6) || (strlen($passwd) > 16)) 
    { 
      throw new exception(&#39;Your password must be between 6 and 16 characters Please go back and try again.&#39;); 
    } 
     
    //尝试注册 
    register($username,$email,$passwd); 
     
    //注册会话变量 
    $_SESSION[&#39;valid_user&#39;] = $username; 
     
    //提供成员页面链接 
    do_html_header(&#39;Registration successful&#39;); //HTML标题 
    echo &#39;Your registration was successful.Go to the members page to start setting up your bookmarks!&#39;; //输出URL 
    do_html_URL(&#39;member.php&#39;,&#39;Go to members page&#39;); //HTML页脚 
    do_html_footer();  //HTML页脚 
  } 
  catch(exception $e) 
  { 
    do_html_header(&#39;Problem:&#39;); 
    echo $e->getMessage(); 
    do_html_footer(); 
    exit; 
  } 
?>

5.3 member.php

<?php 
 
/** 
 * 用户的主页面,包含该用户所有的当前书签 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
  session_start(); 
   
  //创建变量 
  $username = @$_POST[&#39;username&#39;]; 
  $passwd = @$_POST[&#39;passwd&#39;]; 
   
  if($username && $passwd) 
  { 
    try 
    { 
      login($username,$passwd); 
      //如果该用户在数据库中,则注册会话变量 
      $_SESSION[&#39;valid_user&#39;] = $username; 
    } 
    catch(exception $e) 
    { 
      //登录不成功 
      do_html_header(&#39;Problem:&#39;); 
      echo &#39;You could not be logged in. You must be logged in to view this page.&#39;; 
      do_html_URL(&#39;login.php&#39;,&#39;Login&#39;); 
      do_html_footer(); 
      exit; 
    } 
  } 
   
  do_html_header(&#39;Home&#39;); 
  check_valid_user(); 
   
  //获取用户的书签 
  if($url_array = get_user_urls($_SESSION[&#39;valid_user&#39;])) 
    display_user_urls($url_array); 
  //获取用户菜单选项 
  display_user_menu(); 
 
  do_html_footer(); 
?>

5.4 logout.php

<?php 
 
/** 
 * 将用户注销的脚本 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
  session_start(); 
  $old_user = $_SESSION[&#39;valid_user&#39;]; 
   
  //注销会话变量 
  unset($_SESSION[&#39;valid_user&#39;]); 
  $result_dest = session_destroy(); 
   
  do_html_header(&#39;Logging Out&#39;); 
   
  if(!empty($old_user)) 
  { 
    if($result_dest)  //登出成功 
    { 
      echo &#39;Logged out.<br />&#39;; 
      do_html_URL(&#39;login.php&#39;,&#39;Login&#39;); 
    } 
    else  //不成功 
    { 
      echo &#39;Could not log you out.<br />&#39;; 
    } 
  } 
  else 
  { 
    echo &#39;You were not logged in, and so have not been logged ot.<br />&#39;; 
    do_html_URL(&#39;login.php&#39;,&#39;Login&#39;); 
  } 
  do_html_footer(); 
?>

5.5 change_passwd.php

<?php 
 
/** 
 * 修改数据库中用户密码的表单 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
  session_start(); 
  do_html_header(&#39;Changing password&#39;); 
   
  //创建变量 
  $old_passwd = $_POST[&#39;old_passwd&#39;]; 
  $new_passwd = $_POST[&#39;new_passwd&#39;]; 
  $new_passwd2 = $_POST[&#39;new_passwd2&#39;]; 
   
  try 
  { 
    check_valid_user(); 
    if(!filled_out($_POST)) 
      throw new exception(&#39;You have not filled out the form completely.Please try again.&#39;); 
     
    if($new_passwd != $new_passwd2) 
      throw new exception(&#39;Passwords entered were not the same. Not changed.&#39;); 
       
    if((strlen($new_passwd) > 16) || (strlen($new_passwd) < 6)) 
    { 
      throw new exception(&#39;New password must be between 6 and 16 characters. Try again.&#39;); 
    } 
     
    //尝试修改 
    change_password($_SESSION[&#39;valid_user&#39;],$old_passwd,$new_passwd); 
    echo &#39;Password changed.&#39;; 
  } 
  catch(exception $e) 
  { 
    echo $e ->getMessage(); 
  } 
  display_user_menu(); 
  do_html_footer(); 
?>

5.6 forgot_paswd.php

<?php 
 
/** 
 * 重新设置遗忘密码的脚本 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
  do_html_header("Resetting password"); 
   
  //创建变量 
  $username = $_POST[&#39;username&#39;]; 
   
  try 
  { 
    $passwd = reset_password($username); 
    notify_password($username,$passwd); 
    echo &#39;Your new password has been emailed to you.<br />&#39;; 
  } 
  catch(exception $e) 
  { 
    echo &#39;Your password could not be reset - please try again later.&#39;; 
  } 
  do_html_URL(&#39;login.php&#39;,&#39;Login&#39;); 
  do_html_footer(); 
?>

6、实现书签的存储和检索6.1 add_bms.php

<?php 
 
/** 
 * 添加书签的表单 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
  session_start(); 
   
  //创建变量 
  $new_url = $_POST[&#39;new_url&#39;]; 
   
  do_html_header(&#39;Adding bookmarks&#39;); 
   
  try 
  { 
    check_valid_user(); //检查用户有效性 
    if(!filled_out($new_url))  //检查表单是否填写 
      throw new exception(&#39;Form not completely filled out.&#39;); 
    if(strstr($new_url,&#39;http://&#39;) === false) 
      $new_url = &#39;http://&#39;. $new_url; 
    if(!(@fopen($new_url,&#39;r&#39;))) //可以调用fopen()函数打开URL,如果能打开这个文件,则假定URL是有效的 
      throw new exception(&#39;Not a valid URL.&#39;); 
    add_bm($new_url);  //将URL添加到数据库中 
    echo &#39;Bookmark added.&#39;; 
    if($url_array = get_user_urls($_SESSION[&#39;valid_user&#39;])) 
      display_user_urls($url_array); 
  } 
  catch(exception $e) 
  { 
    echo $e ->getMessage(); 
  } 
  display_user_menu(); 
  do_html_footer(); 
?>

6.2 delete_bms.php

<?php 
 
/** 
 * 从用户的书签列表中删除选定书签的脚本呢 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
  session_start(); 
   
  //创建变量 
  $del_me = @$_POST[&#39;del_me&#39;]; 
  $valid_user = $_SESSION[&#39;valid_user&#39;]; 
   
  do_html_header(&#39;Deleting bookmarks&#39;); 
  check_valid_user(); 
   
  if(!filled_out($del_me))  // 
  { 
    echo &#39;<p>You have not chosen any bookmarks to delete.<br />Please try again.</p>&#39;; 
    display_user_menu(); 
    do_html_footer(); 
    exit; 
  } 
  else 
  { 
    if(count($del_me) > 0) 
    { 
      foreach($del_me as $url) 
      { 
        if(delete_bm($valid_user,$url)) 
        { 
          echo &#39;Deleted &#39;. htmlspecialchars($url) .&#39;.<br />&#39;; 
        } 
        else 
        { 
          echo &#39;Could not delete &#39;. htmlspecialchars($url) .&#39;.<br />&#39;; 
        } 
      } 
    } 
    else 
    { 
      echo &#39;No bookmarks selected for deletion&#39;; 
    } 
  } 
  if($url_array = get_user_urls($valid_user)) 
  { 
    display_user_urls($url_array); 
  } 
  display_user_menu(); 
  do_html_footer(); 
?>

6.3 recommend.php

<?php 
 
/** 
 * 基于用户以前的操作,推荐用户可能感兴趣的书签 
 */ 
  //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。 
  require_once(&#39;bookmark_fns.php&#39;); 
  session_start(); 
  do_html_header(&#39;Recommending URLs&#39;); 
  try 
  { 
    check_valid_user(); 
    $urls = recommend_urls($_SESSION[&#39;valid_user&#39;]); 
    display_recommended_urls($urls); 
  } 
  catch(exception $e) 
  { 
    echo $e ->getMessage(); 
  } 
  display_user_menu(); 
  do_html_footer(); 
?>

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。

相关推荐:

PHP中类属性与类静态变量的访问方法实例

php cookie工作原理及实例详解

PHP 使用socket 模拟POST的方法

以上是PHP书签系统案例的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn