郑先森灬
【技术解读】react build 后打包发布总结
一、部署在apache web服务器上(wamp|xammp)
1.后台接口需要做跨域设置
(1)在服务端利用Access-Control-Allow-Origin响应头解决。设置Access-Control-Allow-Origin:*,允许所有域名的脚本访问该资源。如果考虑到安全问题,也可以设置Access-Control-Allow-Origin:www.build.im 允许特定域名访问(2)服务器做反向代理
(2)打包文件单独放置一个服务器
1.把react 项目 build 打包后 复制build 里面的文件到web服务器的根目录
2.同时需要在web根目录放置.htaccess文件,文件内容为:(当服务器出现找不到路由时自动回到index.html 路由由react-router 接管
附备注:
前端本地开发时会存在跨域问题,如果项目是用creat-react-app cli 创建的,则直接在package.json 文件里添加 api 地址目录即可:"proxy": “www.api.com:8000” 即可解决跨域问题,如果是自己创建的项目
配置好proxy middlle 中间件 也可以实现代理。本地fecth( ''api/userinfo", fucntion(){} ); 请求会发送到 http://www.online.com:80/api/userinfo 接口上
proxy: {
'/api)': {
target: 'http://www.online.com:80/',
changeOrigin: true
},
}
<IfModule mod_rewrite.c>
Options +FollowSymlinks
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.html [QSA,PT,L]
</IfModule>
二,部署在nginx web 服务器上
try_files 指令:配置 nginx/nginx.conf 文件
server {
...
location / {
try_files $uri /index.html
}
}
react build 后的文件包里的文件直接放到 nginx 下的web 目录 即可通过ip 访问
EYblog - Powered by Eyblog
https://jwwey.com/index.php/archives/62/(转载时请注明本文出处及文章链接)