php中获取文件后缀名多种方法

 更新时间:2016年11月25日 17:09  点击:2216
以前我都讲过了很多关于获取文件后缀名的方法,今天我们再次总结一下关于利用不同种函数来取得,有需要的朋友可以参考一下

一,php explode函数,函数用法参考 http://www.111cn.net/phper/24/f486bb8b0528a628528530b295e6281b.htm

 代码如下 复制代码

$pic = 'abc.php';
$pics = explode('.' , $pic);

echo $num = count($pics);
echo '<br>'.$pics[$num-1];

这样就可以输出
.php了。

下面利用foreach  此函数用法 http://www.111cn.net/phper/18/foreach-foreach.htm

 代码如下 复制代码

foreach ($pics as $value) //2
{
  $a = $value;
}
echo $a.'<br>';

来有一个比较好的函数end我推荐使用此函数快捷 end函数用法 http://www.111cn.net/w3school/php/func_array_end.htm

 代码如下 复制代码

echo end($pics);
echo '<br>';

其它的访方法可以在文件上传时判断,不过那需要文件上传不上传我们不能使用$_FILES来操作。

在用户登录时有很多种有我实例一样的最基本的用户登录跑到指定页面这个不安全如果用户知道你这个地址就不需要登录了,实例二利用了session也是较常用的在操作页面加了session验证,但是无法记住下次登录,实例三就利用了session和cookie同时登录并可以自动记录下次自动登录功能。

我们先来看个最简单的实例

以下附简单的login.htm内容

 代码如下 复制代码

<html>
<body>
<form name="login" action="login.php" method=post>
用户名<input type=text name="name">
<p>密码<input type=password name="password">
<p>
<input name="log" type=submit value="登录">
</form>
</body>
</html>

login.php内容如下:

 代码如下 复制代码

<?
error_reporting(0);
$mysql_servername = "localhost"; //主机地址
$mysql_username = "root"; //数据库用户名
$mysql_password =""; //数据库密码
$mysql_database ="peng"; //数据库
mysql_connect($mysql_servername , $mysql_username , $mysql_password);
mysql_select_db($mysql_database);
$name=$_POST['name'];
$passowrd=$_POST['password'];

if ($name && $passowrd){
 $sql = "SELECT * FROM liuyanban WHERE name = '$name' and password='$passowrd'";
 $res = mysql_query($sql);
 $rows=mysql_num_rows($res);
  if($rows){
   header("refresh:0;url=a.htm");//跳转页面,注意路径
   exit;
 }
 echo "<script language=javascript>alert('用户名密码错误');history.back();</script>";
}else {
 echo "<script language=javascript>alert('用户名密码不能为空');history.back();</script>";
}

?>

下面还有一个我刚学php 是写的

这是一个登录页面的效果图,其它登陆别名与密码

 代码如下 复制代码

<input name="myname" type="text" id="myname" style="border:solid 0px;" />

<input name="mypass" type="password" id="mypass" style="border:solid 0px;" />

php代码

 代码如下 复制代码

<?

session_start();//这个一定要申明喽,给个小提示:在session之前不能有任何输出哦,在php.5以下的版本会有问题.
 
 $myname =get_value('myname',post);
 $mypass =get_value('mypass',post);
 if(!preg_match("/^w+$/",$myname) || strlen($myname)<3 || strlen($myname)>15 ){
  alert('输入的用户名信息有误!用户名必须由数字下划线英语字母组成,长度为3-15个字符!','');
 }
 if(!preg_match("/^w+$/",$mypass) || strlen($mypass)<6 || strlen($mypass)>15 ){
  alert('输和的用户密码!密码必须由数字下划线英语字母组成,长度为6-15个字符!','');
 }
 $sql ="select * from tbn where admin_name='$myname' and admin_pwd='".md5($mypass)."'";
 $result =mysql_query($sql);
 if(mysql_num_rows($result) ){
  $my =mysql_fetch_array($result);
  $_SESSION['uid']=$myname;
  //$_SESSION['auth']=return_auth($my['group_id']);  //这里是因为用到用户组取得用户组的权限
  header("location:main.php");
 }else{
  alert('提示:你输入的用户名与密码不一致!','');
 }

?>

上面的实例我都只保存信息到了session下面来看个同时应用session和cookie来保存用户登录信息


1、数据库连接设备页面:connectvars.php

 代码如下 复制代码

<?php
//数据库的地位
define(""DB_HOST"", ""127.0.0.1"");
//用户名
define(""DB_USER"", ""root"");
//口令
define(""DB_PASSWORD"", ""19900101"");
//数据库名
define(""DB_NAME"",""test"") ;
?>

2、登录页面:logIn.php

 代码如下 复制代码

<?php
//插入连接数据库的相干信息
require_once ""connectvars.php"";

//开启一个会话
session_start();

$error_msg = "";
//若是用户未登录,即未设置$_SESSION[""user_id""]时,履行以下代码
if(!isset($_SESSION[""user_id""])){
    if(isset($_POST[""submit""])){//用户提交登录表单时履行如下代码
        $dbc = mysqli_connect(DB_HOST,DB_USER,DB_PASSWORD,DB_NAME);
        $user_username = mysqli_real_escape_string($dbc,trim($_POST[""username""]));
        $user_password = mysqli_real_escape_string($dbc,trim($_POST[""password""]));

        if(!empty($user_username)&&!empty($user_password)){
            //MySql中的SHA()函数用于对字符串进行单向加密
            $query = "SELECT user_id, username FROM mismatch_user WHERE username = ""$user_username"" AND "."password = SHA(""$user_password"")";
            $data = mysqli_query($dbc,$query);
            //用用户名和暗码进行查询,若查到的记录正好为一条,则设置SESSION和COOKIE,同时进行页面重定向
            if(mysqli_num_rows($data)==1){
                $row = mysqli_fetch_array($data);
                $_SESSION[""user_id""]=$row[""user_id""];
                $_SESSION[""username""]=$row[""username""];
                setcookie(""user_id"",$row[""user_id""],time()+(60*60*24*30));
                setcookie(""username"",$row[""username""],time()+(60*60*24*30));
                $home_url = ""loged.php"";
                header(""Location: "".$home_url);
            }else{//若查到的记录不合错误,则设置错误信息
                $error_msg = ""Sorry, you must enter a valid username and password to log in."";
            }
        }else{
            $error_msg = ""Sorry, you must enter a valid username and password to log in."";
        }
    }
}else{//若是用户已经登录,则直接跳转到已经登录页面
    $home_url = ""loged.php"";
    header(""Location: "".$home_url);
}
?>
<html>
    <head>
        <title>Mismatch - Log In</title>
        <link rel="stylesheet" type="text/css" href="style.css" />
    </head>
    <body>
        <h3>Msimatch - Log In</h3>
        <!--经由过程$_SESSION[""user_id""]进行断定,若是用户未登录,则显示登录表单,让用户输入用户名和暗码-->
        <?php
        if(!isset($_SESSION[""user_id""])){
            echo ""<p class="error">"".$error_msg.""</p>"";
        ?>
        <!-- $_SERVER[""PHP_SELF""]代表用户提交表单时,调用自身php文件 -->
        <form method = "post" action="<?php echo $_SERVER[""PHP_SELF""];?>">
            <fieldset>
                <legend>Log In</legend>

                <label for="username">Username:</label>
                <input type="text" id="username" name="username"
                value="<?php if(!empty($user_username)) echo $user_username; ?>" />

                <br/>

                <label for="password">Password:</label>
                <input type="password" id="password" name="password"/>

            </fieldset>
            <input type="submit" value="Log In" name="submit"/>
        </form>
        <?php
        }
        ?>
    </body>
</html>


3、登入页面:loged.php

 代码如下 复制代码

<?php
//应用会话内存储的变量值之前必须先开启会话
session_start();
//若是会话没有被设置,查看是否设置了cookie
if(!isset($_SESSION[""user_id""])){
    if(isset($_COOKIE[""user_id""])&&isset($_COOKIE[""username""])){
        //用cookie给session赋值
        $_SESSION[""user_id""]=$_COOKIE[""user_id""];
        $_SESSION[""username""]=$_COOKIE[""username""];
    }
}
//应用一个会话变量搜检登录状况
if(isset($_SESSION[""username""])){
    echo ""You are Logged as "".$_SESSION[""username""].""<br/>"";
    echo ""<a href="logOut.php"> Log Out("".$_SESSION[""username""]."")</a>"";
}
/**在已登录页面中,可以哄骗用户的session如$_SESSION[""username""]、
 * $_SESSION[""user_id""]对数据库进行查询,可以做很多多少很多多少工作*/
