微信小程序入门05-用户登录注册接口开发

news2024/11/28 0:49:32

用户登录注册,我们先需要开发后端的接口,接口一般需要有入参,然后和数据库进行交互。

1 创建表

我们现在先实现用户的登录及注册,建表语句

create database diancan;
use diancan;
CREATE TABLE users (
  id INT AUTO_INCREMENT PRIMARY KEY,
  username VARCHAR(255) NOT NULL,
  password VARCHAR(255) NOT NULL
);

连上Mysql在命令行里执行脚本
在这里插入图片描述

2 创建后端文件

我们现在要想后端的文件在哪里放,大型项目可能是前后端分离,各有各的目录,因为我们这个是练手项目,就和前端的项目放到一起就可以

vscode里打开我们的前端脚手架项目,在src下边增加一个server文件夹,里边创建一个server.js文件
在这里插入图片描述
输入如下代码

const express = require('express');
const mysql = require('mysql');
const bodyParser = require('body-parser');
const jwt = require('jsonwebtoken');
const app = express();
const port = 3000;

// 连接数据库
const connection = mysql.createConnection({
    host: 'localhost',
    user: 'root',
    password: '111111',
    database: 'diancan'
});

// 解析请求体
app.use(bodyParser.json());

// 注册接口
app.post('/register', (req, res) => {
    const { username, password } = req.body;
    connection.query('INSERT INTO users SET ?', { username, password }, (err, result) => {
        if (err) {
            console.error(err);
            res.status(500).send('Server Error');
        } else {
            res.send('Register Success');
        }
    });
});

// 登录接口
app.post('/login', (req, res) => {
    const { username, password } = req.body;
    connection.query('SELECT * FROM users WHERE username = ?', username, (err, results) => {
        if (err) {
            console.error(err);
            res.status(500).send('Server Error');
        } else if (results.length === 0) {
            res.status(401).send('User Not Found');
        } else if (results[0].password !== password) {
            res.status(401).send('Password Incorrect');
        } else {
            const token = jwt.sign({
                userId: results[0].id,
                username: results[0].username
            }, 'secret');
            res.send({ token });
        }
    });
});

// 权限验证中间件
const authMiddleware = (req, res, next) => {
    const authHeader = req.header('Authorization');
    if (authHeader) {
        const token = authHeader.replace('Bearer ', '');
        try {
            const decoded = jwt.verify(token, 'secret');
            req.userId = decoded.userId;
            req.username = decoded.username;
            next();
        } catch (err) {
            res.status(401).send('Invalid Token');
        }
    } else {
        res.status(401).send('Unauthorized');
    }
};

// 需要授权的接口
app.get('/protected', authMiddleware, (req, res) => {
    res.send(`Hello, ${req.username}`);
});


app.get('/', (req, res) => {
    res.send('Hello, World!');
});

//const userRouter = require('./userRouter');
//app.use('/', userRouter);
// 启动服务器
app.listen(port, () => {
    console.log(`Server listening at http://localhost:${port}`);
});

3 安装依赖

nodejs里凡是使用require语句的,先需要安装npm包,我们一共使用了四个包

const express = require('express');
const mysql = require('mysql');
const bodyParser = require('body-parser');
const jwt = require('jsonwebtoken');

安装方法是进入到项目的根目录
在这里插入图片描述
在根目录打开cmd,然后输入安装命令

npm install express mysql jsonwebtoken --save

在这里插入图片描述
安装完毕后可以去node_modules里查看包是否安装正常
在这里插入图片描述

4 启动服务

进入到我们的server文件夹,打开cmd,使用如下命令启动服务

node server.js

在这里插入图片描述
可以看到服务已经正常启动

5 接口测试

后端接口编写完毕后,我们需要测试一下接口是否正常,可以使用PostMan来测试

从网络上下载并且安装,我们可以先创建一个collection
在这里插入图片描述
collection创建好之后,可以建一个request
在这里插入图片描述
首先测试一下注册接口是否正常,接口地址

http://localhost:3000/register

方法选择POST,然后切换到Body页签,我们按照JSON格式传入参数

