| Nuvem | Vários uploads de arquivo | BASE64 Upload da imagem | Upload de arquivo do servidor |
|---|---|---|---|
| ? Nuvem privada | ✅ | - | ✅ |
| ? Cloud Alibaba | ✅ | ✅ | ✅ |
| ? Tencent Cloud | ✅ | ✅ | ✅ |
| ? Qiniu Cloud | ✅ | ✅ | ✅ |
| ? Amazon (S3) | ✅ | ✅ | ✅ |
composer require tinywan/storage $ res = Tinywan Storage Storage:: uploadFile ();
var_dump ( json_encode ( $ res ));
Apósv1.0.0, esse método não precisa ser chamado após a inicializaçãoTinywanStorageStorage::config(), ele será inicializado automaticamente. A configuração padrão é o arquivo dedefaultdo arquivo deapp.php.
[
{
"key" : " webman " ,
"origin_name" : "常用编程软件和工具.xlsx " ,
"save_name" : " 03414c9bdaf7a38148742c87b96b8167.xlsx " ,
"save_path" : " runtime/storage/03414c9bdaf7a38148742c87b96b8167.xlsx " ,
"save_path" : " /var/www/webman-admin/public/storage/03414c9bdaf7a38148742c87b96b8167.xlsx " ,
"url" : " /storage/fd2d472da56c71a6da0a5251f5e1b586.png " ,
"uniqid " : " 03414c9bdaf7a38148742c87b96b8167 " ,
"size" : 15050 ,
"mime_type" : " application/vnd.openxmlformats-officedocument.spreadsheetml.sheet " ,
"extension" : " xlsx "
}
...
]Falhou, lançando exceção de
StorageAdapterException
| Campos | descrever | Valores de exemplo |
|---|---|---|
| chave | Faça o upload da chave do arquivo | Webman |
| origem_name | Nome do arquivo original | Software de programação comum e ferramentas.xlsx |
| save_name | Salvar o nome do arquivo | 03414C9BDAF7A38148742C87B96B8167.XLSX |
| save_path | Caminho de economia de arquivos (relativo) | /var/www/webman-admin/runtime/storage/03414c9bdaf7a38148742c87b96b8167.xlsx |
| url | Caminho de acesso da URL | /Storage/03414C9BDAF7A38148742C87B96B8167.XLSX |
| exclusivo_id | Uniqid | 03414C9BDAF7A38148742C87B96B8167 |
| tamanho | Tamanho do arquivo | 15050 (bytes) |
| MIME_TYPE | Tipo de arquivo | Application/vnd.openxmlformats-tingocument.spreadsheetml.sheet |
| extensão | Extensão de arquivo | xlsx |
Por padrão, ele é carregado no servidor local. Um arquivo com a data atual como subdiretório e o nome do arquivo codificado pelo SHA1 do fluxo de arquivos serão gerados no diretório runtime/storage . Por exemplo, o nome do arquivo gerado acima pode ser:
runtime/storage/fd2d472da56c71a6da0a5251f5e1b586.png
Se você deseja que o arquivo carregado seja diretamente acessível ou baixado, você pode usar o método de armazenamento public .
Você pode configurar o diretório raiz de upload no arquivo de configuração config/plugin/tinywan/storage/app.php , por exemplo:
' local ' => [
' adapter ' => Tinywan Storage Adapter LocalAdapter::class,
' root ' => public_path () . ' /storage ' ,
],Acesso ao navegador: http://127.0.0.1:8787/storage/fd2d472da56c71a6da0a5251f5e1b586.png
Suporta a verificação de arquivos enviados usando classes de verificação, incluindo tamanho do arquivo, tipo de arquivo e sufixo
| Campos | descrever | Valores de exemplo |
|---|---|---|
| single_limit | O limite de tamanho para um único arquivo, padrão de 200m | 1024 * 1024 * 200 |
| Total_limit total_limit | Todos os arquivos Limite de tamanho, padrão 200m | 1024 * 1024 * 200 |
| Nums | Limite do número do arquivo, padrão 10 | 10 |
| incluir | Lista de tipos de arquivo permitidos | ['xlsx', 'pdf'] |
| excluir | Lista de tipos de arquivos não autorizados | ['png', 'jpg'] |
composer require aliyuncs/oss-sdk-phpcomposer require qcloud/cos-sdk-v5composer require qiniu/php-sdkcomposer require league/flysystem-aws-s3-v3Cenário de uso: Captura de tela direta do front-end (Ava, Canvas, etc.) Uma imagem do fluxo de dados base64 é carregada diretamente para a nuvem
{
"extension" : " png " ,
"base64" : " data:image/jpeg;base64,/9j/4AAQSkxxxxxxxxxxxxZJRgABvtyQBIr/MPTPTP/2Q== "
} public function upload ( Request $ request )
{
$ base64 = $ request -> post ( ' base64 ' );
$ response = Tinywan Storage Storage:: disk ( Tinywan Storage Storage:: MODE_OSS , false )-> uploadBase64 ( $ base64 , ' png ' );
var_dump ( $ response );
}
Apósv1.0.0, esse método não precisa ser chamado após a inicializaçãoTinywanStorageStorage::config(), ele será inicializado automaticamente. A configuração padrão é o arquivo dedefaultdo arquivo deapp.php.
{
"save_path" : " storage/20220402213639624851671439e.png " ,
"url" : " http://webman.oss.tinywan.com/storage/20220402213639624851671439e.png " ,
"unique_id" : " 20220402213639624851671439e " ,
"size" : 11802 ,
"extension" : " png "
}Cenário de uso: os arquivos de exportações do servidor precisam ser carregados para armazenamento em nuvem ou baixados no Arquivo de Arquivos Zero Time.
$ serverFile = runtime_path () . DIRECTORY_SEPARATOR . ' storage/webman.png ' ;
$ res = Tinywan Storage Storage:: disk ( Tinywan Storage Storage:: MODE_OSS , false )-> uploadServerFile ( $ serverFile );
Apósv1.0.0, esse método não precisa ser chamado após a inicializaçãoTinywanStorageStorage::config(), ele será inicializado automaticamente. A configuração padrão é o arquivo dedefaultdo arquivo deapp.php.
{
"origin_name" : " /var/www/webman-admin/runtime/storage/webman.png " ,
"save_path" : " storage/6edf04d7c26f020cf5e46e6457620220402213414.png " ,
"url" : " http://webman.oss.tinywan.com/storage/6ed9ffd54d0df57620220402213414.png " ,
"unique_id" : " 6edf04d7c26f020cf5e46e6403213414 " ,
"size" : 3505604 ,
"extension" : " png "
} vendor/bin/phpstan analyse src
vendor/bin/php-cs-fixer fix src