• 基于JavaSpringMVC+vue实现协同过滤电影推荐系统详细设计


    博主介绍全网粉丝20W+,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星TOP100、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业设计项目实战

    🍅文末获取联系🍅

    精彩专栏推荐👇🏻👇🏻👇🏻👇🏻

    java项目精品实战案例《100套》https://blog.csdn.net/weixin_39709134/category_11128297.html

    目录

    一、前言介绍:

    二、系统设计:

    2.1 系统设计原则:

    2.2 系统结构设计:

    2.3 协同过滤算法:

    三、数据设计:

    3.1 用户实体属性:

    3.2 电影实体属性:

    3.3 数据逻辑设计: 

    四、功能截图: 

    4.1 登录注册:

    4.2 用户首页:

    4.2.1 首页:

    4.2.2 免费电影:

    4.2.3 付费电影:

    4.2.4 电影论坛:

    4.2.5 电影资讯:

    4.2.6 个人中心: 

    4.3 用户后端:

    4.3.1 个人信息:

    4.3.2 电影订单:

    4.4 管理员后端: 

    4.4.1 用户管理:

    4.4.2 电影分类:

    4.4.3 免费电影:

    4.4.4 付费电影:

    4.4.5 电影订单:

    4.4.7 电影论坛:

    4.4.8 系统管理:

    4.4.9 首页轮播图:

    五、代码实现:

    5.1 用户登录:

    5.2 文件上传;

    5.3 电影订单:

    5.4 协同过滤算法主要实现:

    六、项目总结: 

    七、源码获取:


    一、前言介绍:

            本次设计任务是要设计一个基于协同过滤算法的电影推荐系统,通过这个系统能够满足电影推荐的管理功能。系统的主要包括首页,个人中心,用户管理,电影分类管理,免费电影管理,付费电影管理,电影订单管理,电影论坛,系统管理等功能

            管理员可以根据系统给定的账号进行登录,登录后可以进入电影推荐系统个性化智能电影推荐所有模块进行管理。包括查看和修改自己的个人信息以及登录密码。

            该系统为每一个用户都分配了一个用户账号,用户通过账号的登录可以在系统中查看个性化智能电影推荐信息及对个人信息进行修改等功能。

    二、系统设计:

    2.1 系统设计原则:

    本电影推荐系统采用Java技术,Mysql数据库开发,充分保证了系统稳定性、完整性。

    电影推荐系统设计与实现的设计思路如下:

    1.操作简单方便,页面布局简单清晰、界面安全良好:,便于查询电影推荐系统的相关信息。

    2.即时可视性:电影推荐系统的信息处理将在相应的位置即时可用,以实现“即时发布、即时生效”的系统功能。

    功能完善:个人中心,用户管理,电影分类管理,免费电影管理,付费电影管理,电影订单管理,我的电影管理,电影论坛,系统管理等功能等模块的修改和维护。

    2.2 系统结构设计:

            系统设计是把本系统的各项功能需求进行细化,而转换为软件系统表示的一个设计过程,在对目标系统的研究分析之后,做出整个系统平台的总体规划,进而对用例中各个对象进一步地合理精细设计。为降低整个系统的复杂度,而使其更加便于修改,提高代码的可读性,我们会将系统模块化,模块间保持相对独立,且每个模块只完成一个子功能,并且与其他模块通过简单的接口链接,即高内聚低耦合原则,而使整个系统能够拥有一个高性能的结构,这边是系统概要设计最重要的目的。在之前的需求分析的基础上,本电影推荐系统结构,如下图所示。

    2.3 协同过滤算法:

            协同过滤算法是一种较为著名和常用的推荐算法,它基于对用户历史行为数据的挖掘发现用户的喜好偏向,并预测用户可能喜好的产品进行推荐。也就是常见的“猜你喜欢”,和“购买了该商品的人也喜欢”等功能。它的主要实现由:

    ●根据和你有共同喜好的人给你推荐

    ●根据你喜欢的物品给你推荐相似物品

    ●根据以上条件综合推荐

      因此可以得出常用的协同过滤算法分为两种,基于用户的协同过滤算法(user-based collaboratIve filtering),以及基于物品的协同过滤算法(item-based collaborative filtering)。特点可以概括为“人以类聚,物以群分”,并据此进行预测和推荐。

    三、数据设计:

             在查询时,应保证所有满足条件的记录都能查到。数据库记录通常在几百条以上,如有遗漏将会对客户的统计造成影响。一般操作的响应时间应该在1-2秒内。采用菜单界面,对会员比较友好。通过E-R图来设计并展示数据的概念模型,

    3.1 用户实体属性:

    3.2 电影实体属性:

    3.3 数据逻辑设计: 

    四、功能截图: 

    4.1 登录注册:

    4.2 用户首页:

    4.2.1 首页:

    电影推荐系统,在系统首页可以查看首页,免费电影,付费电影,电影论坛,电影资讯,个人中心等内容,并进行详细操作。

    4.2.2 免费电影:

    免费电影,在免费电影页面可以查看电影编号,电影分类,评分,开映时间,时长,导演,主演,点击次数等信息,并进行赞一下,踩一下,点我收藏等操作

     4.2.3 付费电影:

    付费电影,在免费电影页面可以查看电影编号,电影分类,评分,开映时间,时长,导演,主演,点击次数等信息,并进行赞一下,踩一下,点我收藏等操作

     查看详情!进行预览播放视频!收藏 点餐 踩等功能!收藏越多权重越高

     详情查看以及评论等操作

    4.2.4 电影论坛:

     

    4.2.5 电影资讯:

    4.2.6 个人中心: 

    个人中心,在个人中心页面通过填写用户名,姓名,密码,性别,年龄,手机号等内容进行更新信息,还可以根据需要对我的发布,我的收藏进行相对应操作

    4.3 用户后端:

    4.3.1 个人信息:

    4.3.2 电影订单:

    4.4 管理员后端:

    可以对首页,个人中心,用户管理,电影分类管理,免费电影管理,付费电影管理,电影订单管理、电影论坛,系统管理等功能进行相应的操作 

    4.4.1 用户管理:

    用户管理,在用户管理页面可以对索引,用户名,姓名,性别,年龄,手机号等内容进行详情,修改和删除操作

    4.4.2 电影分类:

    4.4.3 免费电影:

    免费电影管理,在免费电影管理页面可以对索引,电影编号,电影名称,视频,海报,评分,开映时间,时长,主演,导演等内容进行详情,修改,查看评论和删除操作

     

    4.4.4 付费电影:

    付费电影管理,在付费电影管理页面可以对索引,电影编号,电影名称,预告片,价格,海报,评分,开映时间,时长,主演,导演等内容进行详情,修改,查看评论和删除操作

    4.4.5 电影订单:

    电影订单管理,在电影订单管理页面可以对 索引,订单编号,电影编号,电影名称,价格,用户名,姓名,手机号,购买时间,是否支付等内容进行详情,我的电影,修改和删除等操作

    4.4.7 电影论坛:

    4.4.8 系统管理:

    4.4.9 首页轮播图:

    五、代码实现:

    5.1 用户登录:

    1. form.on('submit(login)', function(data) {
    2. data = data.field;
    3. if (vue.roles.length!=1) {
    4. if (!data.role) {
    5. layer.msg('请选择登录用户类型', {
    6. time: 2000,
    7. icon: 5
    8. });
    9. return false;
    10. }
    11. } else {
    12. data.role = vue.roles[0].tableName;
    13. }
    14. http.request(data.role + '/login', 'get', data, function(res) {
    15. layer.msg('登录成功', {
    16. time: 2000,
    17. icon: 6
    18. });
    19. // 登录凭证
    20. localStorage.setItem('Token', res.token);
    21. var roleName = "";
    22. if(typeof(jquery('#role:checked').attr('title')) == "undefined") {
    23. roleName = vue.roles[0].roleName;
    24. } else {
    25. roleName = jquery('#role:checked').attr('title');
    26. }
    27. localStorage.setItem('role', roleName);
    28. // 当前登录用户角色
    29. localStorage.setItem('userTable', data.role);
    30. localStorage.setItem('sessionTable', data.role);
    31. // 用户名称
    32. localStorage.setItem('adminName', data.username);
    33. http.request(data.role + '/session', 'get', {}, function(res) {
    34. // 用户id
    35. localStorage.setItem('userid', res.data.id);
    36. if(res.data.vip) {
    37. localStorage.setItem('vip', res.data.vip);
    38. }
    39. // 路径访问设置
    40. window.location.href = '../../index.html';
    41. })
    42. });
    43. return false
    44. });

    5.2 文件上传;

    1. /**
    2. * 上传文件
    3. */
    4. @RequestMapping("/upload")
    5. public R upload(@RequestParam("file") MultipartFile file, String type,HttpServletRequest request) throws Exception {
    6. if (file.isEmpty()) {
    7. throw new EIException("上传文件不能为空");
    8. }
    9. String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
    10. String fileName = new Date().getTime()+"."+fileExt;
    11. File dest = new File(request.getSession().getServletContext().getRealPath("/upload")+"/"+fileName);
    12. file.transferTo(dest);
    13. // FileUtils.copyFile(dest, new File("D:\\ssmpiv99\\src\\main\\webapp\\upload"+"/"+fileName)); /**修改了路径以后请将该行最前面的//注释去掉**/
    14. if(StringUtils.isNotBlank(type) && type.equals("1")) {
    15. ConfigEntity configEntity = configService.selectOne(new EntityWrapper().eq("name", "faceFile"));
    16. if(configEntity==null) {
    17. configEntity = new ConfigEntity();
    18. configEntity.setName("faceFile");
    19. configEntity.setValue(fileName);
    20. } else {
    21. configEntity.setValue(fileName);
    22. }
    23. configService.insertOrUpdate(configEntity);
    24. }
    25. return R.ok().put("file", fileName);
    26. }

    5.3 电影订单:

    1. /**
    2. * 电影订单
    3. * 后端接口
    4. * @author
    5. * @email
    6. * @date 2022-08-06 21:42:07
    7. */
    8. @RestController
    9. @RequestMapping("/dianyingdingdan")
    10. public class DianyingdingdanController {
    11. @Autowired
    12. private DianyingdingdanService dianyingdingdanService;
    13. /**
    14. * 前端列表
    15. */
    16. @RequestMapping("/list")
    17. public R list(@RequestParam Map params,DianyingdingdanEntity dianyingdingdan,
    18. HttpServletRequest request){
    19. EntityWrapper ew = new EntityWrapper();
    20. PageUtils page = dianyingdingdanService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, dianyingdingdan), params), params));
    21. return R.ok().put("data", page);
    22. }
    23. /**
    24. * 列表
    25. */
    26. @RequestMapping("/lists")
    27. public R list( DianyingdingdanEntity dianyingdingdan){
    28. EntityWrapper ew = new EntityWrapper();
    29. ew.allEq(MPUtil.allEQMapPre( dianyingdingdan, "dianyingdingdan"));
    30. return R.ok().put("data", dianyingdingdanService.selectListView(ew));
    31. }
    32. /**
    33. * 查询
    34. */
    35. @RequestMapping("/query")
    36. public R query(DianyingdingdanEntity dianyingdingdan){
    37. EntityWrapper< DianyingdingdanEntity> ew = new EntityWrapper< DianyingdingdanEntity>();
    38. ew.allEq(MPUtil.allEQMapPre( dianyingdingdan, "dianyingdingdan"));
    39. DianyingdingdanView dianyingdingdanView = dianyingdingdanService.selectView(ew);
    40. return R.ok("查询电影订单成功").put("data", dianyingdingdanView);
    41. }
    42. /**
    43. * 前端详情
    44. */
    45. @RequestMapping("/detail/{id}")
    46. public R detail(@PathVariable("id") Long id){
    47. DianyingdingdanEntity dianyingdingdan = dianyingdingdanService.selectById(id);
    48. return R.ok().put("data", dianyingdingdan);
    49. }
    50. /**
    51. * 前端保存
    52. */
    53. @RequestMapping("/add")
    54. public R add(@RequestBody DianyingdingdanEntity dianyingdingdan, HttpServletRequest request){
    55. dianyingdingdan.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    56. //ValidatorUtils.validateEntity(dianyingdingdan);
    57. dianyingdingdanService.insert(dianyingdingdan);
    58. return R.ok();
    59. }
    60. /**
    61. * 修改
    62. */
    63. @RequestMapping("/update")
    64. public R update(@RequestBody DianyingdingdanEntity dianyingdingdan, HttpServletRequest request){
    65. //ValidatorUtils.validateEntity(dianyingdingdan);
    66. dianyingdingdanService.updateById(dianyingdingdan);//全部更新
    67. return R.ok();
    68. }
    69. /**
    70. * 删除
    71. */
    72. @RequestMapping("/delete")
    73. public R delete(@RequestBody Long[] ids){
    74. dianyingdingdanService.deleteBatchIds(Arrays.asList(ids));
    75. return R.ok();
    76. }
    77. }

    5.4 协同过滤算法主要实现:

    1. /**
    2. * 协同算法(按收藏推荐)
    3. */
    4. @RequestMapping("/autoSort")
    5. public R autoSort2(@RequestParam Map params,MianfeidianyingEntity mianfeidianying, HttpServletRequest request){
    6. String userId = request.getSession().getAttribute("userId").toString();
    7. String inteltypeColumn = "dianyingfenlei";
    8. List storeups = storeupService.selectList(new EntityWrapper().eq("type", 1).eq("userid", userId).eq("tablename", "mianfeidianying").orderBy("addtime", false));
    9. List inteltypes = new ArrayList();
    10. Integer limit = params.get("limit")==null?10:Integer.parseInt(params.get("limit").toString());
    11. List mianfeidianyingList = new ArrayList();
    12. //去重
    13. if(storeups!=null && storeups.size()>0) {
    14. for(StoreupEntity s : storeups) {
    15. mianfeidianyingList.addAll(mianfeidianyingService.selectList(new EntityWrapper().eq(inteltypeColumn, s.getInteltype())));
    16. }
    17. }
    18. EntityWrapper ew = new EntityWrapper();
    19. params.put("sort", "id");
    20. params.put("order", "desc");
    21. PageUtils page = mianfeidianyingService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, mianfeidianying), params), params));
    22. List pageList = (List)page.getList();
    23. if(mianfeidianyingList.size()
    24. int toAddNum = (limit-mianfeidianyingList.size())<=pageList.size()?(limit-mianfeidianyingList.size()):pageList.size();
    25. for(MianfeidianyingEntity o1 : pageList) {
    26. boolean addFlag = true;
    27. for(MianfeidianyingEntity o2 : mianfeidianyingList) {
    28. if(o1.getId().intValue()==o2.getId().intValue()) {
    29. addFlag = false;
    30. break;
    31. }
    32. }
    33. if(addFlag) {
    34. mianfeidianyingList.add(o1);
    35. if(--toAddNum==0) break;
    36. }
    37. }
    38. }
    39. page.setList(mianfeidianyingList);
    40. return R.ok().put("data", page);
    41. }

    六、项目总结: 

            历经六个月左右的时间,本次的毕业设计已画上了句号。原本以为完成一个系统会很顺利,因为在之前课上,也曾动手操作过相关的模块编写,但当真正接触到一个完整的系统时,发现并没有想象地那么简单。首先,以前实践过的只是单独的模块,而这次,是一个庞大的系统,许多细节不容忽视,有时候稍不留意的一个小错误,会致使整个系统都运行不起来,而查找错误的过程又漫长且艰辛,这也正是经验不足所导致的。在整个系统开发过程中,也查阅了很多书籍和相关资料,这让我不但巩固了原本的知识,同时还学习到了一些新的知识,这让我受益匪浅。

            此次系统从整体看来,已基本达到预期的设计目的,能够实现基本的功能,但相较于市场的一些优秀网站而言,还是有许多不足的地方。遗憾的是,由于时间的有限,已经不允许再投入更多的时间和精力进行研究开发。相信在以后的工作中,我会接触到更多相关的知识,会更丰富自身的经验,我希望到时能够在此基础上完成一个丰富完整的学习网站,这将对我有很大的意义。

            通过这次的毕业设计,我学到了很多,除了学识方面的知识,在态度上也有了很大的转变,细心和耐心是整个开发过程中最重要的两件事。我也在跟随着系统的完善而成长,这次毕业设计考核地也不单单是所学的知识,也同样在衡量着面对困难时的态度。

    七、源码联系:

    大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻获取联系方式👇🏻👇🏻👇🏻

    打卡 文章 更新 308/  365天

     精彩专栏推荐订阅下方专栏👇🏻👇🏻👇🏻👇🏻

    java项目精品实战案例《100套》https://blog.csdn.net/weixin_39709134/category_11128297.html

  • 相关阅读:
    LNMP编译安装
    几何距离与函数距离:解锁数据空间中的奥秘
    java 将字符串转为Base64格式与将Base64内容解析出来
    基于java+SpringBoot+HTML+MySQL医院挂号系统的设计与实现
    windows安装telnet工具
    c语言map的详细用法
    【Java 进阶篇】Java HTTP 请求消息详解
    总结vue框架中的钩子函数
    Java学习笔记——Map之HashMap
    【Spring Cloud Alibaba】9 - OpenFeign集成Sentinel实现服务降级
  • 原文地址:https://blog.csdn.net/weixin_39709134/article/details/126346952