PHP实现一个简陋的注册登录页面

今天来水一篇没有**用的 /滑稽脸,代码简陋臃肿考虑不全,各位大佬轻喷,还望不吝赐教。

首先考虑了一下需要至少四个页面:register.htmlregister.phplogin.htmllogin.php

register.html是这么写的:

<!DOCTYPE html>
<html>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<head>
<title>注册界面</title>
</head>
<body>
<form action="register.php" method="post">
用户名:<input type="text" name="name"></input>
<br />
密码:<input type="password" name="password"></input>
<br />
<input type="submit" value="注册"></input>
</form>
</body>
</html>

register.php是这么写的:

<?php
header("Content-type:text/html;charset=utf-8");
$conn=new mysqli('localhost','wy','000000','test');
if ($conn->connect_error){
die("服务器连接失败!");
}
$name=$_POST["name"];
$password=$_POST["password"];
$sql="insert into new_info values('$name',$password)";
$res=$conn->query($sql);
if(!$res){
echo "注册失败!";
}else{
if($conn->affected_rows>0){
sleep(2);
header("Location:login.html");
exit;
}else{
echo "注册失败";
}
}
$conn->close();
?>

login.html是这么写的:

<!DOCTYPE html>
<html>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<head>
<title>登录界面</title>
</head>
<body>
<p>注册成功,请登录!</p>
<form action="login.php" method="post">
用户名:<input type="text" name="name"></input>
<br />
密码:<input type="password" name="password"></input>
<br />
<input type="submit" value="登录"></input>
</form>
</body>
</html>

login.php是这么写的:

<?php
header("Content-type:text/html;charset=utf-8");
$conn=new mysqli('localhost','wy','000000','test');
if ($conn->connect_error){
die("服务器连接失败!");
}
$name=$_POST["name"];
$password=$_POST["password"];
$sql_name="select name from new_info where name='$name'";
$res_sql=$conn->query($sql_name);
if($conn->affected_rows==0){
die("账号或密码有误");
}else{
$sql_pass="select password from new_info where name='$name'";
$res_pass=$conn->query($sql_pass);
$row_pass=$res_pass->fetch_row();
if($row_pass[0]==$password){
echo "登录成功!";
}else{
echo "账号或密码有误";
}
}
$conn->close();
?>

然后来看一下效果:



看一下数据库:

可以看到已经将数据写入数据库。

接着来登录试一下:



换个错误密码试一下:



2018-09-04 问题修正:

1.用户密码加密

2.数据库编码问题

1.用户密码加密

register.php页面:

<?php
header("Content-type:text/html;charset=utf-8");
$conn=new mysqli('192.168.134.128','root','123456','test');
if ($conn->connect_error){
die("服务器连接失败!");
}
$name=$_POST["name"];
$password=$_POST["password"];
$password=md5($password); //将用户输入的密码进行md5加密
$sql="insert into test values('$name','$password')";
$res=$conn->query($sql);
if(!$res){
echo "注册失败!";
}else{
if($conn->affected_rows>0){
sleep(2);
header("Location:login.html");
}else{
echo "注册失败";
}
}
$conn->close();
?>

login.php页面:

<?php
header("Content-type:text/html;charset=utf-8");
$conn=new mysqli('192.168.134.128','root','123456','test');
if ($conn->connect_error){
die("服务器连接失败!");
}
$name=$_POST["name"];
$password=$_POST["password"];
$password=md5($password); //对用户输入的密码进行md5加密
$sql_name="select name from test where name='$name'";
$res_sql=$conn->query($sql_name);
if($conn->affected_rows==0){
die("账号或密码有误!");
}else{
$sql_pass="select password from test where name='$name'";
$res_pass=$conn->query($sql_pass);
$row_pass=$res_pass->fetch_row();
if($row_pass[0]==$password){ //将用户输入的加密密码与数据库密码进行对比
echo "登录成功!";
}else{
echo "账号或密码有误";
}
}
$conn->close();
?>

2.数据库编码问题

在数据库执行set names utf8命令,将数据库编码改为utf8

这样就可以使用中文名注册登录。

2018-09-06 问题修正:

用户注册或者登录时输入为空的问题

register.php页面:

<?php
header("Content-type:text/html;charset=utf-8");
$conn=new mysqli('192.168.134.128','root','123456','test');
if ($conn->connect_error){
die("服务器连接失败!");
}
$name=$_POST["name"];
$password=$_POST["password"];
if(empty($name) || empty($password)){ //判断注册时账号或密码是否为空
die('账号或密码不能为空!');
}else{
$password=md5($password);
$sql="insert into test values('$name','$password')";
$res=$conn->query($sql);
if(!$res){
echo "注册失败!";
}else{
if($conn->affected_rows>0){
sleep(2);
header("Location:login.html");
}else{
echo "注册失败";
}
}
$conn->close();
}
?>

login.php页面:

<?php
header("Content-type:text/html;charset=utf-8");
$conn=new mysqli('192.168.134.128','root','123456','test');
if ($conn->connect_error){
die("服务器连接失败!");
}
$name=$_POST["name"];
$password=$_POST["password"];
if(empty($name) || empty($password)){ //判断登陆时账号或密码是否为空
die('账号或密码不能为空!');
}else{
$password=md5($password);
//var_dump($password);
$sql_name="select name from test where name='$name'";
$res_sql=$conn->query($sql_name);
if($conn->affected_rows==0){
die("账号或密码有误!");
}else{
$sql_pass="select password from test where name='$name'";
$res_pass=$conn->query($sql_pass);
$row_pass=$res_pass->fetch_row();
if($row_pass[0]==$password){
echo "登录成功!";
}else{
echo "账号或密码有误";
}
}
$conn->close();
} ?>

代码臃肿,还望见谅。

PHP实现一个简陋的注册登录页面的更多相关文章

  1. 原生js验证简洁美观注册登录页面

    序 一个以js验证表单的简洁的注册登录页面,不多说直接上图 效果 主要文件 完整代码 sign_up.html 注册表单 <!DOCTYPE html> <html lang=&qu ...

  2. Node.js基于Express框架搭建一个简单的注册登录Web功能

    这个小应用使用到了node.js  bootstrap  express  以及数据库的操作 :使用mongoose对象模型来操作 mongodb 如果没了解过的可以先去基本了解一下相关概念~ 首先注 ...

  3. 如何设计一个 App 的注册登录流程?

    移 动设备发力之前的登录方式很简单:用户名/邮箱+密码+确认密码,所有的用户登录注册都是围绕着邮箱来做.随着移动设备和社交网络的普及,邮箱不再是唯 一,渐渐的出现了微博,QQ,微信等第三方登录方式,手 ...

  4. 一个最简单的登录页面测试case

    具体需求: 有一个登陆页面, (假如上面有2个textbox, 一个提交按钮. 请针对这个页面设计30个以上的testcase.) 此题的考察目的:面试者是否熟悉各种测试方法,是否有丰富的Web测试经 ...

  5. HTML5实战教程———开发一个简单漂亮的登录页面

    最近看过几个基于HTML5开发的移动应用,比如臭名昭著的12036移动客户端就是主要使用HTML5来实现的,虽然还是有点反应迟钝,但已经比较流畅了,相信随着智能手机的配置越来越高性能越来越好,会越来越 ...

  6. PHP实践项目【1】:注册登录页面

    在我们这个项目里面,一共用到了5个php文件,他们分别是: login.php 登录页面 logincheck.php 登录检测php文件 register.php 新用户注册页面 regcheck. ...

  7. 注册登录页面修订-Python使用redis-手机验证接口-发送短信验证

    登录页面修订 views.Login.vue <template> <div class="login box"> <img src="@/ ...

  8. 用java语言写一个简易版本的登录页面,包含用户注册、用户登录、用户注销、修改密码等功能

    package com.Summer_0421.cn; import java.util.Arrays; import java.util.Scanner; /** * @author Summer ...

  9. 分享一个酷炫动态登录页面html

    话不多说,如下图: 代码如下: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <H ...

随机推荐

  1. springboot shiro开启注释

    shiroconfiguration中增加 @Bean public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceA ...

  2. 从零开始学 Web 之 BOM(四)client系列

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...

  3. quartz执行两遍问题

    转:http://blog.csdn.net/hejinwei_1987/article/details/49100975 在现在的项目中发现Quartz执行了两次,在网上找到下列解决方案,我是用的第 ...

  4. 搭建jenkins集群

    搭建jenkins集群是为了解决单点服务器存在的性能瓶颈,也有业务的需要,比如:java服务打包的环境我们需要linux,ios打包的服务器需要mac机. 一.创建agent节点 1.打开 系统管理- ...

  5. RMQ问题(Sparse-Table算法)

    范围最值问题(Range Minimum/maximum Query,RMQ).给出一个哪个元素的数组A1,A2,...An,要求设计一个数据结构,支持查询操作:计算min(AL,AL+1,...,A ...

  6. C#winform窗体用户控件自定义事件

    C#许多事情都和事件有关系,大部分的事情我们可以通过C#自己的事件来完成,但如果我们自己新建了一个自定义控件,我们该如何定义自己想要的事件呢?下面我就来为大家粗略的讲解一番. 假设我们自定义了一个控件 ...

  7. Spring中四种实例化bean的方式

    本文主要介绍四种实例化bean的方式(注入方式) 或者叫依赖对象实例化的四种方式.上面的程序,创建bean 对象,用的是什么方法 ,用的是构造函数的方式 (Spring 可以在构造函数私有化的情况下把 ...

  8. oracle创建用户、授权、导入、导出命令总结

    1.创建用户 需要先用system用户登录数据库,因为system用户具有创建其他用户的权限. 语法[创建用户]: create user 用户名 identified by 口令[即密码]: 例子: ...

  9. 自封装node 的简单增删改查

    1 首先引入的上篇node 链接mysql 里面的js var connect = require('./nodemysql.js'); 2 定义常量 const customerSQL = { qu ...

  10. 关于python访问字典的方法

    def stu( **kwargs): # 在函数体内对于kwargs的使用不用带星号 print("大家好,我为大家简单自我介绍以下:") print(type(kwargs)) ...