質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

0回答

253閲覧

RESTAPI叩く際にCROSのエラーが起きる

21212121

総合スコア61

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2020/03/23 06:18

ReactでAPIを取得しようとしたらこのようなエラーが起きました。

signup:1 Access to fetch at 'https://mayoeru-sheep.herokuapp.com/api/v1/sign_up' from origin 'http://localhost:3000' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled.

コードは下記の通りです。

import React, { Component } from "react"; import "bootstrap/dist/css/bootstrap.min.css"; import { Form } from "react-bootstrap"; import { Button } from "react-bootstrap"; import { Container, Row, Col } from "react-bootstrap"; import LOGO from "../../assets/img/logo.jpg"; import TOP from "../../assets/img/top.jpg"; class Signup extends Component { constructor(props) { super(props); this.state = { name: "", email: "", old: "", gender: "", password: "" // redirectToReferrer: false }; this.signup = this.signup.bind(this); this.onChange = this.onChange.bind(this); } signup(event) { const url = "https://mayoeru-sheep.herokuapp.com/api/v1/sign_up"; event.preventDefault(); let data = { user_params: { name: this.state.name, birthday: this.state.old, email: this.state.email, gender: 1, password: this.state.password, password_confirm: this.state.password } }; fetch(url, { mode: "cors", method: "POST", body: JSON.stringify(data), headers: { Accept: "application/json", "Content-Type": "application/json" } }) .then(response => response.json()) .then(json => { alert("loh"); //ユーザ生成時に以下の情報をローカルストレージに入れる。 console.log(json); window.localStorage.setItem("token", json.token); window.localStorage.setItem("id", json.id); window.localStorage.setItem("token", json.token); }) .then(responseData => { console.log(responseData); }) .catch(err => { console.log(err, err.data); }); alert("koko"); } onChange(e) { this.setState({ [e.target.name]: e.target.value }); console.log([e.target.name], e.target.value); } render() { return ( <Container style={{ textAlign: "left" }}> <Row> <Col lg={4}> <Form style={{ marginTop: "10%", marginRight: "28%" }}> <img src={LOGO} alt="MyLogo" /> <Form.Group controlId="formBasicEmail"> <Form.Label>お名前</Form.Label> <Form.Control name="name" type="name" placeholder="name" onChange={this.onChange} /> </Form.Group> <Form.Group controlId="formBasicEmail"> <Form.Label>メールアドレス</Form.Label> <Form.Control name="email" type="email" placeholder="Enter email" onChange={this.onChange} /> </Form.Group> <Form.Group controlId="exampleForm.ControlSelect1"> <Form.Label>年齢</Form.Label> <Form.Control as="select" name="old" onChange={this.onChange}> <option>18</option> <option>19</option> <option>20</option> <option>21</option> <option>22</option> <option>23</option> <option>24</option> <option>25</option> <option>26</option> <option>27</option> <option>28</option> <option>29</option> <option>30</option> </Form.Control> <Form.Label>性別</Form.Label> <Form.Control as="select" name="gender" onChange={this.onChange} > <option>男</option> <option>女</option> </Form.Control> </Form.Group> <Form.Group controlId="formBasicPassword"> <Form.Label>パスワード</Form.Label> <Form.Control name="password" type="password" placeholder="Password" onChange={this.onChange} /> <Form.Label>パスワード</Form.Label> <Form.Control name="password" type="password" placeholder="Password" onChange={this.onChange} /> </Form.Group> <Button variant="danger" type="submit" onClick={this.signup}> 始める </Button> </Form> </Col> <Col lg={8}> <img style={{ maxWidth: "100%", height: "95vh", margin: "0" }} src={TOP} alt="toppic" /> </Col> </Row> </Container> ); } } export default Signup;

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

21212121

2020/03/23 06:55

というと、APIの不備が問題ですか?
hoshi-takanori

2020/03/23 06:57

不備というかポリシーかもしれません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問