?>

4、刊出session与cookie页面:logOut.php(刊出后重定向到lonIn.php)

 代码如下 复制代码

<?php
/**同时刊出session和cookie的页面*/
//即使是刊出时,也必须起首开端会话才干接见会话变量
session_start();
//应用一个会话变量搜检登录状况
if(isset($_SESSION[""user_id""])){
    //要清除会话变量,将$_SESSION超等全局变量设置为一个空数组
    $_SESSION = array();
    //若是存在一个会话cookie,经由过程将到期时候设置为之前1个小时从而将其删除
    if(isset($_COOKIE[session_name()])){
        setcookie(session_name(),"""",time()-3600);
    }
    //应用内置session_destroy()函数调用撤销会话
    session_destroy();
}
//同时将各个cookie的到期时候设为畴昔的某个时候,使它们由体系删除,时候以秒为单位
setcookie(""user_id"","""",time()-3600);
setcookie(""username"","""",time()-3600);
//location首部使浏览看重定向到另一个页面
$home_url = ""logIn.php"";
header(""Location:"".$home_url);
?>

用户注册登录涉及到用户信息与数据库的交互,因此要特别注意用户提交的信息不能为非法信息,本例中注册部分已经使用正则表达式做了限制,对登录部分只简单使用了 htmlspecialchars() 处理,实际应用时可更严格一些。
本教程只是简单演示用户注册与登录的过程,其代码仅供学习参考,不可直接用于项目生产。
本教程中对于用户登录成功后采用 session 来管理,也可以采用 cookie 来管理,尤其对于有时限要求的情况。
为了提高用户体验,用户注册部分可以结合 AJAX 来检测用户输入的信息而不必等点击提交后再检测。

生成验证码原理相当简单就是利用mt_rand随机生成一个数字,然后保存到session中用来用户登录时判断输入的验证码与我们生成的是否一致,然后就是把随机数字利用php gd函数生成一张图片,这样就完成了验证码的生成了。
 代码如下 复制代码

<?php
/**
 *
 * @file imgvcode.php
 * @create date 2007-09-25
 * @copyright (c) 2005 - 2007 eifr.com
 * @license http://www.111cn.net/nokia/n97/

 * eifr is free software
 */

session_start();

// main
$vcodes = '';
//generate Number 4
srand((double)microtime()*1000000);
for($i=0;$i<4;$i++){
    $vcodes.=rand(1,9);
}

$_SESSION['eifr_checkvcode'] = $vcodes;

if(function_exists('imagecreate')){
    //generate picture validation code
    Header("Content-type: image/PNG");

    $img = imagecreate(44,18);
    $bg = ImageColorAllocate($img, 245,245,245);
    imagefill($img,0,0,$bg); //background

   
    //generate Number 4
    for($i=0;$i<4;$i++){
        $font = ImageColorAllocate($img, rand(100,255),rand(0,100),rand(100,255));
        $vnum = substr($vcodes, $i, 1);
        imagestring($img, 5, 2+$i*10, 1, $vnum, $font);
    }

    //add interference
    for($i=0;$i<100;$i++)
    {
        $randcolor = ImageColorallocate($img,rand(0,255),rand(0,255),rand(0,255));
        imagesetpixel($img, rand()%70 , rand()%30 , $randcolor);
    }
    ImagePNG($img);
    ImageDestroy($img);
}

?>

注:php生成验证码需要开启php gd图片库哦,要不是不能生成的。

本文章分享一个自己使用的验证码实例,从生成图片验证码到利用使用验证码的实例,有需要学习的同学可以参考一下本文章哦。

hyml页面

 代码如下 复制代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script language="javascript">
 function refresh_code()
 {
  form1.imgcode.src="verifycode.php?a="+Math.random();
 }
</script>
</head>

<body>
<form id="form1" name="form1" method="post" action="checkcode.php">
  <label for="code">验证码:</label>
  <input type="text" name="code" id="textfield" />
  <img id="imgcode" src="VerifyCode.php" alt="验证码" />
  <a href="javascript:refresh_code()">看不清?换一个</a>
  <input type="submit" name="button" id="button" value="提交" />
</form>
</body>
</html>

verifycode.php文件代码如下

 代码如下 复制代码
<?php
 /*
  图片验证码 Powered By KASON
   */
  session_start();
  $num=4;//验证码个数
  $width=80;//验证码宽度
  $height=20;//验证码高度
  $code=' ';
  for($i=0;$i<$num;$i++)//生成验证码
  {
   switch(rand(0,2))
   {
    case 0:$code[$i]=chr(rand(48,57));break;//数字
    case 1:$code[$i]=chr(rand(65,90));break;//大写字母
    case 2:$code[$i]=chr(rand(97,122));break;//小写字母
   }
  }
  $_SESSION["VerifyCode"]=$code;
  $image=imagecreate($width,$height);
  imagecolorallocate($image,255,255,255);
  for($i=0;$i<80;$i++)//生成干扰像素
  {
   $dis_color=imagecolorallocate($image,rand(0,2555),rand(0,255),rand(0,255));
   imagesetpixel($image,rand(1,$width),rand(1,$height),$dis_color);
  }
  for($i=0;$i<$num;$i++)//打印字符到图像
  {
   $char_color=imagecolorallocate($image,rand(0,2555),rand(0,255),rand(0,255));
   imagechar($image,60,($width/$num)*$i,rand(0,5),$code[$i],$char_color);
  }
  header("Content-type:image/png");
  imagepng($image);//输出图像到浏览器
  imagedestroy($image);//释放资源
?>   


  

checkcode.php文件如下

 代码如下 复制代码

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<?php
ini_set('display_errors', 'Off');
session_start();
  if((strtoupper($_POST["code"])) == strtoupper(($_SESSION["VerifyCode"]))){
 print("验证码正确,");
  }else{
    print("验证码错误,");
  }
  echo "提交的验证码:".strtoupper($_POST["code"]).",正确的验证码:".strtoupper($_SESSION["VerifyCode"]);
?>

本文章介绍了一个简单的删除数据库的记录时再刷新当前页面,这个不是用ajax实现的而是用了get方式来刷新当前页面,这个方法在实际应用中用户体验不好哦。

功能:

1、在某个页面上显示查询数据,并在每条数据后增加删除功能,点击“删除”,删除掉数据,同时刷新页面

2、用GET方式获得删除条件

数据库连接变量connectvars.php

 代码如下 复制代码
<?php
//服务器
define('DB_HOST', 'localhost');
//用户名
define('DB_USER', 'root');
//密码
define('DB_PASSWORD', 'root');
//数据库
define('DB_NAME','test') ;
?>

记录展示页面display.php,每条记录后有“删除”功能,点击“删除”,可删除该条记录,同时刷新页面

 代码如下 复制代码

<?php
require_once 'connectvars.php';
$dbc = mysqli_connect(DB_HOST,DB_USER,DB_PASSWORD,DB_NAME);
//如果调用此页面时,页面链接中有‘DelID’变量,则获得要删除记录的‘ID’号,进行删除
if(isset($_GET['DelID'])){
    $query = "DELETE FROM toyota WHERE ID = ".$_GET['DelID']." LIMIT 1";
    mysqli_query($dbc,$query);
}   
//查出所有记录,并在接下来的表格中进行显示(如果上面的删除代码被执行,此处相当于刷新页面)
$query = "SELECT * FROM toyota ORDER BY ID DESC";
$data = mysqli_query($dbc,$query);
//统计所查询出的记录条数
$count = mysqli_num_rows($data);
?>
<html>
    <head>
        <title>丰田汽车数据查看</title>
    </head>
    <body>
        <table>
        <!-- 表格列名 -->
            <tr>
                <th>标题</th>
                <th>来源</th>
                <th>车型</th>
                <th>主要部件</th>
                <th>操作</th>
            </tr>
            <?php
            //循环输出列表元素:title、source、carType、majorPart,后加一个"删除"链接
              while($row = mysqli_fetch_array($data)){
                  echo '<tr>';
                  echo '<td><a href = '.$row['url'].'>'.$row['title'].'</td>';
                  echo '<td>'.$row['source'].'</td>';
                  echo '<td>'.$row['carType'].'</td>';
                  echo '<td>'.$row['majorPart'].'</td>';
                  //点击"删除"链接,调用自身页面,同时在页面链接上增加‘DelID’变量,赋值为该记录在数据库中的‘ID’号,用于GET方式获得
                  echo '<td><a href = "'.$_SERVER['PHP_SELF'].'?DelID='.$row['ID'].'">删除</a></td>';
                 echo '</tr>';
              }
            ?>
        </table>
    </body>
</html>

[!--infotagslink--]

相关文章

  • C#文件后缀名的详细介绍

    这篇文章详细介绍了C#文件后缀名,有需要的朋友可以参考一下...2020-06-25
  • C#获取图片的后缀名解析

    这篇文章主要介绍了C#获取图片的后缀名解析,需要的朋友可以参考下...2020-06-25
  • php批量删除指定文件夹中指定后缀名文件

    这是一个比较实现的函数我们可以自定义要删除那些目录保存在一个数据中,然后我们根据数据进行遍历并且删除目录下指定文件了,具体代码如下。 直接上代码: 下面的例子...2016-11-25
  • Node.js path模块,获取文件后缀名操作

    这篇文章主要介绍了Node.js path模块,获取文件后缀名操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-07
  • php中获取文件后缀名多种方法

    以前我都讲过了很多关于获取文件后缀名的方法,今天我们再次总结一下关于利用不同种函数来取得,有需要的朋友可以参考一下 一,php explode函数,函数用法参考 http://...2016-11-25
  • PHP 批量修改文件名/文件后缀名(扩展名)

    今天我有几千个文件要一次修改文件或把后缀名给改了,但是我要手工一个个去改,不得改几天后来想到一个办法,利用php写一个量修改文件名/文件后缀名程序,一下就实现了,下面来...2016-11-25
  • php取得文件后缀名方法

    下面举出了三种获取文件缀名方法代码有需要的朋友可以参考一下。 <?php教程 //方法一: function extend_1($file_name) { $retval=""; $pt=strrpos($file_n...2016-11-25
  • php获取文件后缀名的几种方法

    后缀名指的是文件拓展名了,我们在php中可以通过许多的方法来获得了,下面一起来看小编整理的一些例子吧。 获取文件后缀的方法有很多种,差不多能总结出7,8种,原理基本...2016-11-25
  • ASP.NET中各个后缀名的含义介绍

    ASP.NET中各个后缀名的含义,使用asp.net的朋友可以看下,了解不同后缀名文件的作用。...2021-09-22
  • php 获取文件名后缀名扩展名

    在php 有这么二个函数 end() 与 current() 前者是读取数组最后一个元素值,后者是读取数组第一个值, 那么下面我们来看看我利用end也读取文件111cn.gif文件后缀名gif...2016-11-25
  • php 如何获取文件的后缀名

    本文给大家汇总了几种使用PHP实现获取文件的后缀名的方法,十分的简单实用,有需要的小伙伴可以参考下...2016-06-12
  • php中一行代码获取文件后缀名

    php中一行代码获取文件后缀名的方法要结合很多的函数了,我们这个有点像asp中的函数了,下面来一起看看吧。 实例: 代码如下 复制代码 $filenam...2016-11-25
  • php获取文件后缀的9种方法

    这篇文章主要为大家详细介绍了php获取文件后缀的9种方法,有一定的实用价值,感兴趣的小伙伴们可以参考一下...2016-03-27
  • php获取上传文件类型 获取文件后缀

    本教程提供了三款获取上传文件与图片类型的方法,方法也是很简单的前二种,是先把类型定义好,再用in_array判断,最后一步是利用了fopen再读取前二个字节,判断。 ...2016-11-25
  • 修改服务器配置 让asp.net文件后缀名随心所欲

    asp或php的方法对.net就不行了,同样的办法,修改应用程序映射后,仍然没有得到预期的结果,文件什么内容,返回的就是什么内容,而不是当作asp.net程序来处理了...2016-01-27
  • httpHandler实现.Net无后缀名Web访问的实现解析

    有时候我们看到很多网站是网址是没有后缀名的,其实.net中可以通过httpHandler来实现。...2021-09-22
  • php 取文件后缀名几种有效的方法

    要取得文件后缀名在php中有很多的广告,如php函数pathinfo得出结果后的$extend[\"extension\"]就是一个不错的方法,后面都是民间自定义有需了解的朋友也可以参考一下。...2016-11-25