北大药学院项目总结

2023-10-24 02:10
文章标签 总结 项目 北大 药学院

本文主要是介绍北大药学院项目总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目介绍

本项目是一个北京大学药学院的一个论坛项目,这个项目的主要服务人员是北京大学药学院的师生们,医师们可以在该平台上对一些医术问题、比较有代表意义的问题进行讨论。可以使广大的师生们做深入的交流以及相互的沟通及其合作。这些药师都是有正式工作的,分散在各个科室。该平台是针对药师讨论处方的平台,应对药师过于分散,没有集中交流的平台的问题。北大中暂时没有这样的论坛,所以就产生了这个项目。

我主要负责的模块是后台管理模块及用户接口,不仅仅是单纯的后台接口,也学习了相应的 vue 和 element ui 来实现后台管理的界面

统计分析模块中统计分析有年统、月统和日统,主要统计了帖子和用户的活跃度。在这个过程中,由于数据库中的数据比较多,所以在这里做了年统、月统、日统的冗余设计以及一些统计表,让数据查询过程中的查询效率更快,系统的负载更高一些。同时统计了每天的帖子数和历史的帖子数、点赞数、评论数,还有一些统计报表和一些发帖的排名,根据我们的点赞量和收藏量确定这个排名。

对于点赞量、浏览量、收藏量这样的信息,我们选择使用 redis 缓存来实现,方式用户频繁的点赞、取消点赞、收藏、取消收藏,对数据库产生巨大的压力

持久化采用 mysql,redis 中的各自事务,要么同时成功,要么同时失败

①先更新数据库,再更新缓存
②先删除缓存,再更新数据库
③先更新数据库,再删除缓存

在这里插入图片描述
经过讨论,我们采用的是先更新数据库再删除缓存的操作,如此可以更好的保证数据的一致性

帖子管理中,我们还做了帖子的审核,鉴于帖子的实时性,选择后审的方式,因为一些帖子可能会包含不良言论,有可能会有一些敏感信息。所以说我们做了一个待审核的一个功能。然后同时我们也加了一个敏感词的一个过滤,敏感词就和管理。
敏感词的过滤通过自定义注解+AOP切片来实现的,因为在项目的其他地方以及未来的扩展中还会有很多需要进行敏感词检测的地方,所以把敏感词过滤封装为一个自定义注解,使用AOP切片来实现,在加上这个注解之后可以对内容进行敏感词分析过滤。没有用传统的正则表达式来过滤敏感词的原因就是工作量太大,而且使用切片实现代码更加简单。然后只要我们在这个特定的场景下,选定好需要过滤的字段,我们就可以通过这个方法对其中的敏感词进行分析及过滤,之后再进行替换敏感词等操作。

我们这里面这个论坛涉及到一些帖子管理、敏感词管理、学院管理、论坛现在的科室管理,用户管理、系统通知管理等等的功能。然后我们在帖子管理里面的话,我们有一些常规的操作,像我们的普通的一些论坛有置顶,这个加精这些功能,在该论坛中都有。

在系统通知管理中为管理员设置了定时发布的功能,这个功能主要使用 quartz 框架实现的,管理员选择定时发布的时间,后台自动创建 cron 表达式,添加到定时任务队列中

在用户管理中,由于我们现在是面向北大药学院的师生来构建的论坛,是一个内部的系统,不允许随意注册,所以用户基本都是直接导入的,所以我们在该模块提供了 excel 批量导入用户的功能,也提供了自定义替换模板的功能,这一系列 excel 功能都是使用的 poi 来实现的。同时在这一部分还添加了拉黑用户的功能,在一些用户频繁发表不当言论时,可以对其进行拉黑,用户拉黑之后不得进行登陆以及其他操作。要保证用户拉黑后不得进行任何操作,我们采用的检测 token 的方式,在每次登陆成功后,后台会生成一个 token ,用户发起的每次请求都需要携带 token 否则拒绝访问,若在拉黑的同时用户正在进行操作,此时同时清空用户的token,此后用户发起任何请求均被拒绝。(@PreAuthoration)

为了方便未来扩展,加了科室学院管理

用户接口采用的是 swagger 来管理接口文档, 服务器采用linux服务器


同时在该系统中我们需要防止 xss 攻击,包括跨站脚本攻击和 sql 注入等问题,我们这个项目使用的是自己的 niua 框架,我也是这个框架的开发人员之一,其中的 xss 防护部分是我做的,就是在后台接收到请求的时候,对请求参数、请求体中的内容进行过滤,如果有检测到内容中存在 html 或脚本内容,就进行 bad parameters 的替换,以及在检测到其中包含有 insert update 等恶意 sql 语句时,过滤这些信息,达到 xss 防护的作用

这篇关于北大药学院项目总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/272015

相关文章

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

配置springboot项目动静分离打包分离lib方式

《配置springboot项目动静分离打包分离lib方式》本文介绍了如何将SpringBoot工程中的静态资源和配置文件分离出来,以减少jar包大小,方便修改配置文件,通过在jar包同级目录创建co... 目录前言1、分离配置文件原理2、pom文件配置3、使用package命令打包4、总结前言默认情况下,

python实现简易SSL的项目实践

《python实现简易SSL的项目实践》本文主要介绍了python实现简易SSL的项目实践,包括CA.py、server.py和client.py三个模块,文中通过示例代码介绍的非常详细,对大家的学习... 目录运行环境运行前准备程序实现与流程说明运行截图代码CA.pyclient.pyserver.py参

Python中连接不同数据库的方法总结

《Python中连接不同数据库的方法总结》在数据驱动的现代应用开发中,Python凭借其丰富的库和强大的生态系统,成为连接各种数据库的理想编程语言,下面我们就来看看如何使用Python实现连接常用的几... 目录一、连接mysql数据库二、连接PostgreSQL数据库三、连接SQLite数据库四、连接Mo

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

IDEA运行spring项目时,控制台未出现的解决方案

《IDEA运行spring项目时,控制台未出现的解决方案》文章总结了在使用IDEA运行代码时,控制台未出现的问题和解决方案,问题可能是由于点击图标或重启IDEA后控制台仍未显示,解决方案提供了解决方法... 目录问题分析解决方案总结问题js使用IDEA,点击运行按钮,运行结束,但控制台未出现http://

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

SpringBoot项目中Maven剔除无用Jar引用的最佳实践

《SpringBoot项目中Maven剔除无用Jar引用的最佳实践》在SpringBoot项目开发中,Maven是最常用的构建工具之一,通过Maven,我们可以轻松地管理项目所需的依赖,而,... 目录1、引言2、Maven 依赖管理的基础概念2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机