-
php上传功能集后缀名判断和随机命名(强力推荐)
本篇文章给大家分享php上传功能集后缀名判断和随机命名,代码写的简单易懂,感兴趣的朋友快来参考下吧。
不废话了,具体请看下文代码示例讲解。
form.php
- <html>
- <head>
- <meta http-equiv="content-type" content="text/html" charset="utf-8">
- <title>Upload Image</title>
- </head>
- <body>
- <form method="post" action="upload.php" enctype="multipart/form-data">
- <input type="hidden" name="MAX_FILE_SEZE" value="2000000">
- <input type="file" name="file" value="view">
- <input type="submit" value="upload" name="B1">
- </form>
- </body>
- </html>
upload.php
- <?php
- include("check.php"); // 引入自定义函数文件
- $type = array("jpg", "gif", "bmp", "jpeg", "png");
- // 判断上传文件类型
- $fileext = strtolower(fileext($_FILES['file']['name']));
- $uploadfilename = random(8);
- if(in_array($fileext, $type)){
- $filename = explode(".", $_FILES['file']['name']);
- if(is_uploaded_file($_FILES['file']['tmp_name'])){
- // echo $_FILES['file']['tmp_name'];
- $flag = move_uploaded_file($_FILES['file']['tmp_name'], "/Library/WebServer/Documents/test/".$uploadfilename.".".$fileext);
- if($flag){
- echo "上传成功!";
- }else{
- echo "Error.";
- }
- echo "<a href='javascript:history.go(-1)'>Back</a>";
- }
- }
check.php
- <?php
- header("Content-type:text/html;charset=utf8");
- // 获取文件后缀名函数
- function fileext($filename){
- $sTemp = strrchr($filename, ".");
- return substr($sTemp, 1);
- }
- function fileext2($filename){
- $sTemp = explode(".", $filename);
- return $sTemp[count($sTemp)-1];
- }
- // 生成随机文件名函数
- function random($length){
- $captchaSource = "0123456789abcdefghijklmnopqrstuvwxyz这是一个随机打印输出字符串的例子";
- $captchaResult = "2015"; // 随机数返回值
- $captchaSentry = ""; // 随机数中间变量
- for($i=0;$i<$length;$i++){
- $n = rand(0, 35); #strlen($captchaSource));
- if($n >= 36){
- $n = 36 + ceil(($n-36)/3) * 3;
- $captchaResult .= substr($captchaSource, $n, 3);
- }else{
- $captchaResult .= substr($captchaSource, $n, 1);
- }
- }
- return $captchaResult;
- }
- ?>
将三个文件整合成一个:
- <?php
- // 获取文件后缀名函数
- function fileext($filename){
- $sTemp = strrchr($filename, ".");
- return substr($sTemp, 1);
- }
- function fileext2($filename){
- $sTemp = explode(".", $filename);
- return $sTemp[count($sTemp)-1];
- }
- // 生成随机文件名函数
- function random($length){
- $captchaSource = "0123456789abcdefghijklmnopqrstuvwxyz这是一个随机打印输出字符串的例子";
- $captchaResult = "2015"; // 随机数返回值
- $captchaSentry = ""; // 随机数中间变量
- for($i=0;$i<$length;$i++){
- $n = rand(0, 35); #strlen($captchaSource));
- if($n >= 36){
- $n = 36 + ceil(($n-36)/3) * 3;
- $captchaResult .= substr($captchaSource, $n, 3);
- }else{
- $captchaResult .= substr($captchaSource, $n, 1);
- }
- }
- return $captchaResult;
- }
- $type = array("jpg", "gif", "bmp", "jpeg", "png");
- // 判断上传文件类型
- $fileext = strtolower(fileext($_FILES['file']['name']));
- $uploadfilename = random(8);
- if(in_array($fileext, $type)){
- $filename = explode(".", $_FILES['file']['name']);
- if(is_uploaded_file($_FILES['file']['tmp_name'])){
- // echo $_FILES['file']['tmp_name'];
- $flag = move_uploaded_file($_FILES['file']['tmp_name'], "/Library/WebServer/Documents/test/".$uploadfilename.".".$fileext);
- if($flag){
- echo "上传成功!";
- }else{
- echo "Error.";
- }
- echo "<a href='javascript:history.go(-1)'>Back</a>";
- }
- }
- ?>
- <html>
- <head>
- <meta http-equiv="content-type" content="text/html" charset="utf-8">
- <title>Upload Image</title>
- </head>
- <body>
- <form method="post" action="" enctype="multipart/form-data">
- <input type="hidden" name="MAX_FILE_SEZE" value="2000000">
- <input type="file" name="file" value="view">
- <input type="submit" value="upload" name="B1">
- </form>
- </body>
- </html>
以上内容就是给大家讲解的php上传功能集后缀名判断和随机命名(强力推荐),希望大家喜欢。
出处:http://www.phpfensi.com/php/20210617/16457.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式