cari

Rumah  >  Soal Jawab  >  teks badan

Muat turun pdf dari API Laravel melalui Axios dalam VueJS 3

Helo, saya mempunyai bahagian hadapan VUEJS 3 dan bahagian belakang Laravel 8. Saya akan memuat turun pdf yang disimpan dalam public/pdf/temp/file.pdf

Sekarang saya membuat panggilan daripada VUEJS:

axios.post('/api/'+ this.url_access +'/rebuild', formData, { headers: {
                'Content-Type': 'multipart/form-data',
                'responseType': 'blob'
            }})
            .then(response=>{
                if(response.status == 200){
                    const url = window.URL.createObjectURL(new Blob([response.data]));
                    const link = document.createElement('a');
                    link.href = url;
                    link.setAttribute('download', 'test.pdf');
                    document.body.appendChild(link);
                    link.click();
                }
            })
            .catch(error=>{
                console.log(error);
            })

Di bahagian belakang saya mempunyai fungsi yang mengembalikan fail pdf:

try{
   $headers = [
       'Content-Type' => 'application/pdf',
   ];
   return response()->download($file_path, $workspace['name'] . '_' .date("Ymd").'.pdf', $headers)->deleteFileAfterSend(true);
}catch(Exception $e){
   return $e->getMessage();
}

Tetapi saya memuat turun pdf dengan kandungan kosong.

Ada sesiapa terfikir tentang isu ini?

P粉993712159P粉993712159420 hari yang lalu1096

membalas semua(2)saya akan balas

  • P粉610028841

    P粉6100288412023-11-17 11:46:38

    Dalam Laravel

    $pdf = PDF::loadView('users.pdf', ['data' => $data]);
     return $pdf->output();

    Dalam Vue js

    axios({
      url: 'http://localhost:8000/api/your-route',
      method: 'GET',
      responseType: 'blob',
    }).then((response) => {
     var fileURL = window.URL.createObjectURL(new Blob([response.data], {type: 
     'application/pdf'}));
     var fileLink = document.createElement('a');
     fileLink.href = fileURL;
     fileLink.setAttribute('download', 'file.pdf');
     document.body.appendChild(fileLink);
     fileLink.click();
     });

    balas
    0
  • P粉722521204

    P粉7225212042023-11-17 10:00:02

    Jawapan

    responseType ialah adik beradik header, bukan kanak-kanak

    axios.post('/api/'+ this.url_access +'/rebuild', formData, { headers: {
                    'Content-Type': 'multipart/form-data',
                },
                    'responseType': 'blob' // responseType is a sibling of headers, not a child
                })
                .then(response=>{
                    if(response.status == 200){
                        const url = window.URL.createObjectURL(new Blob([response.data]));
                        const link = document.createElement('a');
                        link.href = url;
                        link.setAttribute('download', 'test.pdf');
                        document.body.appendChild(link);
                        link.click();
                    }
                })
                .catch(error=>{
                    console.log(error);
                })

    Terima kasih Phil atas bantuan.

    balas
    0
  • Batalbalas