Steps to package and deploy the Vue project to the Apache server

Steps to package and deploy the Vue project to the Apache server

In the development environment, the vue project is run through the npm run dev command, which is based on building an express server locally.

But this is not the case on the server. The entire project must be packaged using the npm run build command. After packaging, a dist folder will be generated in the project directory with the following contents:

Then just drop these files into a folder on the server. My folder name is ibms

Problems encountered:

1. Go directly to http://www.xxx.com/ibms/, you will find that the webpage is a white screen with nothing on it. This is quite strange. In fact, it is because there is a problem with the resource loading path!

Solution:

Modify the webpack configuration in build in index.js in config:

assetsPublicPath: '/ibms/'

Add the following to the index.js configuration in the router:

export default new Router({
 mode: 'history',
 scrollBehavior: () => ({ y: 0 }),
 base: '/ibms/', // add this line routes: constantRouterMap
})

Next, re-package it with npm run build, and then drop it into the ibms folder on the server. Then the page can be accessed normally.

2. Refresh the current page or use the URL bar to access a sub-page, and you will find that the webpage is 404. This is because the mode of Vue routing is history mode.

Solution:

Just forward all requests to http://www.xxx.com/ibms/index.html

I am using Apache as the web server here. Create a new .htaccess file in the ibms directory (at the same level as index.html) and edit the code.

<IfModule mod_rewrite.c>
  RewriteEngine On
  RewriteBase /ibms/
  RewriteRule ^index\.html$ - [L]
  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteRule . /ibms/index.html [L]
</IfModule>

The purpose of this configuration is to forward all requests that do not exist on the server to index.html. (PS: Remember to restart the Apache server)

This is the end of this article about the steps to package and deploy the Vue project to the Apache server. For more relevant Vue project packaging and deployment to Apache, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • How to automatically deploy vue-cli3 project to the server after packaging
  • Solution to the problem that the backend interface cannot be requested after the Vue3 project is packaged and deployed to the server
  • Configuration method of packaging and deploying Vue project to IIS server
  • Example of how to package and deploy a Vue project to a server
  • How to deploy Vue packaged files to the express server
  • Detailed example of how to package and deploy the Vue project webpack to the server

<<:  mysql delete multi-table connection deletion function

>>:  View the port number occupied by the process in Linux

Recommend

The past two years with user experience

<br />It has been no more than two years sin...

Detailed tutorial on deploying Springboot or Nginx using Kubernetes

1 Introduction After "Maven deploys Springbo...

MySQL FAQ series: When to use temporary tables

Introduction to temporary tables What is a tempor...

Vue implements dynamic circular percentage progress bar

Recently, when developing a small program, I enco...

Solution to Nginx session loss problem

In the path of using nginx as a reverse proxy tom...

mysql5.7.21.zip installation tutorial

The detailed installation process of mysql5.7.21 ...

Reasons why MySQL queries are slow

Table of contents 1. Where is the slowness? 2. Ha...

Example analysis of the impact of MySQL index on sorting

This article uses examples to illustrate the impa...

What are the image file formats and how to choose

1. Which three formats? They are: gif, jpg, and pn...

W3C Tutorial (8): W3C XML Schema Activities

XML Schema is an XML-based alternative to DTD. XM...

MySQL automatically inserts millions of simulated data operation code

I use Navicat as my database tool. Others are sim...

Briefly talk about mysql left join inner join

Preface I have been busy developing a cold chain ...