PHP-实例-文件上传

1 需求


2 basename

在 PHP 中,basename() 函数用于返回路径中的文件名部分。如果路径中包含了文件扩展名,则该函数也会返回它。如果路径的结尾有斜杠(/)或反斜杠(\),则 basename() 函数会返回空字符串。

函数的基本语法是:

string basename ( string $path [, string $suffix ] )
  • $path 是必需的参数,指定了需要处理的路径。
  • $suffix 是可选的参数,如果你指定了一个字符串作为后缀,并且这个后缀在文件名的末尾,那么它会被去除。

示例:

// 不带后缀参数
$path = "/home/username/documents/myfile.txt";
$filename = basename($path);
echo $filename; // 输出: myfile.txt

// 带有后缀参数
$filename = basename($path, ".txt");
echo $filename; // 输出: myfile

// 如果路径以斜杠结尾
$path = "/home/username/documents/";
$filename = basename($path);
echo $filename; // 输出: (空字符串)

注意,basename() 函数并不检查文件或目录是否真的存在,它只是根据提供的路径字符串进行字符串操作。因此,即使 $path 指向的文件或目录不存在,basename() 仍然会返回路径中的文件名部分。

此外,如果你正在处理用户输入或不可信的路径,你应该始终验证和清理这些路径,以防止潜在的安全风险,如目录遍历攻击(也称为路径遍历或本地文件包含)。


2 pathinfo

在 PHP 中,strtolower() 函数用于将字符串中的所有字符转换为小写,而 pathinfo() 函数用于返回文件路径的信息。当你将 pathinfo() 与 PATHINFO_EXTENSION 常量一起使用时,它会返回文件路径的扩展名部分。

将这两个函数结合起来,strtolower(pathinfo($target_file, PATHINFO_EXTENSION)) 的作用是获取 $target_file 变量中指定的文件的扩展名,并将其转换为小写。

这里是一个示例:

$target_file = "uploads/myfile.JPG"; // 假设这是你的文件路径

// 使用 pathinfo 获取扩展名,并使用 strtolower 转换为小写
$extension = strtolower(pathinfo($target_file, PATHINFO_EXTENSION));

echo $extension; // 输出: jpg

在上面的示例中,$target_file 变量包含了一个文件路径,其中文件的扩展名是 "JPG"。通过调用 pathinfo($target_file, PATHINFO_EXTENSION),我们获取了扩展名 "JPG"。然后,我们使用 strtolower() 函数将其转换为小写,得到了 "jpg"。最后,我们将结果存储在 $extension 变量中并输出它。


2 htmlspecialchars

在 PHP 中,htmlspecialchars() 函数用于将特殊字符转换为 HTML 实体。这样做是为了防止跨站脚本攻击(XSS)和其他安全漏洞,通过确保这些特殊字符在 HTML 上下文中被正确地转义。

特殊字符包括:

  • & (和号) 转换为 &
  • " (双引号) 转换为 "(只有当 ENT_QUOTES 被设置时)
  • ' (单引号) 转换为 '(在 PHP 5.4.0 之前的版本中,只有当 ENT_QUOTES 被设置时;在 PHP 5.4.0 及更高版本中,总是如此)
  • < (小于号) 转换为 &lt;
  • > (大于号) 转换为 &gt;

函数的语法如下:

string htmlspecialchars ( string $string [, int $flags = ENT_COMPAT | ENT_HTML401 [, string $encoding = ini_get("default_charset") [, bool $double_encode = true ]]] )
  • $string:需要转换的字符串。
  • $flags:一个位掩码,指定如何转换字符串。可能的值包括 ENT_HTML401(默认,处理 HTML 4.01)、ENT_HTML5(处理 HTML 5)、ENT_XHTML(处理 XHTML)、ENT_QUOTES(转义单引号和双引号)等。
  • $encoding:指定使用的字符编码。默认是 ini_get("default_charset")(通常是 UTF-8)。
  • $double_encode:当设置为 false 时,防止已经存在的 HTML 实体被双重编码。默认为 true

使用 htmlspecialchars() 的示例:

$user_input = '<script>alert("XSS!");</script>';
$safe_output = htmlspecialchars($user_input);

