基于 PHP 实现的注册登录程序(CRUD)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 基于 PHP 实现的注册登录程序(CRUD)

一、实践要求


要求以前后端分离的形式,运用合适的语言平台开发一个注册、登录和信息修改的小程序。


二、实现思路


2.1 总体思路


  • 采用JQuery+PHP+JSON完成实验


  • 利用三层体系结构,即模型、视图、控制器实现前端、后端分离


  • 利用ajax实现异步刷新页面,实现资源合理利用


  • 设计登录界面,实现用户登录


  • 设计注册页面,实现用户注册,即“增”


  • 设计修改页面,实现用户信息修改,即“改“


2.2 体系结构



2.3 开发工具与平台介绍


2.3.1 Sublime Text



Sublime Text3 是一个代码编辑器,也是HTML和散文先进的文本编辑器。Sublime Text是由程序员Jon Skinner于2008年1月份所开发出来,它最初被设计为一个具有丰富扩展功能的Vim。


2.3.2 WAMP



Windows下的Apache+Mysql/MariaDB+Perl/PHP/Python,一组常用来搭建动态网站或者服务器的开源软件,本身都是各自独立的程序,但是因为常被放在一起使用,拥有了越来越高的兼容度,共同组成了一个强大的Web应用程序平台。随着开源潮流的蓬勃发展,开放源代码的LAMP已经与J2EE和.Net商业软件形成三足鼎立之势,并且该软件开发的项目在软件方面的投资成本较低,因此受到整个IT界的关注。LAMP是基于Linux,Apache,MySQL/MariaDB和PHP的开放资源网络开发平台,PHP是一种有时候用Perl或Python可代替的编程语言。这个术语来自欧洲,在那里这些程序常用来作为一种标准开发环境。名字来源于每个程序的第一个字母。每个程序在所有权里都符合开放源代码标准:Linux是开放系统;Apache是最通用的网络服务器;mySQL是带有基于网络管理附加工具的关系数据库;PHP是流行的对象脚本语言,它包含了多数其它语言的优秀特征来使得它的网络开发更加有效。开发者在Windows操作系统下使用这些Linux环境里的工具称为使用WAMP。


2.3.3 ajax


Ajax 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术。Ajax = 异步 JavaScript 和 XML 或者是 HTML(标准通用标记语言的子集)。Ajax 是一种用于创建快速动态网页的技术。Ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。


2.3.4 JSON


JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。


2.3.5 PHP (超文本预处理器)


PHP即“超文本预处理器”,是一种通用开源脚本语言。PHP是在服务器端执行的脚本语言,与C语言类似,是常用的网站编程语言。PHP独特的语法混合了C、Java、Perl以及 PHP 自创的语法。利于学习,使用广泛,主要适用于Web开发领域。


2.3.6 jQuery


jQuery是一个快速、简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架)。jQuery设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作、事件处理、动画设计和Ajax交互。jQuery的核心特性可以总结为:具有独特的链式语法和短小清晰的多功能接口;具有高效灵活的css选择器,并且可对CSS选择器进行扩展;拥有便捷的插件扩展机制和丰富的插件。


2.4 注册功能


  • 界面:


  1. 设置三个input文本输入框,一个为id,一个为username,一个为password填写注册信息


  1. 设置一个submit对填写信息的提交


  1. 设置一个超链接实现注册的页面跳转放回登录界面。


  • 功能:


  1. 点击保存实现用户的信息写入数据库


  1. 思路:通过mysqli连接MySQL数据库,将输入框中的数据保存在PHP的数组array中,利用json_encode和json_decode实现数值转换成json数据存储格式,最后利用SQL语句存入MySQL中


  • 关键源码


<?php
if(isset($_POST['save'])){
  $conn = new mysqli('localhost', 'root', '', 'app');
  $input = array(
    'id' => $_POST['id'],
    'username' => $_POST['username'],
    'password' => $_POST['password'],
  );
  $data[] = $input;
  $data = json_encode($data);
  $data = json_decode($data);
  echo $data[0]->id;
      foreach ($data as $user) {
      $sql="INSERT INTO members (id,username,userpassword) VALUES ($user->id,'$user->username','$user->password')";
      echo $sql;
      $result = $conn->query($sql);   // 查询执行成功
      echo $result;         // 返回1表示成功
  }
  header('location: index.php');
}
?>


2.5 登录功能


  • 界面:


  • 设置两个input文本输入框,一个为username,另一个为password输入用户名密码


  • 设置一个button登录按钮


  • 设置一个超链接实现注册的页面跳转


  • 关键代码


