当前位置: 首页 > news >正文

wordpress全站伪静态网站开发人员分配

wordpress全站伪静态,网站开发人员分配,台州网站公司建站,上海著名企业问题 当Angular在本地ng server运行时候,可以顺利访问各级路由。 但是运行ng build后,在dist 路径下的打包好的额index.html 必须要在服务器下运行才能加载。 在服务器下我们第一次访问路由页面时是没有问题的,但是尝试刷新页面或手动输入路…

问题

当Angular在本地ng server运行时候,可以顺利访问各级路由。
但是运行ng build后,在dist 路径下的打包好的额index.html 必须要在服务器下运行才能加载。
在服务器下我们第一次访问路由页面时是没有问题的,但是尝试刷新页面或手动输入路由地址,会发现页面变成了404,
在这里插入图片描述
可以看到控制台报警 GET http://localhost:8004/b-component 404 (File not found), 我们在debug模式下是没有问题的,但是在打包服务器环境下运行就不行了。
有其他文章说 使用hash 路由可以解决问题,但是hash路由毕竟不是主流的路由方式。
目前使用重定位路由解决。

解决方式

一 创建文件

由于我们使用的是 python的 http server。所以我们创建python 脚本,src/server.py
代码如下:

import http.server
import socketserver
import os , reclass MyHttpRequestHandler(http.server.SimpleHTTPRequestHandler):def do_GET(self):# #方法一:根据路由地址判断# if self.path in ['/', '/a-component', '/b-component', '/c-component']:#     self.path = 'index.html'#方法二:根据文件后缀判断# 排除一些可能的无后缀静态资源# path 里面不含有 . 后缀的都认为是路由地址if re.match(r'^\/(?!robots\.txt|sitemap\.xml|manifest\.json).*', self.path) and '.' not in self.path:self.path = 'index.html'return http.server.SimpleHTTPRequestHandler.do_GET(self)handler_object = MyHttpRequestHandlerPORT = 8004
my_server = socketserver.TCPServer(("", PORT), handler_object)my_server.serve_forever()

代码里面,创建了一个自定义的 http.server
当页面请求到固定的路由地址的时候,将请求重定向到了index.html文件,因为我们打包后只有index.html文件,并没有其他的网页文件,所以请求的资源找不到。
这里简单有几种判断方式:

  • 一:枚举所有的重定向地址,如果网页有改动的话需要动态更高
  • 二:根据响应的规则,判断如果是路由地址的话,就重定向到index.html,此规则需要根据实际情况修改
  • 三:在ng build 后,编写脚本,通过js或者python,读取src/app/app.routes.ts文件里面的所有路由地址,存入文件,然后在服务器脚本里面读取判断(未做)

配置拷贝

在angular.json 中添加"src/server.py",这样当build的时候,会拷贝 server.py 在dist 的index.html的同级目录
在这里插入图片描述

打包

运行 ng build

运行服务器

进入打包目录后,运行 server.py

  • cd …/dist/btest/browser
  • python3 server.py

访问网页正常

在这里插入图片描述

http://www.yayakq.cn/news/766798/

相关文章:

  • 网站建设色网站建设合同
  • 电商网站建设目的虎鲸微信管理系统
  • 建设旅游门户网站网站名称与域名
  • 单县菏泽网站建设ppt设计主题
  • 专业网站建设公司兴田德润信任高汽车企业网站开发方案
  • 建设银行上海分行招聘网站微信上微网站怎么做的
  • 企业门户网站服务器搜索网站怎么做
  • 网站建设与规划实验报告网上接单
  • 武威市建设局网站ftp更换网站
  • 峡江网站建设哈尔滨网站建设好
  • 网站制作应用知识移动互联网50+互联网
  • php网站开发开发实例教程跟网站开发公司签合同主要要点
  • 网站是否降权查询wordpress个人小说主题
  • 长沙网站关键词排名集团公司网站源码php
  • 网站建设情况通报php 实现网站扫码登录
  • 网站带后台网站服务器的DNs怎么查
  • 备份wordpress网站青岛开发区网站制作
  • 静态网站源文件下载上海网页设计服务
  • 郑州搭建网站校园无线网络建设方案
  • 网站建设推介会发言稿长沙网站seo厂家
  • 东莞废水处理 东莞网站建设wordpress主题教程视频
  • 专业电子网站建设wordpress插件音乐播放器
  • 做网站优化有必要学校网站建设方案模板
  • 外贸建站如何推广百度手机助手app下载安装
  • 温州网站建设外包网站开发设计的源码
  • 汕头建站价格宝塔批量建站工具
  • 专业网站推广引流互联网站开发
  • 赣榆做网站游戏服务端源码
  • 营销网站的建设流程h5网站建设代理
  • 开发网站开源免费网站建设费 无形资产