ubutu 16.04环境下,PHP与mysql数据库,网页登录验证实例讲解


Posted in PHP onJuly 20, 2017

正好最近的域名备案通过了,兴起就突然想做一个网页,虽然之前去备案域名也是有这个目的。

问过几个人,说用linux上用PHP搭建网站很简单,就试着做了一个,这里主要说一下登录验证相关的部分;

首相准备几个文件,主要是index.php、conn.php、data.php以及login.php;

login.php 主要是登录过程中的数据对比部分;其中include ('conn.php')内容在下面有说。

<?php
if(!isset($_POST['submit'])){
 exit('login in error.');
}
$username = htmlspecialchars($_POST['username']);
$password = MD5($_POST['password']);
include('conn.php');
echo"$password";
$check_query = mysqli_query($result,"select USERID from USERINFO where EMAIL='$username' and PASSWORD='$password' limit 1");
if($ret = mysqli_fetch_array($check_query)){

 echo'connect true.';
}
else
{
 echo'connect false';
}
?>

另外要注意的是:关于$_POST针对的是form中的method =“post”中的内容。

因为里面用到MD5加密的方式,所以说一下,在后台数据库加密的时候也需要用到MD5加密的方式update数据,具体方式如下:

UPDATE USERINFO SET PASSWORD = md5('root') WHERE USERID = 1000;

其中的表格以及具体查询位置根据个人数据库而定。

conn.php 主要是跟mysql数据库连接相关的操作,分为数据库连接,以及数据库选择部分(注意数据库连接的返回值取值,不要随便起,后边引用的时候是用得着的。)

<?php
try{
$result = mysqli_connect('localhost','root','root');
mysqli_select_db($result,'WEBDATAS');
}catch(Exception $e)
{
 echo $e->message;
 exit;
}
if(!$result)
{
 return false;
}
echo "ok\n";
?>

剩下的主要是index.php 该文件是主页相关了,我只把登录相关的部分拿出来说明一下(这里用到的是boostrap中的模板,有兴趣的可以百度一下boostrap)

<?php
session_start();
include_once('data.php');

$handle = db_connect();
if(!$handle){
 echo 'Did not access to the database';
}else{
 echo'connect success';
}
?>

其中包含的data.php登录部分如下:

<div class="modal fade" tabindex="-1" role="dialog" id="login">
   <div class="modal-dialog" role="document">
    <div class="modal-content">
     <div class="modal-header">
      <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
      <h3 class="modal-title">ログイン</h3>
     </div>
     <div class="modal-body">
      <form class="form-signin" action="login.php" method = "post">
       <h4 class="form-signin-heading">利用者名 パスワ?ド 入力</h4>
       <label for="inputEmail" class="sr-only">利用者名</label>
       <input type="email" name="username" id="inputEmail" class="form-control" placeholder="利用者名を入力" required autofocus>
       <label for="inputPassword" class="sr-only">パスワ?ド</label>
       <input type="password" name="password" id="inputPassword" class="form-control" placeholder="パスワ?ド" required>
       <div class="checkbox">
        <label>
        <input type="checkbox" value="remember-me"> ログイン状?Bを保持
       </label>
       </div>
       <button class="btn btn-lg btn-primary btn-block" type="submit" name="submit">ログイン</button>
      </form>
     </div>
     <div class="modal-footer">
      <button type="button" class="btn btn-default" data-dismiss="modal">クロ?ズ</button>
     </div>
    </div>
    <!-- /.modal-content -->
   </div>
   <!-- /.modal-dialog -->
  </div>

基本关于登录验证部分就是这些,主要是与数据库的数据进行对比,一开始用的对称加密的方式,对加密的方式还没有仔细去研究,后面有机会再仔细看一下就好。

以上这篇ubutu 16.04环境下,PHP与mysql数据库,网页登录验证实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
数字转英文
Dec 06 PHP
PHP+.htaccess实现全站静态HTML文件GZIP压缩传输(一)
Feb 15 PHP
mysql 搜索之简单应用
Apr 27 PHP
php empty,isset,is_null判断比较(差异与异同)
Oct 19 PHP
JS与PHP向函数传递可变参数的区别实例代码
May 18 PHP
PHP字符串函数系列之nl2br(),在字符串中的每个新行 (\n) 之前插入 HTML 换行符br
Nov 10 PHP
php插入中文到sqlserver 2008里出现乱码的解决办法分享
Jul 19 PHP
php获取数组长度的方法(有实例)
Oct 27 PHP
PHP中使用curl伪造IP的简单方法
Aug 07 PHP
PHP输入流php://input实例讲解
Dec 22 PHP
php单链表实现代码分享
Jul 04 PHP
Laravel如何创建服务器提供者实例代码
Apr 15 PHP
thinkphp3.2实现在线留言提交验证码功能
Jul 19 #PHP
ThinkPHP框架表单验证操作方法
Jul 19 #PHP
动态表单验证的操作方法和TP框架里面的ajax表单验证
Jul 19 #PHP
关于ThinkPhp 框架表单验证及ajax验证问题
Jul 19 #PHP
php实现的pdo公共类定义与用法示例
Jul 19 #PHP
PHP多进程编程实例详解
Jul 19 #PHP
PHP preg_match实现正则表达式匹配功能【输出是否匹配及匹配值】
Jul 19 #PHP
You might like
php生成图片缩略图的方法
2015/04/07 PHP
PHP云打印类完整示例
2016/10/15 PHP
javascript 异步页面查询实现代码(asp.net)
2010/05/26 Javascript
jQuery与其它库冲突的解决方法
2010/06/25 Javascript
Javascript中正则表达式的全局匹配模式分析
2011/04/26 Javascript
Javascript处理DOM元素事件实现代码
2012/05/23 Javascript
JS教程:window.location使用方法的区别介绍
2013/10/04 Javascript
js中call与apply的用法小结
2013/12/28 Javascript
js正则表达exec与match的区别说明
2014/01/29 Javascript
多种方法实现360浏览器下禁止自动填写用户名密码
2014/06/16 Javascript
Javascript学习笔记之 函数篇(三) : 闭包和引用
2014/11/23 Javascript
jQuery中end()方法用法实例
2015/01/08 Javascript
浏览器中url存储的JavaScript实现
2015/07/07 Javascript
jquery实现滑动特效代码
2015/08/10 Javascript
javascript如何实现暂停功能
2015/11/06 Javascript
实例学习JavaScript读取和写入cookie
2018/01/29 Javascript
vue移动端路由切换实例分析
2018/05/14 Javascript
JS实现数组去重,显示重复元素及个数的方法示例
2019/01/21 Javascript
微信小程序实现卡片层叠滑动效果
2019/06/21 Javascript
20道JS原理题助你面试一臂之力(必看)
2019/07/22 Javascript
转换layUI的数据表格中的日期格式方法
2019/09/19 Javascript
python中lambda与def用法对比实例分析
2015/04/30 Python
Python文件及目录操作实例详解
2015/06/04 Python
高质量Python代码编写的5个优化技巧
2017/11/16 Python
使用Selenium破解新浪微博的四宫格验证码
2018/10/19 Python
解决Python 命令行执行脚本时,提示导入的包找不到的问题
2019/01/19 Python
python文字转语音的实例代码分析
2019/11/12 Python
python实现把两个二维array叠加成三维array示例
2019/11/29 Python
Tensorflow训练模型越来越慢的2种解决方案
2020/02/07 Python
Python3监控疫情的完整代码
2020/02/20 Python
详解Python openpyxl库的基本应用
2021/02/26 Python
美国精品家居用品网站:US-Mattress
2016/08/24 全球购物
日语专业毕业生自荐信
2013/11/11 职场文书
创业计划书之旅游网站
2019/09/06 职场文书
vue实现登陆页面开发实践
2022/05/30 Vue.js
微软发布Windows 11今年最大更新22H2(附 ISO 镜像官方下载)
2022/09/23 数码科技