>웹 프론트엔드 >프런트엔드 Q&A >Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

藏色散人
藏色散人원래의
2023-01-29 13:45:052338검색

vue 파일 업로드 오류에 대한 해결 방법: 1. "vue init webpack 데모"를 통해 vue 프로젝트를 생성합니다. 2. 파일을 업로드할 요소를 추가합니다. 3. 메서드에 "upload(data)" 메서드를 추가합니다. FromData를 사용하여 필수 매개변수를 추가하고 axios를 사용하여 요청을 제출합니다.

Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

이 튜토리얼의 운영 환경: Windows 10 시스템, vue3 버전, DELL G3 컴퓨터

vue 파일을 업로드할 때 오류가 발생하면 어떻게 해야 합니까?

파일 업로드 실패에 대한 Vue의 솔루션

프로젝트에서 프론트엔드를 개발한 동료가 Vue를 사용하여 파일 업로드 모듈을 개발했는데, 어찌됐든 이 POST 요청을 제출하는 것은 불가능했습니다.
구체적인 현상은 프런트 엔드 인터페이스가 파일을 업로드할 때
Content-Type이 항상 application/x-www-form-urlencoded이고 SpringBoot의 백그라운드 서비스가 오류를 보고한다는 것입니다. Current는 멀티파트가 아닙니다. 요청이 잘못되었음을 의미합니다.

실제로 게시물에 파일을 업로드할 때 Content-Type: multipart/form-data여야 하는데 프런트 엔드가 인트라넷 내부에 캡슐화되어 있습니다. 분석 및 테스트를 거쳐 일반 HTML을 사용하여 파일을 업로드하는 데에는 문제가 없습니다. 문제는 VUE 제출 요청 프로세스에 있을 것입니다. 실제 개발 환경은 회사의 인트라넷 환경에 있고 외부 세계와 격리되어 있기 때문에 문제 해결을 용이하게 하기 위해 이 시나리오를 내 컴퓨터에서 시뮬레이션하기로 결정했습니다.

이 시뮬레이션 환경을 구현하려면 Vue 개발 환경과 Python 개발 환경을 설치해야 합니다. 이 두 가지 개발 설치 방법은 기사의 초점이 아니므로 건너뜁니다.

전체 아이디어:

Vue를 사용하여 간단한 프런트 엔드 인터페이스를 개발하여 파일 업로드 기능을 구현한 다음 Python을 사용하여 웹 백엔드 서비스를 개발합니다.

1단계: Vue로 웹 페이지 만들기

vue 프로젝트 만들기:

vue init webpack demo

axios를 사용하여 요청을 제출하려면 axios를 설치할 필요가 없으며 직접 가져오세요

새로 생성된 vue 프로젝트를 VSCode로 엽니다

Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

파일을 업로드할 요소 추가:

<template>
  <div>
    <img  alt="Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?" >
    <router-view></router-view>
    <input>
  </div>
  
</template>
<script></script>
<script>

import axios from &#39;axios&#39;
export default {
  name: &#39;App&#39;
}
</script>

<style>
#app {
  font-family: &#39;Avenir&#39;, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

핵심 사항

그런 다음 제어 스크립트를 추가하세요:

<template>
  <div>
    <img  alt="Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?" >
    <router-view></router-view>
    <input>
  </div>
  
