欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot整合Mybatis-Plus實(shí)現(xiàn)微信注冊(cè)登錄的示例代碼

 更新時(shí)間:2024年02月28日 15:39:35   作者:Blet-  
微信是不可或缺的通訊工具,本文主要介紹了SpringBoot整合Mybatis-Plus實(shí)現(xiàn)微信注冊(cè)登錄的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的可以了解一下

前言:

隨著互聯(lián)網(wǎng)和移動(dòng)互聯(lián)網(wǎng)的快速發(fā)展,微信已成為人們?nèi)粘I詈凸ぷ髦胁豢扇鄙俚耐ㄓ嵐ぞ咧弧T谶@個(gè)背景下,將微信用戶注冊(cè)和登錄功能整合到自己應(yīng)用中,成為了越來越多開發(fā)者所關(guān)注的問題。本文將詳細(xì)介紹如何使用SpringBoot和Mybatis-Plus快速搭建微信注冊(cè)、登錄功能,并通過Vue實(shí)現(xiàn)優(yōu)美的前端頁(yè)面。

一、技術(shù)棧選擇

在開始開發(fā)之前,我們需要選擇一組適合的技術(shù)棧。本文中,我們將使用以下主要技術(shù):

  • SpringBoot:為開發(fā)提供快速、簡(jiǎn)單的企業(yè)級(jí)應(yīng)用程序開發(fā)框架。
  • Mybatis-Plus:一種基于Mybatis的增強(qiáng)工具,通過自動(dòng)生成代碼可極大地提高開發(fā)效率。
  • Vue:一個(gè)輕量級(jí)的JavaScript框架,用于開發(fā)單頁(yè)應(yīng)用程序。

二、環(huán)境搭建

1. 數(shù)據(jù)庫(kù)設(shè)計(jì)

我們首先需要?jiǎng)?chuàng)建一個(gè)數(shù)據(jù)庫(kù),用來存儲(chǔ)用戶信息和登錄憑證。假設(shè)我們要存儲(chǔ)用戶的微信OpenID和登錄憑證,可以按照以下步驟創(chuàng)建名為 “wechat_login” 的數(shù)據(jù)庫(kù)

CREATE DATABASE wechat_login;

USE wechat_login;

