백엔드 개발 Golang Go 언어와 Vue.js를 사용하여 사용자 관리 구성 요소를 구축하는 방법

Go 언어와 Vue.js를 사용하여 사용자 관리 구성 요소를 구축하는 방법

Jun 17, 2023 am 11:18 AM
언어로 가다 vuejs 사용자 관리 구성 요소

인터넷 시대의 지속적인 발전으로 비즈니스 운영 및 관리에 소프트웨어를 사용하는 기업이 점점 더 많아지고 있습니다. 뛰어난 사용자 관리 구성 요소를 갖춘 소프트웨어는 기업이 사용자 정보를 더 잘 관리 및 유지하고 더 나은 사용자 경험을 제공하는 데 도움이 될 수 있습니다. 이 기사에서는 Go 언어와 Vue.js를 사용하여 사용자 관리 구성 요소를 구축하는 방법을 소개하여 독자가 효율적이고 사용하기 쉬운 사용자 관리 도구를 만드는 데 도움을 줍니다.

1. 사용자 관리 API 디자인

우선 비즈니스 요구에 맞는 사용자 관리 API 인터페이스를 디자인해야 합니다. 이 예에서는 다음과 같이 API 인터페이스를 정의합니다.

사용자 만들기:

POST /api/users

사용자 목록 쿼리:

GET /api/users

단일 사용자 쿼리:

GET /api/users /{id}

사용자 업데이트:

PUT /api/users/{id}

사용자 삭제:

DELETE /api/users/{id}

인증 부분을 미들웨어에 넣고 JWT를 사용하여 신원 인증을 수행합니다. 예:

middleware/auth.go

func AuthMiddleware(next http.Handler) http.Handler {
  return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
    // verify token
    tokenStr := r.Header.Get("Authorization")
    if tokenStr == "" {
        http.Error(w, "Authorization required", http.StatusUnauthorized)
        return
    }

    token, err := jwt.Parse(tokenStr, func(token *jwt.Token) (interface{}, error) {
        return []byte("Secret"), nil
    })

    if err != nil || !token.Valid {
        http.Error(w, "Invalid authorization token", http.StatusUnauthorized)
    }

    // Call the next handler, which can be another middleware in the chain, or the final handler.
    next.ServeHTTP(w, r)
})
}
로그인 후 복사

2. 백엔드 서비스 작성

API 설계를 완료한 후 백엔드 서비스를 작성하고 해당 API 구현을 제공해야 합니다. 상호 작용.

Go 언어를 사용하여 백엔드 서비스를 작성하려면 Gin, Echo 또는 Goji와 같은 인기 있는 웹 프레임워크를 사용할 수 있습니다. 여기서는 Gin 프레임워크를 예로 사용합니다. 샘플 코드는 다음과 같습니다.

backend/main.go

func main() {
router := gin.Default()

// Register middleware
router.Use(middleware.AuthMiddleware)

// Create user
router.POST("/api/users", CreateUser)

// Query user list
router.GET("/api/users", GetUserList)

// Query single user
router.GET("/api/users/:id", GetUser)

// Update user
router.PUT("/api/users/:id", UpdateUser)

// Delete user
router.DELETE("/api/users/:id", DeleteUser)

// Start server
router.Run(":8080")
}
로그인 후 복사

위 코드에서는 AuthMiddleware를 사용하여 라우팅 요청을 인증한 후 router.POST, router.GET을 사용합니다. , router.PUT 및 router.DELETE 이 메소드는 API 경로를 등록하고 구현 함수 CreateUser, GetUserList, GetUser, UpdateUser 및 DeleteUser를 연결합니다.

3. 프런트엔드 인터페이스 구성요소 작성

백엔드 서비스를 사용하면 프런트엔드 인터페이스 구성요소를 작성할 수 있습니다. Vue.js를 사용하여 프런트엔드 구성 요소를 빌드하면 webpack 또는 vue-cli와 같은 일반적인 빌드 도구를 사용할 수 있습니다. 여기서는 vue-cli를 사용하며 샘플 코드는 다음과 같습니다.

frontend/src/App.vue

<template>
    <div>
        <!-- User list component -->
        <user-list :users="users" @update="handleUpdate" @delete="handleDelete" />

        <!-- User form component -->
        <user-form v-if="showForm" :user="user" @submit="handleSubmit" @cancel="handleCancel" />
    
        <!-- Button to show user form component -->
        <el-button type="primary" @click="showForm = true">Create User</el-button>
    </div>
</template>

<script>
    import UserList from './components/UserList.vue'
    import UserForm from './components/UserForm.vue'
    import axios from 'axios'
    
    export default {
        components: {
            UserList,
            UserForm
        },

        data() {
            return {
                users: [],
                user: {},
                showForm: false
            }
        },

        methods: {
            // Get user list from backend API
            async loadUsers() {
                const response = await axios.get('/api/users')
                this.users = response.data
            },

            // Handle user update
            handleUpdate(user) {
                this.user = user
                this.showForm = true
            },

            // Handle user delete
            async handleDelete(userId) {
                await axios.delete(`/api/users/${userId}`)
                await this.loadUsers()
            },

            // Handle form submit
            async handleSubmit(user) {
                if (user.id) {
                    await axios.put(`/api/users/${user.id}`, user)
                } else {
                    await axios.post('/api/users', user)
                }
                
                this.showForm = false
                await this.loadUsers()
            },

            // Handle cancel button click
            handleCancel() {
                this.showForm = false
            }
        },

        created() {
            this.loadUsers()
        }
    }
