When i was tried to add Authorization code in react js custom header .. POST method changed to OPTION method .
fetch('http://localhost:8000/api/user/save', {
method : 'POST',
headers: {
'Accept' : 'application/json',
'Content-Type' : 'application/x-www-form-urlencoded',
'Authorization' : 'Bearer ' + sessionStorage.getItem('token')
},
body : formBody
})
.then(response => response.json())
.then(response => {
}).catch((err) => {
alert('Something is error ! ');
});
Note : I want to use cross origin . My react app on localhost:3000 and my server localhost:8000
This is because of CORS, if your API and the front end lives on the same project you can just change http://localhost:8000/api/user/save to /api/user/save.
You can also disable CORS.
Related
We are building an application that uses React framework for the frontend and Laravel framework for the backend. The problem is whenever sending a post request for '/store-image' route. The response returns with Error 500: Call to a member function storeAs() on null.
It seems that Laravel isn't reading the request.
Here is my request code:
const formDa = new FormData();
setSelectedFile(imgRef.current.files[0]);
formDa.append("file", selectedFile);
fetch("https://api.pharo-tech.xyz/store-image",{
method:'POST',
body : {
image : formDa,
},
headers : {
'Authorization': 'Bearer ' + token,
'Accept' : 'application/json',
'Content-Type' : 'multipart/form-data'
}
}).then(res=>res.json()).then(data=> console.log(data)).catch(e => console.log(e))
Here is my ImageController.php code:
public function store(Request $request) {
$request->file('image')->storeAs('profile_images', mt_rand(100, 1000000000) . ".{$request->file('image')->guessExtension()}");
}
You append formDa.append("file", selectedFile);and from API you try to get file $request->file('image'). Here your attach file stored in file not image.
You need to update your code as below.
HTML
<input type="file" onchange="onLoadImage(this)">
Script
function onLoadImage(e) {
var token = '';
var selectedFile = e.files[0];
const formDa = new FormData();
formDa.append("image", selectedFile);
fetch("https://api.pharo-tech.xyz/store-image", {
method: 'POST',
body: formDa,
headers: {
'Authorization': 'Bearer ' + token,
'Accept': 'application/json'
}
}).then(res => res.json()).then(data =>
console.log(data)).catch(e => console.log(e))
}
API
public function store(Request $request) {
$request->file('image')->storeAs('profile_images', mt_rand(100, 1000000000) . ".{$request->file('image')->guessExtension()}");
return response()->json([success: true]);
}
I made a server query via an app developed using react-native. I used fetch API and it turns out any query with authorization header not working. POST and GET method REQUESTS that don't expect Authorization headers at the server side works well. Some Queries at the server side are protected with authorization and when I make such queries including authorization header, I always get '401:unauthorized' error.
But such queries works well with POSTMAN. Any suggestions here would be of great help.
getThingsApi() {
let uri = "https://example.com/things/";
let req = {
method: "GET",
credentials: "include",
//mode: "no-cors",
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json',
//'Access-Control-Request-Method': 'GET',
//'Access-Control-Request-Headers': 'origin, x-requested-with',
'Origin': '',
'Host':'example.com',
'authorization': 'Basic '+Base64.btoa('aaa:bbb'),
'Cache-Control': 'no-cache'
}
};
fetch(uri, req)
.then(response => response.json())
.then(responseJson => {
console.log("ResponseAxis::" + JSON.stringify(responseJson));
console.log("ResponseAxis::" + JSON.stringify(responseJson));
alert("ResponseAxis::" +JSON.stringify(responseJson));
})
.catch(error => {
console.log("Error::" + JSON.stringify(error));
});
}
Issue is fixed. We used Fetch API and fetch Api converts all headers into lower-case(eg: authorization) and the server side expects upper-case starting letter(eg: Authorization). After changing the server side code to be case-insensitive, everything works fine.
There are different ways to make a REST call in react-
e.g
axios.post('link', JSON.stringify(data1),
{
headers: {"content-type" : "application/json", "Access-Control-Allow-Origin" : "*"}})
.then(response => {
console.log("res:", response)
})
.catch(err =>{
console.log(err)
})
}
OR
fetch('http://localhost:8080/feedbacks/addfeedback', {
method: 'post',
headers: {
'Content-Type': 'application/json',
'Access-Control-Allow-Origin' : '*'
},
body:body
What is the most effiecient way to enable CORS.
Is there any other way that I can do this either in frontend or backend?
It depends on what HTTP library you are using.
See What is difference between Axios and Fetch?.
I usually use Axios, next what i do is creating a global instance and configuring Axios once.
export const api = axios.create({
baseURL: '_URL_',
timeout: 1000,
withCredentials: false,
responseType: 'json',
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json',
'Access-Control-Allow-Origin': '*' // whatever you want
}
});
// You can add common headers later
api.defaults.headers.common['Authorization'] = `Bearer ${token}`;
Also i'm enabling CORS on my server side application.
Thanks to #henrik123 for good explanation:
The browser is going to see that some Javascript request has tried to initiate a request to a different domain, subdomain or port than what the browsers is currently at. If any of these things are different, the CORS kicks in. Doesn't matter if you use Axios, Fetch or any other other library
Can't send authorization header with rest API. Got 'OPTIONS' error with status 0. All headers and options are allowed on the server. Server is written on PHP.
Here is my request:
axios.post(`${API_URL}users/${23}/profile/main/update`,
{formData},{
headers:{ 'Content-Type':'multipart/form-data',
Authorization:`Bearer ${token}`}
})
It seems like it does not send the header when there is authorization. However, it works, if i delete authorization, and leave only content type
This should do the trick
axios({
method: 'POST',
url:`${API_URL}users/${23}/profile/main/update`,
headers: {
'Content-Type':'multipart/form-data',
'Authorization':`Bearer ${token}`},
data: formData
})
Refer docs for browser
Try to send as below:
var headers = {
'Content-Type': 'multipart/form-data',
'Authorization': `Bearer ${token}`
}
axios.post(`${API_URL}users/${23}/profile/main/update`,
{formData}, headers)
Try using Ajax call below:
import $ from 'jquery';
$.ajax({
url:`${API_URL}users/${23}/profile/main/update`,
processData: false,
contentType: false,
data : formData,
method : "POST",
headers: {
"Authorization": `Bearer ${token}`
}
});
I had this same issue, it is possible that you are not passing the sent auth header from your apache config to your php application.
you might need to set
WSGIPassAuthorization On
inside your virtualhost config.
Check this
I cannot get the fetch api to work with the mailchimp api in React. I'm also using webpack to run a devserver.
This is what I have:
componentDidMount() {
let authenticationString = btoa('123:myapikey-us17');
authenticationString = "Basic " + authenticationString;
fetch('https://us17.api.mailchimp.com/3.0/lists/fakelistid/segments', {
mode: 'no-cors',
method: 'GET',
credentials: 'same-origin',
headers: new Headers({
'Authorization': authenticationString,
'Accept': 'application/json',
'Content-Type': 'application/json'
})
}).then(function(e){
console.log("fetch finished")
}).catch(function(e){
console.log("fetch error");
})
}
I've tested the exact same api request in Postman and that works fine.
When I try this in React I keep getting a 401 status code saying "Your request did not include an API key."