-
php 文件上传至OSS及删除远程阿里云OSS文件
今天给大家介绍php 文件上传至OSS及删除远程阿里云OSS文件的方法,在删除文件的时候大家记住千万不要带域名,具体操作示例参考下本文。
删除的时候记住不要带域名,也不要带'/'这个路径符号,如全路径是:'https://hxty.oss-cn-beijing.aliyuncs.com/data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf',则这里的path_file路径为:'data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf'。
- <?php
- include './aliyun-oss-php-sdk-2.4.2/autoload.php';
- use OSS\OssClient;
- use OSS\Core\OssException;
- error_reporting(E_ALL);
- ini_set('display_errors', 1); //错误信息
- ini_set('display_startup_errors', 1); //php启动错误信息
- session_start();
- /**
- * 取小数点后两位
- * @param type $str 带小数的数字
- * @return type 返回准确截取两位的小数
- */
- function num_format($str) {
- if (strpos($str, '.') === false) {
- return $str;
- }
- $retArr = explode(".", $str);
- $strs = substr($retArr[1], 0, 2);
- return $retArr[0] . "." . $strs;
- }
- function create_folders($dir) {
- return is_dir($dir) or ( create_folders(dirname($dir)) and mkdir(iconv("UTF-8", "GBK", $dir), 0777, true));
- }
- $file = $_FILES['file'];
- $accessKeyId = '';//RAM alioss后台能拿到
- $accessKeySecret = '';//RAM alioss后台能拿到
- $endpoint = 'oss-cn-beijing.aliyuncs.com';//alioss后台 概览可以拿到
- $bucket = 'planet-cross';//创建的组,随便吧创建,权限正常就行
- echo '<pre>';
- var_dump($_SESSION);
- if ($file) {
- $filename = "/upload/image/" . date("Ymd");
- if (!file_exists("." . $filename)) {
- create_folders("." . $filename);
- }
- //获取后缀
- $ary = explode('.', $file['name']);
- $su = end($ary);
- //文件名
- $filenames = $filename . "/" . time() . rand(1, 10000) . "." . $su;
- move_uploaded_file($file['tmp_name'], "." . $filenames);
- $ossClient = new \OSS\OssClient($accessKeyId, $accessKeySecret, $endpoint);
- $filenames = ltrim($filenames, '/'); //去除 第一个 '/'
- // 开始上传
- $pic = $filenames;
- try {
- $oss = $ossClient->uploadFile($bucket, $pic, $filenames);
- $filenames = $oss['info']['url'];
- $_SESSION['file']=$filenames;
- echo $filenames;
- echo '<img src="' . $filenames . '" />';
- //删除本地文件
- } catch (\OSS\Core\OssException $e) {
- die("Failed to upload file ");
- return false;
- }
- } else if(!emptyempty($_SESSION['file'])){
- try {
- $patch=trim(parse_url($_SESSION['file'])['path'],'/');
- $ossClient = new \OSS\OssClient($accessKeyId, $accessKeySecret, $endpoint);
- $oss=$ossClient->deleteObject($bucket,$patch);
- $_SESSION['file']=null;
- } catch (OssException $e) {
- printf(__FUNCTION__ . ": FAILED\n");
- printf($e->getMessage() . "\n");
- return;
- }
- }
- /**
- * 删除文件
- * 可以删除调用ajaxfile上传的文件
- * @param type $path_file 文件路径
- * 删除的时候记住不要带域名 也不要带 / 这个路径符号
- */
- function delfile($path_file) {
- if (config('config.OSS_OPEN')) {
- try {
- // 删除的时候记住不要带域名,也不要带'/'这个路径符号,如全路径是:'https://hxty.oss-cn-beijing.aliyuncs.com/data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf',则这里的path_file路径为:'data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf'。
- $path_file=trim(parse_url($path_file)['path'],'/');//去掉域名,
- $ossClient = new \OSS\OssClient(config('config.OSS_KEY'), config('config.OSS_SECRET'), config('config.OSS_ENDPOINT'));
- $ossClient->deleteObject(config('config.OSS_BUCKET'), $path_file);
- } catch (OssException $e) {
- printf(__FUNCTION__ . ": FAILED\n");
- printf($e->getMessage() . "\n");
- return;
- }
- } else {
- $val2 = "." . $path_file;
- if (file_exists($val2)) {
- $unlinkfilename = trim($path_file, "/");
- unlink($unlinkfilename);
- }
- }
- }
删除的时候记住不要带域名,也不要带'/'这个路径符号,如全路径是:'https://hxty.oss-cn-beijing.aliyuncs.com/data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf',则这里的path_file路径为:'data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf'。
出处:http://www.phpfensi.com/php/20220506/20661.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.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式