{
    "username":"test",
    "password":"111111"
}

填写好之后点击send,如果一切正常会返回注册成功的提示

接着测试一下登录接口

http://localhost:3000/login

在这里插入图片描述
登录接口测试成功后会返回一个token

接着测试权限验证接口

http://localhost:3000/protected

在这里插入图片描述
传入我们的token成功返回结果

6 处理数据库执行不成功的问题

我们如果按照默认配置安装数据库,在首次测试接口的时候后台会报错,主要是因为客户端的密码验证协议和mysql服务端不匹配造成的,需要修改一下

登录到mysql后执行如下命令

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你自己的密码';

然后提交更新

FLUSH PRIVILEGES;

总结

我们本篇主要是解决后端接口的问题,登录注册接口有了之后就需要改造我们的前端,在用户输入用户名密码的时候调用后端接口,验证成功之后进入到我们的系统主页。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/533321.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

软件设计模式介绍与入门

目录 1、软件设计模式的起源 2、什么是设计模式? 2.1、设计模式的设计意图 2.2、设计模式的分类准则 3、为什么要学习设计模式 4、如何学习设计模式 5、最后 VC常用功能开发汇总(专栏文章列表,欢迎订阅,持续更新...&#x…

毕业论文写作技巧

毕业论文的组成部分目录自定义目录 摘要(Abstract)绪论相关工作(Related work)研究方法和结果(Method and Results)研究方法研究结果 结论(Conclusion) 写好一篇论文其实就是讲好一个…

批量查询域名历史软件-域名历史快照查询工具

批量查询域名历史和域名历史快照 批量查询域名历史和域名历史快照是一种可以为您提供有关域名历史信息的工具,以下是该主题的详细介绍。 什么是域名历史? 域名历史记录是指域名在被注册前或过去的使用期间所经历的所有事件的记录。这些事件可能包括域…

SpringBoot拦截器获取Request的body数据

1. 场景 自定义Token后,需要在拦截器中进行token验证。在验证的过程中需要读取HttpServletRequest的body部分数据进行验证。 2. 存在问题 如果直接配置拦截器进行urlPatterns拦截,并进行参数验证,在拦截器中获取request的输入流&#xff0c…

智能防盗防偷门锁语音方案设计

智能锁主要功能 防撬报警功能(非必须,但很实用):防撬报警功能可以说是指纹密码锁功能中对提升家居安全有效的功能之一。当指纹锁受到外暴力破坏时,就会自动发出警报声,提醒小区安保。好一点的甚至可以自动…

【AUTOSAR】【以太网】UdpNM

目录 一、概述 二、限制与约束 三、功能说明 3.1 协调算法 3.2 操作模式 3.2.1 Network Mode 3.2.2 准备总线睡眠模式 3.2.3 准备总线睡眠模式 3.3 网络状态 3.4 初始化 3.5 通信调度 3.5.1 NM消息发送 3.5.2 NM消息接收 3.6 其他功能 3.7 帧结构 四、API接口 …

创新案例 | 肆拾玖坊白酒0到20亿增长是传销还是创新

01.背景介绍 中国证券报引用公开数据显示,2016年,规模以上白酒企业数量为1578家,2021年,这一数字下降到965家。 同时,白酒产能逐年向优势产区集中,头部企业市场占有率不断提高。2021年,茅台、…

性能测试-操作和优化分析

打流工具 iperf 测试吞吐率 服务端:iperf -u -s 客户端:iperf -u -c 1.1.1.1 -b 500M -t 10 测试结果 ------------------------------------------------------------ Client connecting to 192.168.56.106, UDP port 5001 Sending 1470 byte d…

全面监测健康数据,更实用的健康手表,dido E55S Pro上手

关心健康的朋友,一般都特别关注自己的各项健康数据,会通过智能手表之类的工具来持续检测。现在健康类的智能手表选择很多,功能也很丰富,像是我现在用的这款dido E55S Pro,除了常规的心率、血氧之外,还检测心…

vector【实现】:迭代器失效以及非法的间接寻址、深拷贝中的浅拷贝。

vector模拟实现_云的小站的博客-CSDN博客 目录 主题: 迭代器失效 Insert导致的迭代器失效 ereas导致的迭代器失效 非法的间接寻址 深拷贝中的浅拷贝。 主题: 1)迭代器失效 2)非法的间接寻址 3)深拷贝中的浅拷…

