Heim >Web-Frontend >js-Tutorial >Wie lade ich Dateien in AngularJS hoch? Detaillierte Einführung in die Upload-Funktion von AngularJS

Wie lade ich Dateien in AngularJS hoch? Detaillierte Einführung in die Upload-Funktion von AngularJS

寻∝梦
寻∝梦Original
2018-09-08 15:00:533580Durchsuche

In diesem Artikel geht es hauptsächlich um die Datei-Upload-Funktion von AngularJS. Wissen Sie, wie man Dateien in AngularJS hochlädt? Angularjs ist die Frontend-Seite. Wissen Sie, was im Backend verwendet wird? >

Das Frontend ist die
Seite

AngularJS

und das Backend verwendet
  • Angular

  • zum Hochladen von Dateien
  • SpringBoot/SpirngMVC

    html

<p>
    <input id="fileUpload" type="file" />
    <button ng-click="uploadFile()">上传</button></p>

    js
  •         $scope.upload = function(){
                var form = new FormData();            var file = document.getElementById("fileUpload").files[0];
                form.append(&#39;file&#39;, file);            $http({
                    method: &#39;POST&#39;,
                    url: &#39;/upload&#39;,
                    data: form,
                    headers: {&#39;Content-Type&#39;: undefined},
                    transformRequest: angular.identity
                }).success(function (data) {
                    console.log(&#39;upload success&#39;);
                }).error(function (data) {
                     console.log(&#39;upload fail&#39;);
                })
            }
Hinweis:
  • Der Standardwert
  • von AngularJS ist
. Durch die Einstellung von
hilft uns der Browser nicht nur,

auf

zu setzen, sondern auch auszufüllen das aktuelle
    ,
  • 'Content-Type'application/jsonBei manueller Einstellung auf: 'Content-Type': undefined wird eine Ausnahme im Hintergrund ausgelöst: Content-Typemultipart/form-databoundary

  • ist eine zufällig generierte Zeichenfolge, die zum Trennen von Textanfang und -ende verwendet wird.

    'Content-Type': multipart/form-datathe request was rejected because no multipart boundary was found

    Durch Festlegen von
  • serialisiert
  • unser

    oder ohne das Hinzufügen von boundary

  • transformRequest: angular.identityanjularjs transformRequest functionBackendformdata object

  •     @RequestMapping("/upload")    public void uploadFile(@RequestParam(value = "file" , required = true) MultipartFile file) {        //deal with file
        }
Hinweis
  • Die Datei muss über die Annotation @RequestParam abgerufen werden. Und Sie müssen den abzurufenden Wert angeben

  • Damit ist der Upload der Datei abgeschlossen

Datei beim Übergeben anderer Parameter
  • html

    <p>
        <input id="fileUpload" type="file" />
        <button ng-click="ok()">上传</button><br>
        <input ng-model="user.username" />
        <input ng-model="user.password" />
    </p>

    js
  •     $scope.ok = function () {
            var form = new FormData();        var file = document.getElementById("fileUpload").files[0];   
            var user =JSON.stringify($scope.user);
    
            form.append(&#39;file&#39;, file);
            form.append(&#39;user&#39;,user);        $http({
                method: &#39;POST&#39;,
                url: &#39;/addUser&#39;,
                data: form,
                headers: {&#39;Content-Type&#39;: undefined},
                transformRequest: angular.identity
            }).success(function (data) {
                console.log(&#39;operation success&#39;);
            }).error(function (data) {
                console.log(&#39;operation fail&#39;);
            })
        };
  • Hinweis

    Sie müssen das Objekt in einen String konvertieren bevor Sie es an das Formular anhängen, andernfalls wird es direkt in Zeichen umgewandelt. String [Objekt, Objekt]

    • Backend (wenn Sie möchten Um mehr zu sehen, besuchen Sie die chinesische PHP-Website

      AngularJS Development Manual
    • Mittelschule)
    @RequestMapping("/upload")    public Map<String, Object> upload(@RequestParam(value = "file") MultipartFile file, @RequestParam(value = "user", required = true) String user) {        try (FileInputStream in = (FileInputStream) headImg.getInputStream();
             FileOutputStream out = new FileOutputStream("filePathAndName")) {            //将Json对象解析为UserModel对象
            ObjectMapper objectMapper = new ObjectMapper();
            UserModel userModel = objectMapper.readValue(user, UserModel.class);            //保存文件到filePathAndName
            int hasRead = 0;            byte[] bytes = new byte[1024];            while ((hasRead = in.read(bytes)) > 0) {                out.write(bytes, 0, hasRead);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
  • Beachten Sie, dass

  • ist

  • Verwenden Sie ObjectMapper, um Dateien hochzuladencom.fasterxml.jackson.databind.ObjectMapper

  • Dieser Artikel endet hier (falls Sie Wenn Sie mehr sehen möchten, besuchen Sie die chinesische PHP-Website
AngularJS-Benutzerhandbuch
Study). Wenn Sie Fragen haben, können Sie unten eine Nachricht hinterlassen.

AngularJS

Das obige ist der detaillierte Inhalt vonWie lade ich Dateien in AngularJS hoch? Detaillierte Einführung in die Upload-Funktion von AngularJS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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