比如用户发一个帖子要先上传图片(文件是保存在七牛这类第三方平台,用户上传成功后会向数据库里写一条记录的),当用户把图片上传完成后,用户突然不想发帖了,直接关掉了浏览器。结果导致用户刚刚上传的图片成为垃圾。
请问,我该怎么设置数据库 逻辑,当用户上传的文件没被使用时,后台直接清除掉文件
回复内容:
比如用户发一个帖子要先上传图片(文件是保存在七牛这类第三方平台,用户上传成功后会向数据库里写一条记录的),当用户把图片上传完成后,用户突然不想发帖了,直接关掉了浏览器。结果导致用户刚刚上传的图片成为垃圾。
请问,我该怎么设置数据库 逻辑,当用户上传的文件没被使用时,后台直接清除掉文件
我看不下去了,
说方法吧,不管最后发不发帖,都将上传对应的图片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)实现databasequerycachingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandredececonnection.4 limitsclection.4.4

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

databasequeryOptimizationinphpinvolVolVOLVESEVERSEVERSTRATEMIESOENHANCEPERANCE.1)SELECTONLYNLYNESSERSAYCOLUMNSTORMONTOUMTOUNSOUDSATATATATATATATATATATRANSFER.3)

phpisusedforsenderemailsduetoitsbuilt-inmail()函数andsupportiveLibrariesLikePhpMailerandSwiftMailer.1)usethemail()functionforbasicemails,butithasimails.2)butithasimimitations.2)

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

依赖性注射(DI)InphpisadesignPatternthatManages和ReducesClassDeptions,增强量产生性,可验证性和Maintainability.itallowspasspassingDepentenciesLikEdenceSeconnectionSeconnectionStoclasseconnectionStoclasseSasasasasareTers,interitationApertatingAeseritatingEaseTestingEasingEaseTeStingEasingAndScalability。

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 英文版
推荐:为Win版本,支持代码提示!

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器