How to solve the problem of php unlink failure
Solution to php unlink failure: 1. Open the corresponding PHP sample file; 2. Use "unset($info);" to unblock the process of the image; 3. Re-execute the "@unlink" operation. , syntax "@unlink($filePath);".
#The operating environment of this article: Windows 7 system, PHP8, Dell G3 computer.
Recently when I was doing the avatar change function on my website, it involved PHP file upload.
The solution I adopt is that the user first uploads to the server, and then the server uploads it to Alibaba Cloud's OSS. In the middle, there will be a process of temporarily storing the image to the server. So I discovered the problem of deletion failure when using PHP's @unlink (delete specified file) method.
At first I thought my path name was written wrong, but later I confirmed that this parameter was correct. The reason for the deletion failure is that the picture is still occupied by the process, so if we want to successfully perform the @unlink operation, we'd better manually release the file object to avoid deletion failure due to being occupied by other threads or processes. The code snippet is as follows:
// [API接口-用户更新头像] public function setAvatar() { // 获取表单上传文件 $file = $this->request->file('avatar'); if ($file) { // 移动到框架应用根目录/public/uploads/ 目录下 $info = $file->rule('date')->move(ROOT_PATH . 'public' . DS . 'uploads'); if ($info) {//文件上传到服务器成功->接下来上传到OSS $filePath = ROOT_PATH . 'public' . DS . 'uploads/' . $info->getSaveName(); $oss = new Oss(); $result = $oss->putObject($filePath); if ($result) { //上传到OSS成功 unset($info);//解除图片的进程占用 @unlink($filePath); return success(['avatar' => $result['fileSrc']], '头像更新成功'); } } } }
It has to be said that self-study is very difficult, and the reason lies not in the outside world, but in the inside. This time, in order to pursue what I wanted, I cut off my retreat and quit my stable job. I hope these sacrifices will not be worthless.
[Recommended: "PHP Video Tutorial"]
The above is the detailed content of How to solve the problem of php unlink failure. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics





The article discusses OWASP Top 10 vulnerabilities in PHP and mitigation strategies. Key issues include injection, broken authentication, and XSS, with recommended tools for monitoring and securing PHP applications.

PHP 8's JIT compilation enhances performance by compiling frequently executed code into machine code, benefiting applications with heavy computations and reducing execution times.

The article discusses securing PHP file uploads to prevent vulnerabilities like code injection. It focuses on file type validation, secure storage, and error handling to enhance application security.

The article discusses symmetric and asymmetric encryption in PHP, comparing their suitability, performance, and security differences. Symmetric encryption is faster and suited for bulk data, while asymmetric is used for secure key exchange.

The article discusses implementing robust authentication and authorization in PHP to prevent unauthorized access, detailing best practices and recommending security-enhancing tools.

The article discusses strategies for implementing API rate limiting in PHP, including algorithms like Token Bucket and Leaky Bucket, and using libraries like symfony/rate-limiter. It also covers monitoring, dynamically adjusting rate limits, and hand

Article discusses best practices for PHP input validation to enhance security, focusing on techniques like using built-in functions, whitelist approach, and server-side validation.

The article discusses strategies to prevent CSRF attacks in PHP, including using CSRF tokens, Same-Site cookies, and proper session management.
