系统功能结构图
具体实现
4.1 系统功能模块
流浪动物救助及领养管理系统,用户进入前台网站查看首页、宠物教学、领养宠物、宠物认领、感谢信、公告信息、留言板、个人中心、后台管理等内容进行操作,如图4-1所示。
图4-1网站首页界面图
用户注册;在用户注册页面中输入账号、密码、确认密码、姓名、邮箱、手机号码等内容进行注册操作;如图4-2所示。
图4-2用户注册界面图
用户登录;在登录页面中输入账号、密码等内容进行登录操作;如图4-3所示。
图4-3用户登录界面图
宠物教学;在宠物教学页面中可以查看教学名称、教学封面、类型、教学简介、教学视频、发布者日期等内容,还可以进行点我收藏等操作,如图4-4所示。
图4-4宠物教学界面图
领养宠物;在领养宠物页面可以填写领养名称、宠物图片、类型、性别、性情、状态、领养须知、宠物简介、发布日期等内容,并进行领养、点我收藏、评论等操作;如图4-5所示。
图4-5领养宠物界面图
宠物认领;在宠物认领页面可以填写标题、封面、特征、状态、个人账号、个人姓名、联系手机、发布日期等内容,并进行认领、点我收藏、评论等操作;如图4-6所示。
图4-6宠物认领界面图
4.2 管理员功能模块
管理员登录,通过登录页面输入用户名、密码、选择角色等信息进行登录操作,如图4-7所示。
图4-7管理员登录界面图
管理员登录进入流浪动物救助及领养管理系统可以查看个人中心,用户管理、发布者管理、宠物教学管理、领养宠物管理、宠物认领管理、类型管理、领养申请管理、认领信息管理、感谢信管理、留言板管理、系统管理等信息进行详细操作,如图4-8所示。
图4-8管理员功能界面图
用户管理:在用户管理页面中可以查看账号、姓名、性别、邮箱、手机号码、相片等内容,并进行查看,修改和删除等操作,如图4-9所示。
图4-9用户管理界面图
发布者管理;在发布者管理页面中可以查看个人账号、个人姓名、性别、邮箱、联系手机、相片等内容,并进行查看、修改和删除等操作;如图4-10所示。
图4-10发布者管理界面图
宠物教学管理;在宠物教学管理页面中可以查看教学名称、教学封面、类型、教学简介、教学视频、发布者日期等内容,并进行查看、修改、查看评论和删除等操作;如图4-11所示。
图4-11宠物教学管理界面图
领养宠物管理;在领养宠物管理页面中可以查看领养名称、宠物图片、类型、性别、性情、状态、领养须知、宠物简介、发布日期等内容,并进行查看、修改、查看评论和删除等操作;如图4-12所示。
图4-12领养宠物管理界面图
领养申请管理;在领养申请管理页面中可以查看领养名称、类型、性别、账号、姓名、手机号码、申请原因、申请日期、是否审核、审核回复等内容,并进行审核、查看、删除等操作;如图4-13所示。
图4-13领养申请管理界面图
系统管理;系统管理在该页面查看轮播图管理、公告信息管理,还可以上传轮播图的图片进行查看、修改操作,以及图片的删除操作,如图4-14 4-15所示。
图4-14轮播图管理界面图
图4-15公告信息管理界面图
4.3 用户功能模块
用户登录进入流浪动物救助及领养管理系统后台可以查看个人中心、领养申请管理、认领信息管理、感谢信管理、留言板管理、我的收藏管理等内容,如图4-16所示。
图4-16用户功能界面图
留言板管理,在留言板管理页面查看用户名、留言内容、留言图片、回复内容、回复图片等内容,进行查看、修改、删除等操作操作,如图4-17所示。
图4-17留言板管理界面图
感谢信管理,在感谢信管理页面查看标题、封面、简介、账号、姓名、发布日期内容、进行查看、修改、查看评论、删除等操作,如图4-18所示。
图4-18感谢信管理界面图
4.4 发布者功能模块
发布者注册;在发布者注册页面中输入个人账号、密码、确认密码、个人姓名、邮箱、联系手机等内容进行注册操作;如图4-19所示。
图4-19发布者注册界面图
发布者登录;在登录页面中输入用户名、密码、角色等内容进行登录操作;如图4-20所示。
图4-20发布者登录界面图
发布者登录进入流浪动物救助及领养管理系统后可以查看个人中心、宠物认领管理、认领信息管理、系统管理等内容,如图4-21所示。
图4-21发布者功能界面图
认领信息管理,在认领信息管理页面查看标题、个人账户、个人姓名、联系手机、遗失时间、遗失地点、宠物特点、账号、姓名、手机号码、申请日期、是否审核、审核回复等信息进行审核、查看等操作,如图4-22所示。
图4-22认领信息管理界面图
宠物认领管理,在退宠物认领管理页面查看标题、封面、特征、状态、个人账号、个人姓名、联系手机、发布日期等信息进行查看、修改、查看评论、删除等操作,如图4-23所示。
图4-23宠物认领管理界面图
代码参考
@IgnoreAuth @PostMapping(value = "/login") public R login(String username, String password, String captcha, HttpServletRequest request) { UsersEntity user = userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username)); if(user==null || !user.getPassword().equals(password)) { return R.error("账号或密码不正确"); } String token = tokenService.generateToken(user.getId(),username, "users", user.getRole()); return R.ok().put("token", token); } @Override public String generateToken(Long userid,String username, String tableName, String role) { TokenEntity tokenEntity = this.selectOne(new EntityWrapper<TokenEntity>().eq("userid", userid).eq("role", role)); String token = CommonUtil.getRandomString(32); Calendar cal = Calendar.getInstance(); cal.setTime(new Date()); cal.add(Calendar.HOUR_OF_DAY, 1); if(tokenEntity!=null) { tokenEntity.setToken(token); tokenEntity.setExpiratedtime(cal.getTime()); this.updateById(tokenEntity); } else { this.insert(new TokenEntity(userid,username, tableName, role, token, cal.getTime())); } return token; } /** * 权限(Token)验证 */ @Component public class AuthorizationInterceptor implements HandlerInterceptor { public static final String LOGIN_TOKEN_KEY = "Token"; @Autowired private TokenService tokenService; @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { //支持跨域请求 response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE"); response.setHeader("Access-Control-Max-Age", "3600"); response.setHeader("Access-Control-Allow-Credentials", "true"); response.setHeader("Access-Control-Allow-Headers", "x-requested-with,request-source,Token, Origin,imgType, Content-Type, cache-control,postman-token,Cookie, Accept,authorization"); response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin")); // 跨域时会首先发送一个OPTIONS请求,这里我们给OPTIONS请求直接返回正常状态 if (request.getMethod().equals(RequestMethod.OPTIONS.name())) { response.setStatus(HttpStatus.OK.value()); return false; } IgnoreAuth annotation; if (handler instanceof HandlerMethod) { annotation = ((HandlerMethod) handler).getMethodAnnotation(IgnoreAuth.class); } else { return true; } //从header中获取token String token = request.getHeader(LOGIN_TOKEN_KEY); /** * 不需要验证权限的方法直接放过 */ if(annotation!=null) { return true; } TokenEntity tokenEntity = null; if(StringUtils.isNotBlank(token)) { tokenEntity = tokenService.getTokenEntity(token); } if(tokenEntity != null) { request.getSession().setAttribute("userId", tokenEntity.getUserid()); request.getSession().setAttribute("role", tokenEntity.getRole()); request.getSession().setAttribute("tableName", tokenEntity.getTablename()); request.getSession().setAttribute("username", tokenEntity.getUsername()); return true; } PrintWriter writer = null; response.setCharacterEncoding("UTF-8"); response.setContentType("application/json; charset=utf-8"); try { writer = response.getWriter(); writer.print(JSONObject.toJSONString(R.error(401, "请先登录"))); } finally { if(writer != null){ writer.close(); } } // throw new EIException("请先登录", 401); return false; } }
论文参考