javascript - How to separate dynamic and static back-ends
Now there is a project that wants to develop the front-end and back-end separately. What should I do? Mainly what should be done in data communication and rights management.
Reply content:
Now there is a project that wants to develop the front-end and back-end separately. What should I do? Mainly what should be done in data communication and rights management.
Our ERP system is that the front and back ends are completely separated and have no connection.
The backend uses the modified Laravel framework, which splits the business and routing to separate the complex permission verification on the backend. At the same time, it is still a simple and clear RESTful API to the outside world.
The front end is built using Vue.js Bootstrap.
Additional instructions
Before asking this question, it is necessary for the questioner to have a certain understanding of the HTTP protocol, so that you will not be endlessly entangled in some details. Because essentially the difference between the front and back ends is that one is the requester and the other is the responder.
In the past non-separated development, front-end requests were often made by clicking on a hyperlink, and then the browser took over the follow-up. The browser made its own request to obtain data and refreshed the entire page. After receiving the request, the back-end A complete HTML page is directly output by a back-end script such as PHP.
Later, when Ajax came, events were triggered by Javascript scripts, allowing the browser to controllably issue HTTP requests with limited request headers under specific conditions, and after receiving the response, the script would still handle it by itself instead of the previous The browser directly renders the output, which allows the front end to implement partial refresh function.
After understanding this, it is very simple. The backend only outputs data according to the request. The request contains nothing more than a few key data:
What is the resource requested
Qualification of the requested resource
Request parameters
Requested data body
The requested resource is what we call Request URI. For example, for a request to http://www.a.com/order/128141/detail, the resource is /order/128141/detail
.
Resource qualification conditions are applicable to any request, and are often represented by Query String(查询字符串)
, such as http://www.a.com/shop/goods?name=test&sort=time&page=2
, where the part after ?
is the query string, just as the meaning of the word 查询
is used to Limited resource result set.
Query strings are often misunderstood by newcomers as being used to transfer data, and both $_GET and $_POST are used as ways to transfer and obtain data. If this awareness has existed for a long time, PHP deserves to be criticized. Look down on it. .
Request parameters are some things in the Header part. Common ones are similar to Cookie
, Accept
, etc., which are used to tell the server some basic information about the requester. The back-end permission verification is basically Implemented using this part, it is not necessary to use Cookie as the only channel to implement Session. You can completely implement your own set of authentication and session processes in accordance with the specifications .
The last one is the data body of the request. For GET
, DELETE
requests, there is no data to be passed (GET is to get, DELETE
is to delete, how to pass the data?), but for POST
, PUT
Then you need to pass data through the request body, such as form submission or file upload.
The backend can use the large and small data in the request to build a well-defined filtering process (implemented by middleware). With reasonable routing modules and controllers, it is easy to achieve the separation of the backend.
There are many front-end methods. I will take ajax as the simplest and most practical one. Whether you use a front-end framework or not, ajax will not change. It is a request channel.
Having said all of the above, you must understand that to separate, you must clarify responsibilities. The front end is to obtain data, so just use ajax to send a request to obtain the data. You can render the data wherever you get it. As for the data, as long as the structure is correct, it will be considered correct.
// I wrote a lot, I will add more when I have time
You can choose a bootstrap template for the front end and use it with vuejs. The backend uses the yii2 framework in php to design a restful interface. yii2 comes with its own rbac module, which is very convenient. The front and backend use ajax to transmit data.
The front-end is developed purely with html-frameset, and interacts with the back-end through ajax. The back-end has a filter to verify the session.
The front-end uses Bootstrap/Google MDL Angular2 JS, and the back-end uses Laravel. Installing the RBAC extension (portal) can separate dynamic and static. Laravel's REST-style routing is still very useful.
Answer the question first: session verification RESTFUL
Recommended:
Front end: vuejs bootstrap
Backend: Springboot

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Java 8 introduces the Stream API, providing a powerful and expressive way to process data collections. However, a common question when using Stream is: How to break or return from a forEach operation? Traditional loops allow for early interruption or return, but Stream's forEach method does not directly support this method. This article will explain the reasons and explore alternative methods for implementing premature termination in Stream processing systems. Further reading: Java Stream API improvements Understand Stream forEach The forEach method is a terminal operation that performs one operation on each element in the Stream. Its design intention is

Java Made Simple: A Beginner's Guide to Programming Power Introduction Java is a powerful programming language used in everything from mobile applications to enterprise-level systems. For beginners, Java's syntax is simple and easy to understand, making it an ideal choice for learning programming. Basic Syntax Java uses a class-based object-oriented programming paradigm. Classes are templates that organize related data and behavior together. Here is a simple Java class example: publicclassPerson{privateStringname;privateintage;

Java is a popular programming language that can be learned by both beginners and experienced developers. This tutorial starts with basic concepts and progresses through advanced topics. After installing the Java Development Kit, you can practice programming by creating a simple "Hello, World!" program. After you understand the code, use the command prompt to compile and run the program, and "Hello, World!" will be output on the console. Learning Java starts your programming journey, and as your mastery deepens, you can create more complex applications.

Capsules are three-dimensional geometric figures, composed of a cylinder and a hemisphere at both ends. The volume of the capsule can be calculated by adding the volume of the cylinder and the volume of the hemisphere at both ends. This tutorial will discuss how to calculate the volume of a given capsule in Java using different methods. Capsule volume formula The formula for capsule volume is as follows: Capsule volume = Cylindrical volume Volume Two hemisphere volume in, r: The radius of the hemisphere. h: The height of the cylinder (excluding the hemisphere). Example 1 enter Radius = 5 units Height = 10 units Output Volume = 1570.8 cubic units explain Calculate volume using formula: Volume = π × r2 × h (4
