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

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

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

Socket.IOはNode.js上で動くライブラリであり、すべてのブラウザとモバイルデバイスでリアルタイムのアプリを作動させる事を目的としています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

CORS

CORSとはCross-Origin Resource Sharingの頭文字をとったもので、ブラウザがオリジン以外のサーバからデータを取得するシステムのことです。

React.js

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

Q&A

解決済

1回答

192閲覧

Socket.ioをReactで使ってみたいがCORSエラーが直らなくて困っています

Issei_Taka

総合スコア1

Socket.IO

Socket.IOはNode.js上で動くライブラリであり、すべてのブラウザとモバイルデバイスでリアルタイムのアプリを作動させる事を目的としています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

CORS

CORSとはCross-Origin Resource Sharingの頭文字をとったもので、ブラウザがオリジン以外のサーバからデータを取得するシステムのことです。

React.js

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

0グッド

0クリップ

投稿2023/05/22 08:13

編集2023/05/22 08:14

実現したいこと

・ReactでScoket.ioを使ってローカルで動作するチャットアプリを作りたいのですが、CORSエラーが出つづけて一生サーバーと接続されません。CORSエラーの対処法を教えていただきたいです。

前提

CORSエラーの対処法として様々なものを試しました。

app.use(cors())やapp.use(関数でヘッダーなどを指定する方法)などを試してみましたが上手くいきませんでした。

発生している問題・エラーメッセージ

Access to XMLHttpRequest at 'http://localhost:3100/socket.io/?EIO=4&transport=polling&t=OX2VWMF' from origin 'http://localhost:3000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. :3100/socket.io/?EIO=4&transport=polling&t=OX2VWMF:1 Failed to load resource: net::ERR_FAILED

該当のソースコード

javascript

1const express = require('express'); 2const http = require('http'); 3const socketIO = require('socket.io'); 4 5const app = express(); 6const server = http.createServer(app); 7const io = socketIO(server); 8 9 10app.use(function(req, res, next) { 11 res.header("Access-Control-Allow-Origin", "*"); 12 res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept"); 13 next(); 14}); 15 16io.on('connection', (socket) => { 17 console.log('A client connected.'); 18 19 // クライアントからの新しいメッセージを受け取るリスナーを設定 20 socket.on('chat message', (msg) => { 21 console.log('Received message:', msg); 22 // クライアント全体にメッセージをブロードキャスト 23 io.emit('chat message', msg); 24 }); 25 26 // クライアントが切断した場合の処理 27 socket.on('disconnect', () => { 28 console.log('A client disconnected.'); 29 }); 30}); 31 32const port = 3100; // サーバーポート番号を適宜設定してください 33 34server.listen(port, () => { 35 console.log(`Server listening on port ${port}`); 36}); 37

試したこと

他に必要なコードがある場合はなるべく早く対応します。
お助けください よろしくお願いします

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

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

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

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

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

guest

回答1

0

自己解決

Socket.io側でのCORSの設定ができていないだけでした お騒がせしました

投稿2023/05/22 08:29

Issei_Taka

総合スコア1

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問