当前位置:   article > 正文

基于微信小程序的图书销售商城系统源码_小程序商品销售管理系统源码

小程序商品销售管理系统源码

目录

一、整体目录(示范):

文档含项目技术介绍、E-R图、数据字典、项目功能介绍与截图等

二、运行截图

三、代码部分(示范):

四、数据库表(示范):

数据库表有注释,可以导出数据字典及更新数据库时间,欢迎交流学习

五、主要技术介绍:

六、项目调试学习(点击查看)

七、项目交流


一、整体目录(示范):

文档含项目技术介绍、E-R图、数据字典、项目功能介绍与截图等

 

二、运行截图

三、代码部分(示范):

注册较验代码:

  1. // 注册
  2. async register() {
  3. if((!this.ruleForm.yonghuzhanghao) && `yonghu` == this.tableName){
  4. this.$utils.msg(`用户账号不能为空`);
  5. return
  6. }
  7. if(`yonghu` == this.tableName && (this.ruleForm.yonghuzhanghao.length<8)){
  8. this.$utils.msg(`用户账号长度不能小于8`);
  9. return
  10. }
  11. if(`yonghu` == this.tableName && (this.ruleForm.yonghuzhanghao.length>12)){
  12. this.$utils.msg(`用户账号长度不能大于12`);
  13. return
  14. }
  15. if((!this.ruleForm.mima) && `yonghu` == this.tableName){
  16. this.$utils.msg(`密码不能为空`);
  17. return
  18. }
  19. if(`yonghu` == this.tableName && (this.ruleForm.mima!=this.ruleForm.mima2)){
  20. this.$utils.msg(`两次密码输入不一致`);
  21. return
  22. }
  23. if((!this.ruleForm.yonghuxingming) && `yonghu` == this.tableName){
  24. this.$utils.msg(`用户姓名不能为空`);
  25. return
  26. }
  27. if(`yonghu` == this.tableName && this.ruleForm.nianling&&(!this.$validate.isIntNumer(this.ruleForm.nianling))){
  28. this.$utils.msg(`年龄应输入整数`);
  29. return
  30. }
  31. if((!this.ruleForm.schoolname) && `yonghu` == this.tableName){
  32. this.$utils.msg(`学校名称不能为空`);
  33. return
  34. }
  35. if(`yonghu` == this.tableName && this.ruleForm.shouji&&(!this.$validate.isMobile(this.ruleForm.shouji))){
  36. this.$utils.msg(`手机应输入手机格式`);
  37. return
  38. }
  39. if(`yonghu` == this.tableName && this.ruleForm.youxiang&&(!this.$validate.isEmail(this.ruleForm.youxiang))){
  40. this.$utils.msg(`邮箱应输入邮件格式`);
  41. return
  42. }
  43. await this.$api.register(`${this.tableName}`, this.ruleForm, this.emailcode);
  44. this.$utils.msgBack('注册成功');;
  45. }
  46. }
  47. }
  48. </script>

推荐算法代码

  1. //智能推荐商品业务步骤
  2. 1.获取当前用户信息
  3. 2.判断当前是否有收藏信息
  4. 3.如有收藏信息按收藏推荐信息推荐,无推荐信息默认按点击次数
  5. //================以下是相关类和方法==============
  6. //商品信息后端接口类
  7. com.controller.ShangpinxinxiController
  8. /**
  9. * 商品信息前端智能排序
  10. */
  11. @IgnoreAuth
  12. @RequestMapping("/autoSort")
  13. public R autoSort(@RequestParam Map<String, Object> params,ShangpinxinxiEntity shangpinxinxi, HttpServletRequest request,String pre){
  14. EntityWrapper<ShangpinxinxiEntity> ew = new EntityWrapper<ShangpinxinxiEntity>();
  15. Map<String, Object> newMap = new HashMap<String, Object>();
  16. Map<String, Object> param = new HashMap<String, Object>();
  17. boolean flag = false;
  18. String isRecommend =(String) params.get("isRecommend");
  19. if("1".equals(isRecommend)){ //是否推荐
  20. String userId = (String) params.get("userId");
  21. YonghuEntity user = yonghuService.selectById(Long.valueOf(userId));
  22. params.remove("isRecommend");
  23. params.remove("userId");
  24. StringBuffer refIds = new StringBuffer();
  25. List<StoreupView> storeupList = storeupService.selectListView(new EntityWrapper<StoreupEntity>().eq("userid",userId));
  26. if(storeupList!=null && storeupList.size()>0){
  27. for(StoreupView storeupView: storeupList){
  28. refIds.append(storeupView.getRefid()+",");
  29. }
  30. flag =true;
  31. ew.in("id",refIds.toString());
  32. }
  33. }
  34. Iterator<Map.Entry<String, Object>> it = param.entrySet().iterator();
  35. while (it.hasNext()) {
  36. Map.Entry<String, Object> entry = it.next();
  37. String key = entry.getKey();
  38. String newKey = entry.getKey();
  39. if (pre.endsWith(".")) {
  40. newMap.put(pre + newKey, entry.getValue());
  41. } else if (StringUtils.isEmpty(pre)) {
  42. newMap.put(newKey, entry.getValue());
  43. } else {
  44. newMap.put(pre + "." + newKey, entry.getValue());
  45. }
  46. }
  47. params.put("sort", "clicknum");
  48. params.put("order", "desc");
  49. PageUtils page = shangpinxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, shangpinxinxi), params), params));
  50. return R.ok().put("data", page);
  51. }
  52. //收藏表后端接口
  53. com.controller.StoreupController
  54. /**
  55. * 收藏表后端保存方法
  56. */
  57. @RequestMapping("/save")
  58. public R save(@RequestBody StoreupEntity storeup, HttpServletRequest request){
  59. storeup.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
  60. //ValidatorUtils.validateEntity(storeup);
  61. storeup.setUserid((Long)request.getSession().getAttribute("userId"));
  62. storeupService.insert(storeup);
  63. return R.ok();
  64. }
  65. /**
  66. * 收藏表删除方法
  67. */
  68. @RequestMapping("/delete")
  69. public R delete(@RequestBody Long[] ids){
  70. storeupService.deleteBatchIds(Arrays.asList(ids));
  71. return R.ok();
  72. }