-- 創(chuàng)建用戶表
CREATE TABLE `user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `open_id` varchar(50) NOT NULL COMMENT '微信OpenID',
  `credential` varchar(50) NOT NULL COMMENT '登錄憑證',
  `create_time` datetime NOT NULL COMMENT '創(chuàng)建時(shí)間',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用戶表';

2. SpringBoot項(xiàng)目創(chuàng)建

我們使用Spring Initializr創(chuàng)建一個(gè)SpringBoot項(xiàng)目,并引入相關(guān)依賴:Mybatis-Plus、MySQL驅(qū)動(dòng)和Swagger2。可以將以下依賴項(xiàng)添加到pom.xml文件中:

<dependencies>
    <!--Mybatis-Plus-->
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-boot-starter</artifactId>
        <version>3.4.2</version>
    </dependency>
    <!-- MySQL驅(qū)動(dòng)程序 -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.20</version>
    </dependency>
    <!--Swagger2-->
    <dependency>
        <groupId>io.springfox</groupId>
        <artifactId>springfox-swagger2</artifactId>
        <version>3.0.0</version>
    </dependency>
    <dependency>
        <groupId>io.springfox</groupId>
        <artifactId>springfox-swagger-ui</artifactId>
        <version>3.0.0</version>
    </dependency>
</dependencies>

創(chuàng)建好SpringBoot項(xiàng)目后,我們需要在application.properties文件中添加數(shù)據(jù)庫(kù)連接信息

# 數(shù)據(jù)庫(kù)連接信息
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/wechat_login?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai
spring.datasource.username=root
spring.datasource.password=root

# Mybatis配置
# 配置Mapper的掃描路徑
mybatis-plus.mapper-locations=classpath:mapper/*.xml
# 開啟實(shí)體注解掃描
mybatis-plus.typeAliasesPackage=com.springboot.mybatismplus.entity
# 開啟邏輯刪除
mybatis-plus.global-config.db-config.logic-delete-value=1
mybatis-plus.global-config.db-config.logic-not-delete-value=0
mybatis-plus.global-config.refresh=true

# swagger-ui配置
# 訪問路徑:http://localhost:8080/swagger-ui.html
swagger.title=Spring Boot Example
swagger.description=Spring Boot Example API Document
swagger.version=1.0.0
swagger.controller.package=com.springboot.mybatismplus.controller

3. Entity設(shè)計(jì)

在設(shè)計(jì)Entity時(shí),我們需要根據(jù)用戶表的定義,創(chuàng)建一個(gè)對(duì)應(yīng)的Java實(shí)體類。以下是一個(gè)簡(jiǎn)單的UserEntity示例:

public class UserEntity implements Serializable {

    private static final long serialVersionUID = 1L;

    @TableId(type= IdType.AUTO)
    private Long id;

    @TableField("open_id")
    private String openId;

    private String credential;

    @TableField("create_time")
    private LocalDateTime createTime;

    // getters and setters
}

這里我們使用了Mybatis-Plus提供的注解功能,將實(shí)體類的屬性和數(shù)據(jù)庫(kù)表的字段名進(jìn)行了映射,并使用了Lombok插件自動(dòng)生成了getter和setter方法。

4. Mapper設(shè)計(jì)

在設(shè)計(jì)Mapper時(shí),我們可以使用Mybatis-Plus提供的BaseMapper抽象類,并繼承它,實(shí)現(xiàn)對(duì)應(yīng)的方法。以下是一個(gè)簡(jiǎn)單的UserMapper示例:

public interface UserMapper extends BaseMapper<UserEntity> {

    /**
     * 根據(jù)OpenID查詢用戶信息
     */
    UserEntity selectByOpenId(String openId);

}

我們可以看到,我們只需要將UserEntity作為泛型傳入BaseMapper中,就可以輕松地實(shí)現(xiàn)CURD操作。

5. Service設(shè)計(jì)

在設(shè)計(jì)Service時(shí),我們需要注入Mapper,實(shí)現(xiàn)相應(yīng)的業(yè)務(wù)方法。以下是一個(gè)簡(jiǎn)單的UserService示例:

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, UserEntity> implements UserService {

    @Autowired
    private UserMapper userMapper;

    /**
     * 根據(jù)OpenID查詢用戶信息
     */
    @Override
    public UserEntity selectByOpenId(String openId) {
        return userMapper.selectByOpenId(openId);
    }

}

這里我們使用了Spring框架的注解功能注入了UserMapper,并實(shí)現(xiàn)了selectByOpenId方法。

6. Controller設(shè)計(jì)

在設(shè)計(jì)Controller時(shí),我們需要使用@RestController注解將Java類標(biāo)記為控制器,使用@RequestMapping注解處理HTTP請(qǐng)求,并注入Service實(shí)現(xiàn)相應(yīng)的業(yè)務(wù)邏輯。以下是一個(gè)簡(jiǎn)單的UserController示例:

@RestController
@RequestMapping("/user")
@Api(tags = "用戶管理")
public class UserController {

    @Autowired
    private UserService userService;

    /**
     * 用戶登錄接口
     */
    @PostMapping("/login")
    @ApiOperation(value = "用戶登錄", notes = "首次登錄需使用微信注冊(cè)")
    public Result<UserEntity> login(@RequestParam("openId") String openId, @RequestParam("credential") String credential) {
        UserEntity user = userService.selectByOpenId(openId);
        if (user == null) {
            throw new BusinessException("該用戶不存在");
        }
        if (!user.getCredential().equals(credential)) {
            throw new BusinessException("登錄憑證不正確");
        }
        return Result.success(user);
    }

    /**
     * 用戶注冊(cè)接口
     */
    @PostMapping("/register")
    @ApiOperation(value = "用戶注冊(cè)", notes = "注冊(cè)成功后可使用微信直接登錄")
    public Result<UserEntity> register(@RequestBody UserEntity user) {
        boolean result = userService.save(user);
        if (!result) {
            throw new BusinessException("注冊(cè)失敗,請(qǐng)檢查輸入?yún)?shù)");
        }
        return Result.success(user);
    }

}

我們使用了@RestController注解標(biāo)記這個(gè)Java類為Spring MVC控制器,并將@RequestMapping的value映射到 “/user”。在login和register方法中,我們分別處理了用戶登錄和注冊(cè)請(qǐng)求,并調(diào)用Service實(shí)現(xiàn)相應(yīng)的業(yè)務(wù)邏輯。

三、前端頁(yè)面設(shè)計(jì)

在本項(xiàng)目中,我們使用Vue框架和Vant組件庫(kù)來實(shí)現(xiàn)前端頁(yè)面設(shè)計(jì)。主要包括:

  • 用戶登錄頁(yè)面
  • 用戶注冊(cè)頁(yè)面

1. 用戶登錄頁(yè)面

我們?cè)谟脩舻卿涰?yè)面上使用了Vant的輸入框組件,并添加了驗(yàn)證邏輯。以下是簡(jiǎn)單的登錄頁(yè)面示例:

<template>
  <div class="login-page">
    <van-field v-model="openId" label="微信OpenID" placeholder="請(qǐng)輸入微信OpenID" />

    <van-field type="password" v-model="credential" label="登錄憑證" placeholder="請(qǐng)輸入登錄憑證" />

    <van-button type="primary" :disabled="!openId || !credential" class="login-button" @click="login">登錄</van-button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      openId: '',
      credential: ''
    };
  },
  methods: {
    login() {
      if (!this.openId || !this.credential) {
        this.$toast('請(qǐng)?zhí)顚懲暾卿浶畔?);
        return;
      }
      // TODO: 調(diào)用后端接口處理登錄邏輯
    }
  }
};
</script>

在登錄按鈕的點(diǎn)擊事件中,我們將用戶輸入的openId和credential傳遞到后端接口中進(jìn)行驗(yàn)證。登錄成功后可以跳轉(zhuǎn)到其他頁(yè)面,或者直接顯示用戶信息。

2. 用戶注冊(cè)頁(yè)面

在用戶注冊(cè)頁(yè)面上,我們使用了Vant的表單組件和按鈕組件,并添加了表單驗(yàn)證。以下是簡(jiǎn)單的注冊(cè)頁(yè)面示例:

<template>
  <div class="register-page">
    <van-form
      ref="form"
      label-position="top"
      :rules="rules"
    >
      <van-field v-model="openId" label="微信OpenID" placeholder="請(qǐng)輸入微信OpenID" />

      <van-field type="password" v-model="credential" label="登錄憑證" placeholder="請(qǐng)輸入登錄憑證" />

      <van-button type="primary" :disabled="!isFormValid" class="register-button" @click="register">注冊(cè)</van-button>
    </van-form>
  </div>
</template>

<script>
export default {
  data() {
    return {
      openId: '',
      credential: '',
      rules: {
        openId: [
          { required: true, message: '請(qǐng)輸入微信OpenID', trigger: 'blur' }
        ],
        credential: [
          { required: true, message: '請(qǐng)輸入登錄憑證', trigger: 'blur' },
          { min: 6, max: 20, message: '登錄憑證長(zhǎng)度為6到20個(gè)字符', trigger: 'blur' }
        ]
      }
    };
  },
  computed: {
    isFormValid() {
      return this.$refs.form.validate();
    }
  },
  methods: {
    register() {
      if (!this.isFormValid) {
        this.$toast('請(qǐng)?zhí)顚懲暾?cè)信息');
        return;
      }
      // TODO: 調(diào)用后端接口進(jìn)行注冊(cè)操作
    }
  }
};
</script>

在注冊(cè)按鈕的點(diǎn)擊事件中,我們將表單數(shù)據(jù)傳遞到后端接口中進(jìn)行處理。如果注冊(cè)成功,可以跳轉(zhuǎn)到登錄頁(yè)面。

四、項(xiàng)目總結(jié)

本文中,我們使用SpringBoot和Mybatis-Plus快速搭建了一個(gè)微信注冊(cè)、登錄功能,并通過Vue實(shí)現(xiàn)了簡(jiǎn)潔、優(yōu)美的前端頁(yè)面。這個(gè)項(xiàng)目可以作為入門級(jí)別的示例,幫助我們快速理解如何使用這些工具和框架來實(shí)現(xiàn)功能。

到此這篇關(guān)于SpringBoot整合Mybatis-Plus實(shí)現(xiàn)微信注冊(cè)登錄的示例代碼的文章就介紹到這了,更多相關(guān)SpringBoot MybatisPlus微信注冊(cè)登錄內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • springboot自動(dòng)配置原理以及spring.factories文件的作用詳解

    springboot自動(dòng)配置原理以及spring.factories文件的作用詳解

    這篇文章主要介紹了springboot自動(dòng)配置原理以及spring.factories文件的作用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • springmvc流程圖以及配置解析

    springmvc流程圖以及配置解析

    這篇文章主要介紹了springmvc流程圖以及配置解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • JVM內(nèi)存管理之JAVA語言的內(nèi)存管理詳解

    JVM內(nèi)存管理之JAVA語言的內(nèi)存管理詳解

    下面小編就為大家?guī)硪黄狫VM內(nèi)存管理之JAVA語言的內(nèi)存管理詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-08-08
  • Spring框架十一種常見異常的解決方法匯總

    Spring框架十一種常見異常的解決方法匯總

    今天小編就為大家分享一篇關(guān)于Spring框架十一種常見異常的解決方法匯總,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • elasticsearch集群cluster?discovery可配式模塊示例分析

    elasticsearch集群cluster?discovery可配式模塊示例分析

    這篇文章主要為大家介紹了elasticsearch集群cluster?discovery可配式模塊示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • Spring中Bean的作用域與生命周期詳解

    Spring中Bean的作用域與生命周期詳解

    這篇文章主要給大家介紹了Spring中Bean的生命周期和作用域及實(shí)現(xiàn)方式的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧
    2021-08-08
  • JavaWeb使用Cookie模擬實(shí)現(xiàn)自動(dòng)登錄功能(不需用戶名和密碼)

    JavaWeb使用Cookie模擬實(shí)現(xiàn)自動(dòng)登錄功能(不需用戶名和密碼)

    不需要填寫用戶名和密碼自動(dòng)登錄系統(tǒng),其實(shí)現(xiàn)思路使用cookie模擬瀏覽器自動(dòng)登錄,對(duì)cookie實(shí)現(xiàn)自動(dòng)登錄功能感興趣的朋友一起學(xué)習(xí)吧
    2016-08-08
  • SpringBoot在 POM 中引入本地 JAR 包的方法

    SpringBoot在 POM 中引入本地 JAR 包的方法

    在開發(fā) Spring Boot 應(yīng)用程序時(shí),您可能需要使用本地 JAR 包來添加自定義庫(kù)或功能,本文將介紹在 Spring Boot 項(xiàng)目的 POM 文件中如何引入本地 JAR 包,感興趣的朋友跟隨小編一起看看吧
    2023-08-08
  • 如何徹底刪除SVN中的文件和文件夾(附恢復(fù)方法)

    如何徹底刪除SVN中的文件和文件夾(附恢復(fù)方法)

    在SVN中如果刪除某個(gè)文件或文件夾也可以在歷史記錄中進(jìn)行找回,有的時(shí)候需要徹底刪除某些文件,即不希望通過歷史記錄進(jìn)行恢復(fù),需要在服務(wù)器上對(duì)SVN的數(shù)據(jù)進(jìn)行重新整理
    2014-08-08
  • 如何基于java隨機(jī)獲取不重復(fù)數(shù)值

    如何基于java隨機(jī)獲取不重復(fù)數(shù)值

    這篇文章主要介紹了如何基于java隨機(jī)獲取不重復(fù)數(shù)值,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09

最新評(píng)論