实战《天天影视》前后端+管理后台

前言

本人比较喜欢看视频,但都是需要VIP所以开发个APP能免费看各大平台的视频。本平台仅做学习使用

技术栈

APP => flutter
后台管理=>vue3+ts
后端=>nestjs+typeorm+mysql

1、APP

2、后台管理系统(Admin)

3、后端

3-1、项目创建

npm i -g @nestjs/cli 安装nest脚手架
nest new ttvideo_serve

因为考虑APP和后台公用一个数据库,所以我们使用 nest的monorepo模式

在nest项目文件中输入命令
nest generate app server

并且在项目文件中admin=>main.ts设置全局跟路由

app.setGlobalPrefix("/server");

3-2 创建数据库模块

nest g lib db
询问是否使用@apps 我们输入@libs
然后在apps会自动创建libs文件夹
npm install --save @nestjs/typeorm typeorm mysql

3-2-1 使用ConfigModel配置公共配置文件

npm i --save @nestjs/config cross-env
  • 1、我们在项目根目录中创建文件夹config&创建database.config.ts文件
  • 2、在package.json文件中 start&bulid命令加上cross-env NODE_ENV=developmentcross-env NODE_ENV=production
  • 3、在项目根目录创建文件.development.env.production.env
// .development.env
SERVER_PORT=9000 //这个是server端的启动端口
THUA_API_PORT=9001 // 这个是app接口端的启动端口

DATABASE_USER=root // 这个是数据库登陆name
DATABASE_PASSWORD=****// 这个是数据库登陆密码
DATABASE_PORT=3306// 这个是数据库登陆端口
DATABASE_HOST=******// 这个是数据库登陆地址
DATABASE_BASENAME=ttvideo// 这个是数据库名称

上述配置请根据实际的需求进行调整,你可以配置开发/线上不同的配置

// database.config.ts
import { join } from 'path';
export default () => ({
    // 这里需要额外增加database标识符,因在configService中不好拿
    database: {
        type: 'mysql',
        host: process.env.DATABASE_HOST,
        port: process.env.DATABASE_PORT,
        username: process.env.DATABASE_USER,
        password: process.env.DATABASE_PASSWORD,
        database: process.env.DATABASE_BASENAME,
        entities: [join(__dirname, '../', '**/**.entity{.ts,.js}')],
        synchronize: true
    }
})

这里需要注意的是:entities的地址可能会出错,这里可以尝试修改根目录nest-cli.json

// nest-cli.json
"compilerOptions": {
    "webpack": false, //修改这里 原配置这里是true
    "tsConfigPath": "apps/thua-server/tsconfig.app.json" // 这里不用修改 
  },

3-2-2 使用配置文件配置数据库

如果你根据上述步骤来,我们是会有libs/db文件夹的

import { Module } from '@nestjs/common';
import { ConfigModule, ConfigService } from '@nestjs/config';
import { TypeOrmModule } from '@nestjs/typeorm';
import dataBaseConfig from 'config/database.config';
import { DbService } from './db.service';
// 根据你的环境推导env文件
const getEnvPath = () => {
  return `.${process.env.NODE_ENV}.env`
}

@Module({
  imports: [
    ConfigModule.forRoot({ envFilePath: getEnvPath(), load: [dataBaseConfig], isGlobal: true }),
    TypeOrmModule.forRootAsync({
      useFactory: (config: ConfigService) => {
      // 这里的database 就是刚刚dataBaseConfig为什么要加标识符
        console.log(config.get('database'));
        
        return config.get('database')
      },
      inject: [ConfigService]
    })
  ],
  providers: [DbService],
  exports: [DbService],
})
export class DbModule { }

3-2-3 创建实体文件

libs/db/src下创建entitys文件夹来创建实体
根据你实际的需求创建实体

  • userAdmin(后台用户实体)
  • video(视频实体)
  • Collection(视频单集实体)
  • PlayTimes(收集用户播放视频的实体)
  • Analysis(视频解析实体)
  • Bullet(弹幕实体)

注意这些实体文件会根据你具体的配置写入数据库中的表字段等
具体的配置你可以去typeorm文档参考

3-3用户身份鉴权(登录注册)

具体操作可以按照该文章进行操作newst鉴权,不过需要特别注意的是:UsersController需要在users.module.ts删除

//users.module.ts
import { UserAdmin } from '@libs/db/models/userAdmin.entity';
import { Module } from '@nestjs/common';
import { TypeOrmModule } from '@nestjs/typeorm';
import { UsersController } from './users.controller';
import { UsersService } from './users.service';

@Module({
  imports: [TypeOrmModule.forFeature([UserAdmin])],
  //controllers: [UsersController],
  providers: [UsersService],
  exports: [UsersService]
})
export class UsersModule { }

需要在总模块//app.models.ts中导入

//需要在总模块//app.models.ts中导入
import { DbModule } from '@libs/db';
import { Module } from '@nestjs/common';
import { UsersModule } from './users/users.module';
import { AuthModule } from './auth/auth.module';
import { UsersController } from './users/users.controller';

@Module({
  imports: [DbModule, UsersModule, AuthModule],
  controllers: [UsersController],
  providers: [],
})
export class AdminModule { }

3-4用户传参参数校验

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容