カテゴリー
開発中のSvelte/SvelteKitのDevサーバーのCORS対策
※ 当ページには【広告/PR】を含む場合があります。
2024/12/18
data:image/s3,"s3://crabby-images/7aa3f/7aa3fc1b8889e3ae36ba66ff303c22addba55392" alt="蛸壺の技術ブログ|開発中のSvelte/SvelteKitのDevサーバーのCORS対策"
http://localhost
data:image/s3,"s3://crabby-images/cb86a/cb86ac764eb6e80a8da9565d5d31ac43f042aed3" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
Viteのサーバープロキシ機能
data:image/s3,"s3://crabby-images/85855/858553b696729997066a880e0ccc1fb2733e032e" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
vite.config.ts(もしくはvite.config.js)
import { defineConfig } from 'vite';
// ...
export default defineConfig({
// ...
server: {
proxy: {
'/api': {
target: "https://hoge.piyo.com",
changeOrigin: true,
rewrite: (path) => path.replace(/^\/api/, '')
}
}
}
})
http://localhost:12345/api
target
https://hoge.piyo.com/api
/api
rewrite
rewrite
https://hoge.piyo.com/api
/api
https://hoge.piyo.com
cosnst url = 'https://hoge.piyo.com/?huga=moga&buyo=jifo';
const urlForProxy = url.replace(/^https\:\/\/hoge\.piyo\.com/m, '/api');
const response = await fetch(urlForProxy, {
method: 'GET',
headers: {
'content-type': 'application/json'
},
});
const rslt = await response.text();
//OR, const rslt = await response.json();
console.log(rslt);
data:image/s3,"s3://crabby-images/429b8/429b82c27ff682698d0d512fc1034cc58ed4f0c1" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
余談〜ViteのCORS設定の注意点
cors: true
import { defineConfig } from 'vite';
// ...
export default defineConfig({
// ...
server: {
cors: true
}
})
data:image/s3,"s3://crabby-images/cb86a/cb86ac764eb6e80a8da9565d5d31ac43f042aed3" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
Express/CORS
まとめ
記事を書いた人
ナンデモ系エンジニア
主にAngularでフロントエンド開発することが多いです。 開発環境はLinuxメインで進めているので、シェルコマンドも多用しております。 コツコツとプログラミングするのが好きな人間です。
カテゴリー