</script>
로그인 후 복사

위 코드에서 App 구성 요소는 UserList, UserForm, axios 라이브러리 및 백엔드 API를 사용하여 서로 상호 작용합니다. 기능을 구현합니다.

UserList 컴포넌트는 사용자 속성을 테이블 렌더링 데이터로 받는 테이블 컴포넌트입니다.

UserForm组件用于创建和编辑userdata。如果用户信息为新用户数据, updateUser则设置为空对象,否则它设置为要编辑的用户。

async函数 handleSubmit处理与API的交互。如果用户存在,将其作为HTTP PUT请求发出,否则将其记录下来并存储到backend中。
로그인 후 복사

이 함수의 데이터가 변경되는 모든 작업은 UI 다시 로드를 트리거합니다.

이 시점에서 Go 언어와 Vue.js를 사용하여 사용자 관리 구성 요소 개발을 완료했습니다. 개발자는 이를 더욱 개선하고 개선할 수 있으며 실제 비즈니스 요구에 따라 적절하게 수정 및 확장하고 자신의 요구에 맞는 사용자 관리 도구를 만들 수 있습니다.

요약

이 글에서는 Go 언어와 Vue.js를 사용하여 사용자 관리 구성 요소를 구축하는 방법을 소개합니다. API 설계 및 백엔드 서비스 구현을 통해 사용자 정보에 대한 CRUD 연산을 구현하고, Vue.js를 통해 사용자 관리 인터페이스 구성요소를 구현하여 사용자 관리를 보다 편리하고 효율적으로 만듭니다. 동시에 이 기사에서는 독자가 이 분야의 개발 작업을 보다 쉽게 ​​시작할 수 있도록 샘플 코드와 개발 단계를 제공합니다.

위 내용은 Go 언어와 Vue.js를 사용하여 사용자 관리 구성 요소를 구축하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Redis Stream을 사용하여 GO Language에서 메시지 대기열을 구현할 때 User_ID 유형 변환 문제를 해결하는 방법은 무엇입니까? Redis Stream을 사용하여 GO Language에서 메시지 대기열을 구현할 때 User_ID 유형 변환 문제를 해결하는 방법은 무엇입니까? Apr 02, 2025 pm 04:54 PM

Go Language에서 메시지 대기열을 구현하기 위해 Redisstream을 사용하는 문제는 Go Language와 Redis를 사용하는 것입니다 ...

골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? 골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? Apr 02, 2025 pm 05:09 PM

골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? Go Language 개발을 위해 Goland를 사용할 때 많은 개발자가 사용자 정의 구조 태그를 만날 것입니다 ...

GO에서 플로팅 포인트 번호 작업에 어떤 라이브러리가 사용됩니까? GO에서 플로팅 포인트 번호 작업에 어떤 라이브러리가 사용됩니까? Apr 02, 2025 pm 02:06 PM

Go Language의 부동 소수점 번호 작동에 사용되는 라이브러리는 정확도를 보장하는 방법을 소개합니다.

Go 's Crawler Colly의 큐 스레드의 문제는 무엇입니까? Go 's Crawler Colly의 큐 스레드의 문제는 무엇입니까? Apr 02, 2025 pm 02:09 PM

Go Crawler Colly의 대기열 스레딩 문제는 Colly Crawler 라이브러리를 GO 언어로 사용하는 문제를 탐구합니다. � ...

이동 중에 왜 println 및 string () 함수로 문자열이 다른 효과를 갖는 이유는 무엇입니까? 이동 중에 왜 println 및 string () 함수로 문자열이 다른 효과를 갖는 이유는 무엇입니까? Apr 02, 2025 pm 02:03 PM

Go Language의 문자열 인쇄의 차이 : println 및 String () 함수 사용 효과의 차이가 진행 중입니다 ...

GO 언어에서 'var'와 'type` 키워드 정의 구조의 차이점은 무엇입니까? GO 언어에서 'var'와 'type` 키워드 정의 구조의 차이점은 무엇입니까? Apr 02, 2025 pm 12:57 PM

GO 언어에서 구조를 정의하는 두 가지 방법 : VAR과 유형 키워드의 차이. 구조를 정의 할 때 Go Language는 종종 두 가지 다른 글쓰기 방법을 본다 : 첫째 ...

sql.open을 사용할 때 DSN이 비어있을 때 오류가 발생하지 않습니까? sql.open을 사용할 때 DSN이 비어있을 때 오류가 발생하지 않습니까? Apr 02, 2025 pm 12:54 PM

sql.open을 사용할 때 DSN에 오류가 발생하지 않는 이유는 무엇입니까? Go Language, SQL.open ...

GO의 어떤 라이브러리가 대기업에서 개발하거나 잘 알려진 오픈 소스 프로젝트에서 제공합니까? GO의 어떤 라이브러리가 대기업에서 개발하거나 잘 알려진 오픈 소스 프로젝트에서 제공합니까? Apr 02, 2025 pm 04:12 PM

GO의 어떤 라이브러리가 대기업이나 잘 알려진 오픈 소스 프로젝트에서 개발 했습니까? GO에 프로그래밍 할 때 개발자는 종종 몇 가지 일반적인 요구를 만납니다.

See all articles