echo $safe_output; // 输出:&lt;script&gt;alert(&quot;XSS!&quot;);&lt;/script&gt;

在这个例子中,<script> 标签和其中的 JavaScript 代码被转义成了无害的 HTML 实体,从而防止了 XSS 攻击。当这段代码被浏览器渲染时,它不会执行 JavaScript,而只是简单地显示文本。


3 示例


4 参考资料

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/779848.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

为企业知识库选模型?全球AI大模型知识库RAG场景基准测试排名

大语言模型常见基准测试 大家对于AI模型理解和推理能力的的基准测试一定非常熟悉了&#xff0c;比如MMLU&#xff08;大规模多任务语言理解&#xff09;、GPQA&#xff08;研究生级别知识问答&#xff09;、GSMSK&#xff08;研究生数学知识考察&#xff09;、MATH&#xff08…

WordPress作品设计素材图片站资讯文章教程uigreat主题

主题介绍 uigreat主题是一款wordpress作品主题&#xff0c;发布设计作品素材文章&#xff0c;适合作品展示、设计等站点使用等&#xff0c;这款主题都非常合适。 1、自适应设计&#xff0c;PC、平板、手机等均可正常浏览&#xff1b; 2、图片缩略图可自定义高度&#xff0c;主…

摸鱼大数据——Spark SQL——DataFrame详解一

1.DataFrame基本介绍 DataFrame表示的是一个二维的表。二维表&#xff0c;必然存在行、列等表结构描述信息​表结构描述信息(元数据Schema): StructType对象字段: StructField对象&#xff0c;可以描述字段名称、字段数据类型、是否可以为空行: Row对象列: Column对象&#xff…

服务器BMC基础知识总结

前言 因为对硬件方面不太理解&#xff0c;所以打算先从服务器开始学习&#xff0c;也想和大家一起分享一下&#xff0c;有什么不对的地方可以纠正一下哦&#xff01;谢谢啦&#xff01;互相学习共同成长~ 1.BMC是什么&#xff1f; 官方解释&#xff1a;BMC全名Baseboard Mana…

【聚星文社 绘唐3】MJ版一键AI工具使用文档

MJ版一键AI工具使用文档 绘唐地址下载 欢迎使用MJ版一键AI工具&#xff01;这个工具可以帮助您快速生成各种类型的文本&#xff0c;包括文章、对话、代码等等。 使用方法&#xff1a; 登录&#xff1a;首先&#xff0c;您需要登录到您的MJ版账户。如果您还没有账户&#xff0…

Spring AOP源码篇二之 代理工厂ProxyFactory学习

了解AspectJ表达式以及PointCut、Advice、Advisor后&#xff0c;继续学习Spring AOP代理工厂 AspectJ表达式参考&#xff1a;Spring AOP之AspectJ表达式-CSDN博客 PointCut、Advice、Advisor参考&#xff1a;Spring AOP源码篇一之 PointCut、Advice、Advisor学习-CSDN博客 简单…

从零开始实现大语言模型(四):简单自注意力机制

1. 前言 理解大语言模型结构的关键在于理解自注意力机制(self-attention)。自注意力机制可以判断输入文本序列中各个token与序列中所有token之间的相关性&#xff0c;并生成包含这种相关性信息的context向量。 本文介绍一种不包含训练参数的简化版自注意力机制——简单自注意…

STM32-PWR和WDG看门狗

本内容基于江协科技STM32视频学习之后整理而得。 文章目录 1. PWR1.1 PWR简介1.2 电源框图1.3 上电复位和掉电复位1.4 可编程电压监测器1.5 低功耗模式1.6 模式选择1.7 睡眠模式1.8 停止模式1.9 待机模式1.10 库函数 2. WDG看门狗2.1 WDG简介2.2 IWDG框图2.3 IWDG键寄存器2.4 …

ACM ICPS独立出版 | 2024年第三届计算与人工智能国际会议(ISCAI 2024)

会议简介 Brief Introduction 2024年第三届计算与人工智能国际会议(ISCAI 2024) 会议时间&#xff1a;2024年11月22 -24日 召开地点&#xff1a;中国大理 大会官网&#xff1a;www.iscai.org 2024年第三届计算与人工智能国际会议(ISCAI 2024)将围绕“计算与人工智能”的最新研究…