2023年最佳SleekFlow最佳替代品

建立更强大的对话关系的最佳平台是什么?现如今,国内客服集成与营销自动化工具也有非常多,比如SaleSmartly(ss客服),被称为SleekFlow的最佳替代品。了解为什么SaleSmartly是SleekFlow的最佳替代品。在这篇文…

BTC交易费激增,LTC活跃地址数飙升! BRC-20爆火背后,区块链网络经历了什么?

BRC-20 代币和 Ordinals 协议的日益普及推动了对比特币区块空间的需求,比特币区块链的费用已飙升至两年来的高点。 BRC-20代币标准在 Ordinals 协议上运行。Ordinals 允许用户通过将对数字艺术的引用写入基于比特币的小型交易中,来将数据嵌入比特币区块…

网站历史快照查询软件-批量网站历史快照查询

批量网站历史快照查询软件 批量网站历史快照查询软件是一种可以让用户在短时间内批量查询多个网站历史快照的工具,可以极大地提高用户的工作效率。批量实时查询是该软件的一大优势,下面主要介绍批量实时查询的优势。 一、高效性 批量实时查询可以同时…

通过2种Python库,教会你如何在自动化测试时加入进度条?

前言 我们在执行自动化测试或者调试时,自动化测试用例数量过多,不清楚目前用例数执行了多少个了,还差多少个执行完成。 这时候就会猜想,如果执行过程中存在进度条,就很清楚的了解到测试用例的执行情况,今…

Cannot read properties of null (reading ‘content‘)报错解决

项目是用vue3webpack,始终启动不成功~ 一、问题报错 二、报错解决尝试总结 (1)首先尝试的是因为我近期在做vite3vue3的需求把node版本升到了 16.17.1 猜测是不是node版本影响的 node版本切了14.15.3,16.17.1,以及很…

【换根DP+容斥】P3047 [USACO12FEB]Nearby Cows G

P3047 [USACO12FEB]Nearby Cows G - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 思路: 做法就是换根 预处理dp[v][j]用普通的树形DP处理即可 注意:一开始预处理的dp[v][j]指的是在v的子树里离v为j的权值和 Code: #in…

JavaWeb12-三大组件之过滤器-Filter

1. 官方文档 文档:java_ee_api_中英文对照版.chm 2. Filter 过滤器说明 2.1 为啥要过滤器-需求示意图 ● 一图胜千言 2.2 过滤器介绍 Filter 过滤器它是 JavaWeb 的三大组件之一(Servlet 程序、Listener 监听器、Filter 过滤器)Filter 过滤器是 JavaEE 的规范…

图像处理:手写实现图像增广算法(旋转、亮度调整、裁剪与拼接)

前言 图像增广算法在计算机视觉领域扮演着至关重要的角色。随着深度学习的兴起,大规模数据集的需求变得更加迫切,而图像增广算法可以通过对原始图像进行一系列变换,扩充数据集,从而提升模型的泛化能力和鲁棒性。 本文将着重介绍…

win10系统cpu版本 Tensorflow2.5.0的安装

文章目录 前言电脑重装系统了,顺便简单记录一下我的tensorflow2.5.0 CPU的安装过程 一、创建一个虚拟环境?二、确定 输入 y三、激活你的环境四、安装tensorflow2.5.0五、利用清华镜像源加速一下,不然等到猴年马月!六,开…

Shape-E:文字到3D的生成模型试用

文章目录 Shape-E:文字到3D的生成模型试用项目介绍项目地址项目使用试用Text to 3DImage to 3D 总结 Shape-E:文字到3D的生成模型试用 项目介绍 Shape-E是一个生成3D模型的工具,可以通过输入文字或者上传图片生成3D模型。该模型的项目地址是…