<?php
if(!empty($_POST['username'])){
  $data = array()
  //database details
  $dbHost     = 'localhost';
  $dbUsername = 'root';
  $dbPassword = '';
  $dbName     = 'app';
  //create connection and select DB
  $db = new mysqli($dbHost, $dbUsername, $dbPassword, $dbName);
  if($db->connect_error){
      die("Unable to connect database: " . $db->connect_error);
  }
  //get user data from the database
  $query = $db->query("SELECT * FROM members WHERE username = {$_POST['username']} and password = {$_POST['password']}" );
  if($query->num_rows > 0){
      $userData = $query->fetch_assoc();
      $data['status'] = 'ok';
      $data['result'] = $userData;
  }else{
      $data['status'] = 'err';
      $data['result'] = '';
  }
  //returns data as JSON format
  echo json_encode($data);
}
?>


<script src="jquery-3.4.1.js"></script>
    <script>
    $(document).ready(function(){
    $('#getUser').on('click',function(){
        $.ajax({
            type:'POST',
            url:'getData.php',
            dataType: "json",
            data: { // 要传递的数据
                "username": $("#username").val(),
                "password": $("#password").val()
            },
            success:function(data){
                if(data.status == 'ok'){
                    alert("登录成功!");
                    window.location.href="index.php" 
                }else{ alert("用户名或密码错误!");                    
                } }});});
     $("#username").blur(function (){
        $.ajax({
            type:'POST',
            url:'getData.php',
            dataType: "json",
            data: { // 要传递的数据
                "username": $("#username").val()
            },
            success:function(data){
                if(data.status == 'ok'){
                }else{
                    alert("用户名不存在!");
                } }});});});
</script>


  • 功能:


  1. 用户名输入框失去焦点,判断用户是否存在


思路:利用ID选择器,选择输入框username,利用JQuery的blur()事件判断是否失去焦点,利用ajax异步传值通过放回值,判断数据库中是否有该信息,若不存在则提示用户名不存在


  1. 点击确认判断用户名密码是否正确。


思路:利用ID选择器,选择输入框input,利用JQuery的click()事件判断是否触发事件,利用ajax异步传值通过放回值,判断数据库中用户名密码是否正确,它利用alert提示性


2.6 信息修改


  • 界面:


  1. 设置三个input文本输入框,一个为id,一个为username,一个为password填写修改信息


  1. 设置一个submit对填写信息的提交


  1. 设置一个超链接实现注册的页面跳转放回登录界面


  • 功能:


  1. 点击编辑实现用户的信息修改数据库


  1. 思路:通过mysqli连接MySQL数据库,将输入框中的数据保存在PHP的数组array中,利用json_encode和json_decode实现数值转换成json数据存储格式,最后利用SQL语句存入MySQL中


  • 关键代码


<?php
  if(isset($_POST['save'])){
    $conn = new mysqli('localhost', 'root', '', 'app');
    $input = array(
      'id' => $_POST['id'],
      'username' => $_POST['username'],
      'password' => $_POST['password'],
    );
    //update the selected index
    $data_array[$index] = $input;
    //encode back to json
    $data = json_encode($data_array);
    $data = json_decode($data); // 解析json
    echo $data[0]->id;
    foreach ($data as $user) {
        $sql="update members set username='$user->username',password='$user->password' where id=$user->id";
        echo $sql;
        $result = $conn->query($sql); //查询执行成功
        echo $result;//返回1表示成功
    }
    header('location: index.php');
  }
?>


2.7 信息删除


  • 功能:


  1. 点击删除实现用户的信息删除


  1. 思路:通过mysqli连接MySQL数据库,将输入框中的数据保存在PHP的数组array中,利用json_encode和json_decode实现数值转换成json数据存储格式,最后利用SQL语句存入MySQL中


  • 关键代码


<?php
$index = $_GET['index'];
  $conn = new mysqli('localhost', 'root', '', 'app');
$data = array();
$sql = "SELECT * FROM members";
$query = $conn->query($sql);
while($row = $query->fetch_assoc()){
  $data[] = $row;
}
//convert to json
$data = json_encode($data);
$data_array = json_decode($data);
//assign the data to selected index
$row = $data_array[$index];
$data = json_encode($data, JSON_PRETTY_PRINT);
$data = json_decode($data); // 解析json
$sql = "delete from members where id=$row->id";
    $query = $conn->query($sql);
header('location: index.php');
unset($data[$index]);
?>


2.8 数据库


挺简单的,没写查询语句。



三、成果展示


3.1 注册功能


注册前



注册



注册完成



3.2 登录功能


登录成功


登陆失败



3.3 信息修改功能


修改前



