Heim Backend-Entwicklung PHP-Tutorial Detaillierte Erläuterung des Laravel-Framework-Frontends zum Hochladen von Bildern in die Qiniu Cloud-Instanz

Detaillierte Erläuterung des Laravel-Framework-Frontends zum Hochladen von Bildern in die Qiniu Cloud-Instanz

Sep 07, 2017 pm 01:50 PM
laravel 上传 图片

In diesem Artikel wird hauptsächlich der Beispielcode zum Hochladen von Bildern in die Qiniu Cloud mithilfe von Front-End-JS in Laravel vorgestellt. Er hat einen gewissen Referenzwert.

Im Folgenden wird der Browser verwendet Laden Sie Bilder in Laravel hoch. Hier sind nur einige einfache Prozessbeispiele.

1. Stellen Sie zunächst die entsprechende js-Datei vor. Natürlich gibt es viele andere Möglichkeiten zum Herunterladen, z. B. Bower, Git und das SDK der offiziellen Website Qiniu js basiert auf dem Plupload-Plug-In und muss daher Plupload herunterladen. Es wird empfohlen, 2.1.1 bis 2.1.9 zu verwenden.


<script src="https://cdn.staticfile.org/jquery/2.2.1/jquery.min.js"></script>
<script src="https://cdn.staticfile.org/plupload/2.1.9/moxie.js"></script>
<script src="https://cdn.staticfile.org/plupload/2.1.9/plupload.dev.js"></script>
<script src="https://cdn.staticfile.org/qiniu-js-sdk/1.0.14-beta/qiniu.min.js"></script>
Nach dem Login kopieren
2. Erstellen Sie eine Schaltfläche zum Auswählen einer Datei



  <p id="container">
    <a class="btn btn-default btn-lg " id="pickfiles" href="#" rel="external nofollow" >
      <span>选择文件</span>
    </a>
  </p>
Nach dem Login kopieren
3. Initialisierungs-Uploader


(Bitte stellen Sie sicher, dass plupload bei der Initialisierung auf der Seite eingeführt wurde. Hier benötigen wir einen Uptoken-Upload-Zugangsdaten, der vom PHP-Backend generiert und bereitgestellt werden muss). Lassen Sie uns gleich darüber sprechen, wie Sie den Token erhalten.


  function uploaderReady(token) {
    console.log(token);
    var uploader = Qiniu.uploader({
      runtimes: &#39;html5,flash,html4&#39;,   // 上传模式,依次退化
      browse_button: &#39;pickfiles&#39;,   //上传按钮的ID
      uptoken: token, // uptoken是上传凭证,由其他程序生成
     // uptoken_url: &#39;/uptoken&#39;,    // Ajax请求uptoken的Url,强烈建议设置(服务端提供)
     // uptoken_func: function(){    // 在需要获取uptoken时,该方法会被调用
     //  // do something
     //  return uptoken;
     // },
      get_new_uptoken: false,       // 设置上传文件的时候是否每次都重新获取新的uptoken
      unique_names: true,       // 默认false,key为文件名。若开启该选项,JS-SDK会为每个文件自动生成key(文件名)
      //save_key: true,         // 默认false。若在服务端生成uptoken的上传策略中指定了sava_key,则开启,SDK在前端将不对key进行任何处理
      domain: &#39;http://ovngj7u9c.bkt.clouddn.com&#39;,  // bucket域名,下载资源时用到,必需
      container: &#39;container&#39;,       // 上传区域DOM ID,默认是browser_button的父元素
      max_file_size: &#39;100mb&#39;,       // 最大文件体积限制
      flash_swf_url: &#39;path/of/plupload/Moxie.swf&#39;, //引入flash,相对路径
      max_retries: 1,           // 上传失败最大重试次数
      dragdrop: true,           // 开启可拖曳上传
      drop_element: &#39;container&#39;,     // 拖曳上传区域元素的ID,拖曳文件或文件夹后可触发上传
      chunk_size: &#39;4mb&#39;,         // 分块上传时,每块的体积
      auto_start: true,          // 选择文件后自动上传,若关闭需要自己绑定事件触发上传

      init: {
        &#39;FilesAdded&#39;: function (up, files) {
          plupload.each(files, function (file) {
            // 文件添加进队列后,处理相关的事情
          });
        },
        &#39;BeforeUpload&#39;: function (up, file) {
          // 每个文件上传前,处理相关的事情
        },
        &#39;UploadProgress&#39;: function (up, file) {
          // 每个文件上传时,处理相关的事情
        },
        &#39;FileUploaded&#39;: function (up, file, info) {
          // 每个文件上传成功后,处理相关的事情
          // 其中info是文件上传成功后,服务端返回的json,形式如:
          // {
          //  "hash": "Fh8xVqod2MQ1mocfI4S4KpRL6D98",
          //  "key": "gogopher.jpg"
          // }
          // 获取url路径 传入后台保存到数据库
           var domain = up.getOption(&#39;domain&#39;);
           var url = JSON.parse(info);
           var sourceLink = domain +"/"+ url.key;

           $.ajax({
            url: &#39;/image&#39;,
            type: &#39;POST&#39;,
            dataType : &#39;json&#39;,
            data: {
              &#39;_token&#39;:"{{ csrf_token() }}",
              "url":sourceLink
            },
           });
        },
        &#39;Error&#39;: function (up, err, errTip) {
          console.log(errTip);
        },
        &#39;UploadComplete&#39;: function () {
          //队列文件处理完毕后,处理相关的事情
        },
        &#39;Key&#39;: function (up, file) {
          // 若想在前端对每个文件的key进行个性化处理,可以配置该函数
          // 该配置必须要在unique_names: false,save_key: false时才生效
          var key = "";
          // do something with key here
          return key
        }
      }
    });
  }
