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  訪問


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM