微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

React.js 上传文件到服务器

如何解决React.js 上传文件到服务器

我正在尝试通过 Sanctum 身份验证与 Laravel 8 一起反应。我正在尝试使用 React文件上传到服务器。我正在使用 react-dropzone 来拖动和预览图像和 Laravel8 这是 react-dropzone 代码

const { getRootProps,getInputProps } = useDropzone({
    accept: "image/*",onDrop: (acceptedFiles) => {
      setFiles(
        acceptedFiles.map((file) =>
          Object.assign(file,{
            preview: URL.createObjectURL(file),})
        )
      );
    },});

我正在获取文件并且是预览。这是我用来上传到服务器的上传代码

const data = new FormData();
files.map((file) => data.append("images",file));
apiclient.get("sanctum/csrf-cookie").then(() => {
      apiclient
        .post("api/upload/image/1",data,{
          headers,})
        .then((res) => {
          console.log(res);
        })
        .catch((err) => {
          console.dir(err);
          toast.error("Something Went Wrong");
        })
})

在 Laravel 上,我试图通过以下方式捕获请求 $request->all() 但它返回 images: {}

解决方法

您需要通过 file 函数或作为对象属性来捕获它,例如->images 而不是 all

更多:https://laravel.com/docs/8.x/requests#files

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。