修改



3.4 信息删除功能


删除前



删除成功



四、项目链接


https://download.csdn.net/download/weixin_45525272/50416720

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
JavaScript 前端开发 安全
php学习笔记-普通表单参数提交获取及页面的重定向和一个登录小demo-day05
本文介绍了PHP中普通表单参数的提交获取、页面重定向的方法,并通过一个登录示例演示了表单参数的封装和页面跳转处理。
|
4月前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深入探索与实践在软件开发的广袤天地中,PHP以其独特的魅力和强大的功能,成为无数开发者手中的得力工具。而在这条充满挑战与机遇的征途上,设计模式犹如一盏明灯,指引着我们穿越代码的迷雾,编写出更加高效、灵活且易于维护的程序。今天,就让我们聚焦于设计模式中的璀璨明珠——策略模式,深入探讨其在PHP中的实现方法及其实际应用价值。
策略模式,这一设计模式的核心在于它为软件设计带来了一种全新的视角和方法。它允许我们在运行时根据不同情况选择最适合的解决方案,从而极大地提高了程序的灵活性和可扩展性。在PHP这门广泛应用的编程语言中,策略模式同样大放异彩,为开发者们提供了丰富的创作空间。本文将从策略模式的基本概念入手,逐步深入到PHP中的实现细节,并通过一个具体的实例来展示其在实际项目中的应用效果。我们还将探讨策略模式的优势以及在实际应用中可能遇到的挑战和解决方案,为PHP开发者提供一份宝贵的参考。
|
4月前
|
XML 前端开发 JavaScript
php中Ajax的简单使用,登录表单调用Ajax判断是否正确登录利用layer.msg进行提示
本文介绍了在PHP中如何使用Ajax进行登录表单的数据提交,并利用jQuery的$.post()方法与后端通信,以及使用layer.msg进行前端提示。
php中Ajax的简单使用,登录表单调用Ajax判断是否正确登录利用layer.msg进行提示
|
3月前
|
存储 缓存 安全
如何使用 PHP 将天气跟踪集成到 Web 应用程序中
如何使用 PHP 将天气跟踪集成到 Web 应用程序中
40 0
|
4月前
|
设计模式 存储 算法
PHP中的设计模式:策略模式的深入解析与应用在软件开发的浩瀚海洋中,PHP以其独特的魅力和强大的功能吸引了无数开发者。作为一门历史悠久且广泛应用的编程语言,PHP不仅拥有丰富的内置函数和扩展库,还支持面向对象编程(OOP),为开发者提供了灵活而强大的工具集。在PHP的众多特性中,设计模式的应用尤为引人注目,它们如同精雕细琢的宝石,镶嵌在代码的肌理之中,让程序更加优雅、高效且易于维护。今天,我们就来深入探讨PHP中使用频率颇高的一种设计模式——策略模式。
本文旨在深入探讨PHP中的策略模式,从定义到实现,再到应用场景,全面剖析其在PHP编程中的应用价值。策略模式作为一种行为型设计模式,允许在运行时根据不同情况选择不同的算法或行为,极大地提高了代码的灵活性和可维护性。通过实例分析,本文将展示如何在PHP项目中有效利用策略模式来解决实际问题,并提升代码质量。
|
5月前
|
PHP
【Azure Developer】PHP网站使用AAD授权登录的参考示例
【Azure Developer】PHP网站使用AAD授权登录的参考示例
|
5月前
|
存储 安全 Linux
【Azure 应用服务】App Service For Linux 怎么安装Composer,怎么安装PHP扩展,怎么来修改站点根路径启动程序?
【Azure 应用服务】App Service For Linux 怎么安装Composer,怎么安装PHP扩展,怎么来修改站点根路径启动程序?
|
6月前
|
Go PHP 云计算
如何在PHP代码里面调用Go程序
PHP和Go都是广泛使用的编程语言,但各自具有其独特的优势和特性。
|
6月前
|
安全 数据安全/隐私保护
屏蔽修改wp-login.php登录入口确保WordPress网站后台安全
WordPress程序默认的后台地址wp-login.php,虽然我们的密码设置比较复杂,但是如果被软件一直扫后台入口,一来影响网站的速度增加服务器的负担,二来万一被扫到密码,那就处于不安全的境地。所以,我们最好将后台地址入口隐藏屏蔽起来,我们可以通过下面的命令实现隐蔽wp-login.php入口。
174 0
|
6月前
|
缓存 前端开发 PHP
【超详细】php实现扫码关注微信公众号系统/网站自动注册登录
【超详细】php实现扫码关注微信公众号系统/网站自动注册登录
332 0