排序 -- 冒泡排序和快速排序

一、 交换排序 1、基本思想 所谓交换&#xff0c;就是根据序列中两个记录键值的比较结果来对换这两个记录在序列中的位置&#xff0c;交换排序的特点是&#xff1a;将键值较大的记录向序列的尾部移动&#xff0c;键值较小的记录向序列的前部移动。 2、常见的交换排序 1、冒泡…

Java Selenium入门程序

需求&#xff1a;使用chrome浏览器打开百度首页 1.配置浏览器驱动 &#xff08;1&#xff09;下载浏览器驱动&#xff0c;浏览器版本需与驱动版本一致&#xff1b; &#xff08;2&#xff09;编辑系统环境变量-->编辑Path-->填入浏览器驱动路径&#xff1a; 2.maven工…

【反悔贪心 反悔堆】1642. 可以到达的最远建筑

本文涉及知识点 反悔贪心 反悔堆 LeetCode1642. 可以到达的最远建筑 给你一个整数数组 heights &#xff0c;表示建筑物的高度。另有一些砖块 bricks 和梯子 ladders 。 你从建筑物 0 开始旅程&#xff0c;不断向后面的建筑物移动&#xff0c;期间可能会用到砖块或梯子。 当…

刷题之删除有序数组中的重复项(leetcode)

删除有序数组中的重复项 这题简单题&#xff0c;双指针&#xff0c;一个指针记录未重复的数的个数&#xff0c;另一个记录遍历的位置。 以下是简单模拟&#xff0c;可以优化&#xff1a; class Solution { public:int removeDuplicates(vector<int>& nums) {int l0…

STL--求交集,并集,差集(set_intersection,set_union,set_difference)

set_intersection(重要) 求两个有序的序列的交集. 函数声明如下: template<class InputIterator1, class InputIterator2, class OutputIterator>OutputIterator set_intersection(InputIterator1 _First1, //容器1开头InputIterator1 _Last1, //容器2结尾(不包含)Inp…

ChatGPT4深度解析:探索智能对话新境界

大模型chatgpt4分析功能初探 目录 1、探测目的 2、目标变量分析 3、特征缺失率处理 4、特征描述性分析 5、异常值分析 6、相关性分析 7、高阶特征挖掘 1、探测目的 1、分析chat4的数据分析能力&#xff0c;提高部门人效 2、给数据挖掘提供思路 3、原始数据&#xf…

Navicat终于免费了, 但是这个结果很奇葩

个人用下载地址: 点呀 好家伙, 每个机构最多5个用户, 对于正在审计的公司…

DAY1: 实习前期准备

文章目录 VS Code安装的插件C/CCMakeGitHub CopilotRemote-SSH收获 VS Code 下载链接&#xff1a;https://code.visualstudio.com 安装的插件 C/C 是什么&#xff1a;C/C IntelliSense, debugging, and code browsing. 为什么&#xff1a;初步了解如何在VS Code里使用C输出…

Vulnhub-Os-hackNos-1(包含靶机获取不了IP地址)

https://download.vulnhub.com/hacknos/Os-hackNos-1.ova #靶机下载地址 题目&#xff1a;要找到两个flag user.txt root.txt 文件打开 改为NAT vuln-hub-OS-HACKNOS-1靶机检测不到IP地址 重启靶机 按住shift 按下键盘字母"E"键 将图中ro修改成…

筛选Github上的一些优质项目

每个项目旁都有标签说明其特点&#xff0c;如今日热捧、多模态、收入生成、机器人、大型语言模型等。 项目涵盖了不同的编程语言和领域&#xff0c;包括人工智能、语言模型、网页数据采集、聊天机器人、语音合成、AI 代理工具集、语音转录、大型语言模型、DevOps、本地文件共享…

7-6 每日升学消息汇总

复旦附中清北比例大涨&#xff0c;从统计数据来看&#xff0c;今年复附的清北人数将创历史新高&#xff0c;达到前所未有年进43人。离上海7月9号中考出分&#xff0c;还有3天。小道消息说&#xff0c;画狮的数游天下又回来了&#xff0c;目前还未官方消息。2024第二届国际数学夏…