Nach dem Login kopieren
4. Das Backend erhält das Upload-Zertifikat-Token


Zuerst installieren wir einen Qiniu-Packagisten und eine Github-Adresse.


composer require "overtrue/laravel-filesystem-qiniu" -vvv
Nach dem Login kopieren
Fügen Sie


&#39;providers&#39; => [
  // Other service providers...
  Overtrue\LaravelFilesystem\Qiniu\QiniuStorageServiceProvider::class,
],
Nach dem Login kopieren
in app/config.php und dann in config/filesystems hinzu. Konfigurieren Sie Ihre Qiniu-Informationen in PHP


<?php

return [
  //...
  &#39;qiniu&#39; => [
    &#39;driver&#39;   => &#39;qiniu&#39;,
    &#39;access_key&#39; => env(&#39;QINIU_ACCESS_KEY&#39;, &#39;xxxxxxxxxxxxxxxx&#39;),
    &#39;secret_key&#39; => env(&#39;QINIU_SECRET_KEY&#39;, &#39;xxxxxxxxxxxxxxxx&#39;),
    &#39;bucket&#39;   => env(&#39;QINIU_BUCKET&#39;, &#39;test&#39;),
    &#39;domain&#39;   => env(&#39;QINIU_DOMAIN&#39;, &#39;xxx.clouddn.com&#39;), // or host: https://xxxx.clouddn.com
  ],
  //...
];
Nach dem Login kopieren
und schreiben Sie dann den Code, um das Token in der Store-Methode Ihres Controllers zu erhalten. Nach einer Weile kann das Frontend eine Anfrage stellen es mit Ajax.


public function store()
{
  $disk = Storage::disk(&#39;qiniu&#39;);
  $token = $disk->getUploadToken();
  
  return response()->json([&#39;uptoken&#39;=>$token]);
}
Nach dem Login kopieren
Nachdem wir das Token haben, verbessern wir den Front-End-Code weiter


Um Verstehen Sie, wir schreiben einen Ajax, um den Store anzufordern. Natürlich können Sie die Anforderungsadresse auch im Attribut uptoken_url im Uploader festlegen.


function getTokenMessage() {
  $.ajax({
    url: &#39;你的控制器地址&#39;,
    type: &#39;POST&#39;,
    data: {&#39;_token&#39;:"{{ csrf_token() }}"},
    dataType : &#39;json&#39;,
    success: function (data) {
      var obj = data;
      // 请求成功之后,调用刚刚写好的uploaderReady方法,把token传入过去
      uploaderReady(obj.uptoken);
    }
  });
}
//让页面初始化的时候就请求
$(document).ready(function(){
  getTokenMessage();
});
Nach dem Login kopieren
Das ist alles. Weitere Informationen finden Sie im offiziellen js-Dokument von Qiniu Cloud

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des Laravel-Framework-Frontends zum Hochladen von Bildern in die Qiniu Cloud-Instanz. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Vergleich der neuesten Versionen von Laravel und CodeIgniter Vergleich der neuesten Versionen von Laravel und CodeIgniter Jun 05, 2024 pm 05:29 PM

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Jun 01, 2024 pm 01:34 PM

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Was ist einsteigerfreundlicher: Laravel oder CodeIgniter? Was ist einsteigerfreundlicher: Laravel oder CodeIgniter? Jun 05, 2024 pm 07:50 PM

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Jun 04, 2024 am 09:09 AM

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Laravel – Handwerkerbefehle Laravel – Handwerkerbefehle Aug 27, 2024 am 10:51 AM

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Laravel vs CodeIgniter: Welches Framework ist besser für kleine Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für kleine Projekte? Jun 04, 2024 pm 05:29 PM

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.

Welche ist die bessere Template-Engine, Laravel oder CodeIgniter? Welche ist die bessere Template-Engine, Laravel oder CodeIgniter? Jun 03, 2024 am 11:30 AM

Vergleichen Sie Laravel's Blade und die Twig-Vorlagen-Engine von CodeIgniter und wählen Sie je nach Projektanforderungen und persönlichen Vorlieben: Blade basiert auf der MVC-Syntax, die eine gute Codeorganisation und Vorlagenvererbung fördert. Twig ist eine Bibliothek eines Drittanbieters, die flexible Syntax, leistungsstarke Filter, erweiterten Support und eine Sicherheits-Sandbox bietet.

Laravel – Paginierungsanpassungen Laravel – Paginierungsanpassungen Aug 27, 2024 am 10:51 AM

Laravel – Paginierungsanpassungen – Laravel enthält eine Paginierungsfunktion, die einem Benutzer oder Entwickler hilft, eine Paginierungsfunktion einzubinden. Der Laravel-Paginator ist in den Abfrage-Builder und Eloquent ORM integriert. Die Paginierungsmethode automatisch

See all articles