比如用户发一个帖子要先上传图片(文件是保存在七牛这类第三方平台,用户上传成功后会向数据库里写一条记录的),当用户把图片上传完成后,用户突然不想发帖了,直接关掉了浏览器。结果导致用户刚刚上传的图片成为垃圾。
请问,我该怎么设置数据库 逻辑,当用户上传的文件没被使用时,后台直接清除掉文件
回复内容:
比如用户发一个帖子要先上传图片(文件是保存在七牛这类第三方平台,用户上传成功后会向数据库里写一条记录的),当用户把图片上传完成后,用户突然不想发帖了,直接关掉了浏览器。结果导致用户刚刚上传的图片成为垃圾。
请问,我该怎么设置数据库 逻辑,当用户上传的文件没被使用时,后台直接清除掉文件
我看不下去了,
说方法吧,不管最后发不发帖,都将上传对应的图片id存到数据库,只是该图片的对应帖子id为空或者0,查询距当前时间一小时((时间自己决定)),若没有对应的就认为他垃圾图片,调用七牛接口删除,删除数据库记录
若发帖了就标记对应的帖子id
方法很多啊,个人认为最简单的做发是,在发贴成功前,图片先存临时文夹,或做临时文件标识,发贴成功后才把图片移动到相应文件夹或去除临时文件标识,这样,定时去删除临时文件就好了,
没有用数据库保存过文件,说下目录保存文件,比如form表单上传文件上传后文件会保存在系统临时目录,之后一般会移动到Web下的文件目录,所以你可以再分一个目录当作永久目录,对于保存的将文件移动到永久目录,临时目录定时清理就OK。对于数据库存文件,form上传后仍然会保持在系统临时目录,你可以将文件移动到一个临时存储表或者临时目录,保持成功再移动到永久存储表/目录,再定时清理临时表/目录。这样你其实有3个地方存储:系统临时目录,临时目录/临时表,永久目录/永久表,再省事的方法就是只用系统临时目录+永久目录/永久表,上次后文件在系统临时目录,只记录个路径,保持后移动到永久目录/永久表,不保存的定时清理。
其实php上传的文件一开始是保存到了系统临时目录里的。你不去动它就好了。
或者你需要:
http://php.net/manual/zh/function.tempna...
这个函数会在临系统时目录生成一个能使用的临时文件。
七牛官方多媒体静态资源的处理还是建议使用js sdk的方式上传,可以减少服务器端的处理,只需要记住文件上传后的几个基本信息即可,非常省事,性能当然也是目前最佳选择。安全性不用担心,请参考文档,并做好js跨域控制。关注「phpgod」PHP技术大全,成就大神就不远。

tomakephpapplicationsfaster,關注台詞:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

到ImprovephPapplicationspeed,關注台詞:1)啟用opcodeCachingwithapCutoredUcescriptexecutiontime.2)實現databasequerycachingingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandreduceconnection.4 limitesclection.4.4

依赖注入(DI)通过显式传递依赖关系,显著提升了PHP代码的可测试性。1)DI解耦类与具体实现,使测试和维护更灵活。2)三种类型中,构造函数注入明确表达依赖,保持状态一致。3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi

phpisusedforsenderemailsduetoitsbuilt-inmail()函數andsupportivelibrariesLikePhpMailerAndSwiftMailer.1)usethemail()functionForbasiceMails,butithasimails.2)butithasimail.2)

PHP性能瓶颈可以通过以下步骤解决:1)使用Xdebug或Blackfire进行性能分析,找出问题所在;2)优化数据库查询并使用缓存,如APCu;3)使用array_filter等高效函数优化数组操作;4)配置OPcache进行字节码缓存;5)优化前端,如减少HTTP请求和优化图片;6)持续监控和优化性能。通过这些方法,可以显著提升PHP应用的性能。

依賴性注射(DI)InphpisadesignPatternthatManages和ReducesClassDeptions,增強量強制性,可驗證性和MATIALWINABIOS.ItallowSpasspassingDepentenciesLikEdenciesLikedAbaseConnectionStoclasseconnectionStoclasseSasasasasareTers,interitationAseTestingEaseTestingEaseTestingEaseTestingEasingAndScalability。

cachingimprovesphpermenceByStorcyResultSofComputationsorqucrouctationsorquctationsorquickretrieval,reducingServerLoadAndenHancingResponsetimes.feftectivestrategiesinclude:1)opcodecaching,whereStoresCompiledSinmememorytssinmemorytoskipcompliation; 2)datacaching datacachingsingMemccachingmcachingmcachings


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。