## 上傳表如何設計
>[info] 我們希望將每次上傳的文件記錄在表中,這樣有很多作用,比如根據 MD5/HASH 實現圖片上傳時的去重,還可以用在業務字段中,很方便,管理上傳資源也會很方便。
但是這樣的一張表要如何設計呢?
我們先來看基本的上傳文件URL
**上傳文件 URL如何存儲?**
```
https://img30.360buyimg.com/n0/s616x405_jfs/t3856/64/1821196656/118766/f30bddd8/5899ac63N2b32c298.jpg
這是京東的用戶曬圖圖片地址
http://yuanchuan.tenpower.club/uploads/20170331/20853c0d06e363d7509825a80e9846b6.jpg
這是禮品平臺的圖片上傳地址
```
**其實可分為**
```
協議 + 主機 + 域名 + 業務目錄 + 上傳時產生的動態目錄
[ https:// ] + [ img30. ] + [ 360buyimg.com/ ] + [ n0/s616x405_jfs/ ] + [ t3856/64/1821196656/118766/f30bddd8/5899ac63N2b32c298.jpg ]
[ http:// ] + [ yuanchuan. ] + [ tenpower.club/ ] + [ uploads/ ] + [ 20170331/20853c0d06e363d7509825a80e9846b6.jpg ](這部分也是目前我們數據庫中存的部分)
京東那個圖片是動態的
https://img30.360buyimg.com/n0/s616x45_jfs/t3856/64/1821196656/118766/f30bddd8/5899ac63N2b32c298.jpg
可以改變大小
```
**可以知道這部分是動態的,應該不會存**
```
還要也要考慮CDN,一張圖片分發到什么機器上去了
(想錯了,CDN是自動的,并不會要求改變網址,所以網址應該是固定的)
```
**那么結論:**
需要存: 能代表這個文件的真是地址的url也就是 主機和包含路徑的文件名
即
```
還是: 協議 + 主機 + 域名 + 業務目錄 + 上傳時產生的動態目錄
```
但是為了靈活性,比如業務目錄調整啊,網址變更啊,所以這些應分開存在不同的字段中
```
完整URL = 協議 + 主機 + 域名 + 業務目錄 + 上傳時產生的動態目錄
url = agreement + host + domain + business_directory + file
```
**那么我們設計的表應該是:**
表名:`tb_uploads`
| 字段名 | 說明 |
| --- | --- |
| id | 自增ID |
| agreement | 協議 |
| host | 主機 |
| domain | 一級域名 |
| business_directory | 業務目錄 |
| file | 動態文件地址 |
| create_time | 創建時間 |
| create_ip | 創建IP |
| user_id | 用戶ID,默認0表示上傳者未登錄(不過由于去重機制,這只是第一次上傳此文件的用戶ID,實際上由于去重,此表也只會記錄第一個上傳信息) |
| md5 | 文件MD5 |
| hash | 文件HASH |
| size | 文件大小 |
| width| 圖片高度(僅圖片文件有這個值) |
| height| 圖片高度(僅圖片文件有這個值) |
*(根據業務邏輯還可以劃分出一個附件表)*
* * * * *
### 擴展
**獲取圖片的url可訪問地址**
~~~php
/**
* 默認可以壓縮上傳的文件
* 對上傳文件顯示前進行的url轉換/處理
* 如果是有協議的 http:// https:// …… 或者 不限協議 //url 這樣的 直接返回
* 如果是 / 以 域名為頂級 的 給加上域名即可
* 否則和 config('uploads_url') 拼接
* @param string $value 待處理的地址
* @return string 處理后的地址
*/
function media($value, $max_quality = 60)
{
$void = Request::instance()->root(true) . '/static/images/void.jpg';
if ($value == '') {
return $void;
}
if (strpos($value, '://') || 0 === strpos($value, '//')) {
return $value;
}
if (0 === strpos($value, '/')) {
return Request::instance()->domain() . $value;
}
// 那么就是上傳圖片了
if (!file_exists(config('base_uploads_path') . $value)) {
return $void;
}
return config('uploads_url') . getSmallImg($value, $max_quality);
}
~~~
last update :2017-6-1 10:51:39
- 開始
- 公益
- 更好的使用看云
- 推薦書單
- 優秀資源整理
- 技術文章寫作規范
- SublimeText - 編碼利器
- PSR-0/PSR-4命名標準
- php的多進程實驗分析
- 高級PHP
- 進程
- 信號
- 事件
- IO模型
- 同步、異步
- socket
- Swoole
- PHP擴展
- Composer
- easyswoole
- php多線程
- 守護程序
- 文件鎖
- s-socket
- aphp
- 隊列&并發
- 隊列
- 講個故事
- 如何最大效率的問題
- 訪問式的web服務(一)
- 訪問式的web服務(二)
- 請求
- 瀏覽器訪問阻塞問題
- Swoole
- 你必須理解的計算機核心概念 - 碼農翻身
- CPU阿甘 - 碼農翻身
- 異步通知,那我要怎么通知你啊?
- 實時操作系統
- 深入實時 Linux
- Redis 實現隊列
- redis與隊列
- 定時-時鐘-阻塞
- 計算機的生命
- 多進程/多線程
- 進程通信
- 拜占庭將軍問題深入探討
- JAVA CAS原理深度分析
- 隊列的思考
- 走進并發的世界
- 鎖
- 事務筆記
- 并發問題帶來的后果
- 為什么說樂觀鎖是安全的
- 內存鎖與內存事務 - 劉小兵2014
- 加鎖還是不加鎖,這是一個問題 - 碼農翻身
- 編程世界的那把鎖 - 碼農翻身
- 如何保證萬無一失
- 傳統事務與柔性事務
- 大白話搞懂什么是同步/異步/阻塞/非阻塞
- redis實現鎖
- 淺談mysql事務
- PHP異常
- php錯誤
- 文件加載
- 路由與偽靜態
- URL模式之分析
- 字符串處理
- 正則表達式
- 數組合并與+
- 文件上傳
- 常用驗證與過濾
- 記錄
- 趣圖
- foreach需要注意的問題
- Discuz!筆記
- 程序設計思維
- 抽象與具體
- 配置
- 關于如何學習的思考
- 編程思維
- 談編程
- 如何安全的修改對象
- 臨時
- 臨時筆記
- 透過問題看本質
- 程序后門
- 邊界檢查
- session
- 安全
- 王垠
- 第三方數據接口
- 驗證碼問題
- 還是少不了虛擬機
- 程序員如何談戀愛
- 程序員為什么要一直改BUG,為什么不能一次性把代碼寫好?
- 碎碎念
- 算法
- 實用代碼
- 相對私密與絕對私密
- 學習目標
- 隨記
- 編程小知識
- foo
- 落盤
- URL編碼的思考
- 字符編碼
- Elasticsearch
- TCP-IP協議
- 碎碎念2
- Grafana
- EFK、ELK
- RPC
- 依賴注入
- 科目一
- 開發筆記
- 經緯度格式轉換
- php時區問題
- 解決本地開發時調用遠程AIP跨域問題
- 后期靜態綁定
- 談tp的跳轉提示頁面
- 無限分類問題
- 生成微縮圖
- MVC名詞
- MVC架構
- 也許模塊不是唯一的答案
- 哈希算法
- 開發后臺
- 軟件設計架構
- mysql表字段設計
- 上傳表如何設計
- 二開心得
- awesomes-tables
- 安全的代碼部署
- 微信開發筆記
- 賬戶授權相關
- 小程序獲取是否關注其公眾號
- 支付相關
- 提交訂單
- 微信支付筆記
- 支付接口筆記
- 支付中心開發
- 下單與支付
- 支付流程設計
- 訂單與支付設計
- 敏感操作驗證
- 排序設計
- 代碼的運行環境
- 搜索關鍵字的顯示處理
- 接口異步更新ip信息
- 圖片處理
- 項目搭建
- 閱讀文檔的新方式
- mysql_insert_id并發問題思考
- 行鎖注意事項
- 細節注意
- 如何處理用戶的輸入
- 不可見的字符
- 抽獎
- 時間處理
- 應用開發實戰
- python 學習記錄
- Scrapy 教程
- Playwright 教程
- stealth.min.js
- Selenium 教程
- requests 教程
- pyautogui 教程
- Flask 教程
- PyInstaller 教程
- 蜘蛛
- python 文檔相似度驗證
- thinkphp5.0數據庫與模型的研究
- workerman進程管理
- workerman網絡分析
- java學習記錄
- docker
- 筆記
- kubernetes
- Kubernetes
- PaddlePaddle
- composer
- oneinstack
- 人工智能 AI
- 京東
- pc_detailpage_wareBusiness
- doc
- 電商網站設計
- iwebshop
- 商品規格分析
- 商品屬性分析
- tpshop
- 商品規格分析
- 商品屬性分析
- 電商表設計
- 設計記錄
- 優惠券
- 生成唯一訂單號
- 購物車技術
- 分類與類型
- 微信登錄與綁定
- 京東到家庫存系統架構設計
- crmeb
- 命名規范
- Nginx https配置
- 關于人工智能
- 從人的思考方式到二叉樹
- 架構
- 今日有感
- 文章保存
- 安全背后: 瀏覽器是如何校驗證書的
- 避不開的分布式事務
- devops自動化運維、部署、測試的最后一公里 —— ApiFox 云時代的接口管理工具
- 找到自己今生要做的事
- 自動化生活
- 開源與漿果
- Apifox: API 接口自動化測試指南