</template>
<script></script>
<script>
import axios from &#39;axios&#39;
export default {
  name: &#39;App&#39;,
    methods:{
    upload(data){
          console.log(&#39;--->&#39;,data)         
          var formData = new FormData();
          formData.append(&#39;side&#39;, &#39;front&#39;);
          formData.append(&#39;file&#39;,data.target.files[0]);
          
          let config = {
             headers: {
               &#39;Content-Type&#39;: &#39;multipart/form-data&#39;             
             }
          };
          axios.post(&#39;http://127.0.0.1:5050/icard/check&#39;,formData,config)
            .then((response) => {
                console.log("OK");
          })
        }  
  }
}</script>

업로드(데이터) 메소드를 메소드에 추가
FromData를 사용하여 필수 매개변수를 추가하고 axios를 사용하여 요청을 제출합니다.

2단계: Python을 사용하여 간단한 웹 서비스 개발

from flask import Flask, request
from flask_cors import CORS

app = Flask(__name__)

#跨域处理
cors = CORS(app, supports_credentials=True)

@app.route('/icard/check',methods=['POST'])
def deal_request1():
    print('收到post请求')
    side = request.form["side"]
    image = request.files.get('file')   
      
    print("side= %s"% (side))
    print("filename= %s"% (image.filename))

    return "OK"

if __name__ == '__main__':   
    app.run(host="127.0.0.1", port=5050)

Python의 Flask는 너무 예리하고 간단한 웹 서비스를 만드는 것이 너무 쉽습니다.
기본 아이디어는 로컬 포트 ​​5050에 서비스를 생성하는 것입니다. URL http://127.0.0.1:5050/idcard/check에 대한 HTTP 요청이 있으면 매개변수를 수신하고 수신된 매개변수를 인쇄합니다.

jupyter에서 시작한 후 다음은 다음과 같습니다.

Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

시작한 후 프롬프트: Running on http://127.0.0.1:5050/ (종료하려면 Ctrl+C를 누르세요)

OK, 간단합니다. WEB 서비스가 시작됩니다. 다음으로 vue를 시작합니다.

VSCodel에서 명령줄 터미널을 열고 npm run dev를 입력하여 시작합니다.

그런 다음 브라우저에서 엽니다. https://www.php.cn/link/5ba026c424f718a4808f9d3f75856dab

Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

vue의 초기 프로젝트이기 때문에 열어보면 이런 모습입니다. 중요한 점은 마지막 줄에서 파일을 선택할 수 있다는 점입니다. 이때 먼저 브라우저 디버깅 도구를 연 다음 파일을 선택하세요. 브라우저 디버깅 도구의 정보를 살펴보세요. 하이라이트는 여기에 있습니다

로그 출력이 vue 코드에 추가되기 때문입니다: console.log('--->',data)
로그를 볼 수 있습니다. 브라우저의 정보
Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

중요한 부분은 빨간색 선으로 표시되어 있으며 여기서 출력을 볼 수 있습니다. 이벤트의 데이터는

event.target.file에 따라 업로드해야 하는 파일 개체를 가져올 수 있습니다. [0], 네트워크의 상황을 살펴보세요.

Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

요청 헤더에는 두 줄의 중요한 정보가 있습니다.

  Content-Length: 69392
  Content-Type: multipart/form-data; boundary=----WebKitFormBoundarycgFDx4PDNjkXoSnZ

第一行表示上传的文件大小字节数,
Content-Type代表发送端发送的实体数据的数据类型,如果向服务器端发送的是普通的字符串,默认设置为:text/html;
post请求肯定要发送数据包;
因此对数据包的Type有专门的限定:
Content-Type只能是
application/x-www-form-urlencoded,
application/json
multipart/form-data
或 text/plain中的一种。
其他的均不常见。

在看看服务端的情况:

Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?

Web 服务端立即输出了相关信息,说明已经得到了上传文件的数据,这里为了做测试仅仅输出了文件名和另一个参数。
在我的电脑上测试上传文件,接收文件都OK。
然后同事根据我的代码修改了内网VUE工程的代码,问题来了,在内网里上传文件时也用console.log(data)输出了event,但是格式和这里不同哦,这是很大的疑惑或许是环境问题吧,
在我的测试工程中用event.target.file[0]可以得到需要上传的文件对象,但是在内网环境下event里面根本木有target这个节点,根据最后需要的是file节点的特征,在raw节点下找到了file节点,然后代码修改为
 

upload(data){
          console.log('--->',data)         
          var formData = new FormData();
          formData.append('side', 'front');
          formData.append('file',data.raw.files[0]);
          
          let config = {
            // headers: {
            //   'Content-Type': 'multipart/form-data'             
            // }
          };
          axios.post('http://127.0.0.1:5050/icard/check',formData,config)
            .then((response) => {
                console.log("OK");
          })
        }

内网环境下上传文件成功了。并且测试发现,只要这里正确得到了文件对象参数,那么可以不用显式指定Content-Type,这里也会自动把Content-Type设置为multipart/form-data,我不了解Vue底层是如何处理的,可能是发现提交的数据是流,因此把这里的类型自动设置成了multipart/form-data。

 推荐学习:《vue视频教程

위 내용은 Vue 파일 업로드 오류가 발생하면 어떻게 해야 할까요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.