为什么我在Postman中的POST请求可以正常工作,而在客户端(浏览器)中却不能正常工作?

时间:2020-08-21 15:59:49

标签: javascript php reactjs laravel debugging

我有一个Laravel和React.js项目,它们是单独的代码库。当我使用登录端点登录Postman,然后使用另一个端点上传文件名(它们都是POST请求)时,filePathemailuser_id已成功存储在数据库中

但是,当我在浏览器上尝试使用此方法时-我得到了200,但奇怪的是,数据库中没有存储任何内容。

在Postman中,它以某种方式检测到用户的登录状态,这使我可以毫无问题地将上述信息存储到数据库中。

我在前端和后端代码中的哪些操作不允许我在浏览器中执行此操作?我已经用它撞墙了,不知道从这里到哪里。

仅供参考:dd($user);返回正确的信息。

如果您需要更多信息,请告诉我:)

这是我的Upload.js文件:

import React, {Component} from 'react';
import axios from 'axios';

class Upload extends Component {
    constructor(props) {
        super(props);

        this.state = {
            selectedFile: null,
            id: null,
            email: ''
        };
        this.onFormSubmit = this.onFormSubmit.bind(this);
        this.onChange = this.onChange.bind(this);
        this.fileUpload = this.fileUpload.bind(this);
    }

    componentDidMount() {
        console.log("Inside componentDidMount()");
        let id = localStorage.getItem("id");
        let email = localStorage.getItem("email");
        this.setState({
            id: id,
            email: email
        })
        console.log(id);
        console.log(email);
    }

    onFormSubmit(e) {
        e.preventDefault();
        this.fileUpload(this.state.selectedFile);
    }

    onChange(e) {
        this.setState({ selectedFile: e.target.files[0] }, () => this.state.selectedFile);
    }

    fileUpload(file) {
        const formData = new FormData();
        const accessToken = localStorage.getItem("access_token").slice(13,-8);

        console.log(accessToken);
        console.log(this.state.id);
        console.log(this.state.email);
        console.log(file.name);
        formData.append('file',file);

        const headers = {
            'Authorization' : 'Bearer ' + accessToken,
            'Content-type': 'multipart/form-data'
        }

        axios.post('http://127.0.0.1:8000/api/auth/wall-of-fame', formData, {headers})
            .then(response => {
                console.log(response);
            }).catch(error => {
            console.log(error);
        });
    }

    render() {
        return (
            <form encType='multipart/form-data' id="login-form" className="form" >
                <input type="file" name="file" onChange={this.onChange}/>
                <button type="submit" onClick={this.onFormSubmit}>Upload</button>
            </form>
        );
    }

}

export default Upload;

这是我的FileUploadController.php文件:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\DB;

class FileUploadController extends Controller {

    public function store(Request $request) {
        $user = Auth::user();

//        dd($user);
        if($user) {
            $user_id = Auth::user()->id;
            $email = Auth::user()->email;
            $filePath = $request->file('file')->getClientOriginalName();
            $data = [
                'file_path' => $filePath,
                'user_id' => $user_id,
                'email' => $email
            ];
            DB::table('mydb.photos')->insert($data);
        }

        return response()->json($user);
    }
}

这是我的api.php文件:

Route::middleware('auth:api')->group(function () {
    Route::get('/user', function (Request $request) {
        return $request->user();
    });
});

Route::group([
    'prefix' => 'auth'
], function () {
    Route::post('login', 'AuthController@login');
    Route::post('signup', 'AuthController@signup');
    Route::post('wall-of-fame', 'FileUploadController@store');

    Route::group([
        'middleware' => 'auth:api'
    ], function() {
        Route::get('logout', 'AuthController@logout');
        Route::get('user', 'AuthController@user');
        Route::get('wall-of-fame', 'FileUploadController@fileUpload');
    });
});

enter image description here enter image description here

1 个答案:

答案 0 :(得分:0)

我认为您可以尝试使用"Access-Control-Allow-Origin: *"

设置响应的标题

您可以阅读此链接以获取更多信息Cross-Origin Request Blocked