对于网站上传的图片,图片被上传到服务器中后,我们怎么去记录每个上传的图片文件的储存的地址呢?
比如:用户上传的图像,相册,商品图片等等,这些上传的图片我们怎么去记录其所在地址呢?
1:比如用户表有个 avatar 字段,用户上传图片后,然后把形如: http://www.thinkphp.cn/Uploads/da/2015-08-05/55c18ef67e249.jpg 这样的图片url存入 avatar 字段吗? 还是只存图片名称,或者拆分为三段 域名/路径/名称 存入三个字段?
2:还有用户相册,用户上传很多图片,这个怎么将图片的url保存在数据库中呢?
3:还有DZ论坛中一篇帖子内容中可能包含很多图片,这个怎么存呢,还是要单独建一个图片附件表,然后与帖子ID关联?
4:如果使用的是云存储呢,比如七牛和又拍云,使用它们的接口上传后,也是会给你返回一个图片url的吗?那么我们也像上面那样将返回的图片url保存在数据库中吗?
既然网站很多地方都使用了图片上传功能,每个被上传的图片在服务器中的位置都需要被记录下来,那我们何不专门创建一张表来保存所有上传的图片url呢?
我想到的最简单的这个表的设计:imgup(id, url)
就这样简单,所有上传的图片信息都在这里记录,比如原先用户表中的 avatar 保存的是图像的url,现在就可以保存这个对应id就可以了,这样就简单多了,商品图片,帖子内容图片,……,都同理。
但是我总觉得这样太简单了,过于不妥,这个表到底怎样设计最合理呢?需不需要加上图片的一些其它信息呢,比如在客户端被上传前的原始名称,图片大小,图片尺寸,图片创建时间,图片修改时间,图片EXIF信息,……等等。
没有看过DZ的代码,帖子中可以看到每个附件图片和其它文件,并能控制权限让用户下载,不知道它那个是怎么做的。
这个问题被延伸到网站【文件上传】上面就不局限于图片了,所有上传的文件信息都放在这个 记录上传文件信息 的表里面,那就方便多了,管理也方便,所以这个问题我想了很久,就是没有经验,所以先来请教下各位大神。
希望有经验的大神们不吝赐教,指点迷津,我当没齿难忘,谢谢!
回复内容:
对于网站上传的图片,图片被上传到服务器中后,我们怎么去记录每个上传的图片文件的储存的地址呢?
比如:用户上传的图像,相册,商品图片等等,这些上传的图片我们怎么去记录其所在地址呢?
1:比如用户表有个 avatar 字段,用户上传图片后,然后把形如: http://www.thinkphp.cn/Uploads/da/2015-08-05/55c18ef67e249.jpg 这样的图片url存入 avatar 字段吗? 还是只存图片名称,或者拆分为三段 域名/路径/名称 存入三个字段?
2:还有用户相册,用户上传很多图片,这个怎么将图片的url保存在数据库中呢?
3:还有DZ论坛中一篇帖子内容中可能包含很多图片,这个怎么存呢,还是要单独建一个图片附件表,然后与帖子ID关联?
4:如果使用的是云存储呢,比如七牛和又拍云,使用它们的接口上传后,也是会给你返回一个图片url的吗?那么我们也像上面那样将返回的图片url保存在数据库中吗?
既然网站很多地方都使用了图片上传功能,每个被上传的图片在服务器中的位置都需要被记录下来,那我们何不专门创建一张表来保存所有上传的图片url呢?
我想到的最简单的这个表的设计:imgup(id, url)
就这样简单,所有上传的图片信息都在这里记录,比如原先用户表中的 avatar 保存的是图像的url,现在就可以保存这个对应id就可以了,这样就简单多了,商品图片,帖子内容图片,……,都同理。
但是我总觉得这样太简单了,过于不妥,这个表到底怎样设计最合理呢?需不需要加上图片的一些其它信息呢,比如在客户端被上传前的原始名称,图片大小,图片尺寸,图片创建时间,图片修改时间,图片EXIF信息,……等等。
没有看过DZ的代码,帖子中可以看到每个附件图片和其它文件,并能控制权限让用户下载,不知道它那个是怎么做的。
这个问题被延伸到网站【文件上传】上面就不局限于图片了,所有上传的文件信息都放在这个 记录上传文件信息 的表里面,那就方便多了,管理也方便,所以这个问题我想了很久,就是没有经验,所以先来请教下各位大神。
希望有经验的大神们不吝赐教,指点迷津,我当没齿难忘,谢谢!
没人回答吗?
1.UPYUN的外链为形式:http://<空间名>.b0.upaiyun.com/
#可以自己去定义,可以参考save-key 详细说明
2.可以参考官方的SDK
3.DZ官方有插件你可以看看[DZ]
4.同2
我现在也在做类似平台,我采用的方式是使用nodejs来处理所有文件的请求。命名方式采用uid/year-month/hash 。七牛的话,看你的是不是私密空间了,如果不是则直接根据bucket的域名拼接就行。如果是私密空间,可用sdk获取文件临时下载地址。手机打的,说得有点乱,见谅

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

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

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

Atom编辑器mac版下载
最流行的的开源编辑器

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具