四、数据库表(示范):

数据库表有注释,可以导出数据字典及更新数据库时间,欢迎交流学习

 

五、主要技术介绍:

ssm框架介绍:

SSM(Spring+SpringMVC+MyBatis)框架集由Spring、MyBatis两个开源框架整合而成(SpringMVC是Spring中的部分内容)。常作为数据源较简单的web项目的框架。

1.8.1 Spring
Spring就像是整个项目中装配bean的大工厂,在配置文件中可以指定使用特定的参数去调用实体类的构造方法来实例化对象。也可以称之为项目中的粘合剂。
Spring的核心思想是IoC(控制反转),即不再需要程序员去显式地`new`一个对象,而是让Spring框架帮你来完成这一切。
1.8.2 SpringMVC
SpringMVC在项目中拦截用户请求,它的核心Servlet即DispatcherServlet承担中介或是前台这样的职责,将用户请求通过HandlerMapping去匹配Controller,Controller就是具体对应请求所执行的操作。SpringMVC相当于SSH框架中struts。
1.8.3 mybatis
mybatis是对jdbc的封装,它让数据库底层操作变的透明。mybatis的操作都是围绕一个sqlSessionFactory实例展开的。mybatis通过配置文件关联到各实体类的Mapper文件,Mapper文件中配置了每个类对数据库所需进行的sql语句映射。在每次与数据库交互时,通过sqlSessionFactory拿到一个sqlSession,再执行sql命令。

页面发送请求给控制器,控制器调用业务层处理逻辑,逻辑层向持久层发送请求,持久层与数据库交互,后将结果返回给业务层,业务层将处理逻辑发送给控制器,控制器再调用视图展现数据。

 B/S体系结构介绍:

B/S结构(Browser/Server,浏览器/服务器模式),是WEB兴起后的一种网络结构模式,WEB浏览器是客户端最主要的应用软件。这种模式统一了客户端,将系统功能实现的核心部分集中到服务器上,简化了系统的开发、维护和使用。客户机上只要安装一个浏览器,如ChromeSafariMicrosoft EdgeNetscape NavigatorInternet Explorer,服务器安装SQL ServerOracleMYSQL等数据库。浏览器通过Web Server同数据库进行数据交互。 

MVVM模式介绍:

MVVM是Model-View-ViewModel的简写。它本质上就是MVC 的改进版。MVVM 就是将其中的View 的状态和行为抽象化,让我们将视图 UI 和业务逻辑分开。当然这些事 ViewModel 已经帮我们做了,它可以取出 Model 的数据同时帮忙处理 View 中由于需要展示内容而涉及的业务逻辑。微软的WPF带来了新的技术体验,如Silverlight、音频视频3D动画……,这导致了软件UI层更加细节化、可定制化。同时,在技术层面,WPF也带来了 诸如Binding、Dependency Property、Routed Events、Command、DataTemplate、ControlTemplate等新特性。MVVM(Model-View-ViewModel)框架的由来便是MVP(Model-View-Presenter)模式与WPF结合的应用方式时发展演变过来的一种新型架构框架。它立足于原有MVP框架并且把WPF的新特性糅合进去,以应对客户日益复杂的需求变化。

六、项目调试学习点击查看

七、项目交流

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/229046
推荐阅读
相关标签
  

闽ICP备14008679号