@RequestMapping("/addAppliance") //接口路径 public String addAppliance(@RequestBody Appliance appliance,HttpSession session,Model model,HttpServletRequest request, HttpServletResponse response){ //传递的参数是家电实体 Seller seller = (Seller) session.getAttribute("seller"); if (seller == null) { //如果卖家没有登录 request.setAttribute("error","请先登陆后再上架家电");return "login";} Stringpn=Pic.gainPicture(appliance.getAppliancepicture(),"D:/secondhandHA/src/ main/webapp/img/",request.getSession().getServletContext().getRealPath("/img/")); appliance.setAppliancepicture("img/"+pn); //获取二手家电图片 appliance.setSellerid(seller.getSellerid()); //获取卖家id appliance.setApplianceid(UuidUtils.getUuid()); //调用UuidUtils工具类设置家电id int rows = applianceService.addAppce(appliance); //调用applianceService中的addAppce将此家电添加到数据库中并且返回受影响的行数 if(rows > 0){ request.setAttribute("success","上架家电成功");return "appliancesl";}else{ request.setAttribute("error","上架家电失败,请重试");return "addapp";}} //判断上架家电是否成功
时间: 2024-04-22 22:28:25 浏览: 110
这段代码是一个用于添加家电的接口。接口路径是`/addAppliance`,使用`@RequestBody`注解接收一个Appliance对象作为参数。
接口的逻辑如下:
1. 首先,从`HttpSession`中获取卖家对象(Seller)。
2. 如果卖家对象为空,表示卖家未登录,将错误信息设置到request属性中,并返回`login`字符串,用于跳转到登录页面。
3. 使用`Pic.gainPicture()`方法获取家电图片,并设置到Appliance对象的`appliancepicture`属性中。
4. 设置Appliance对象的`sellerid`属性为卖家的ID。
5. 使用`UuidUtils.getUuid()`方法生成一个唯一的家电ID,并设置到Appliance对象的`applianceid`属性中。
6. 调用`applianceService.addAppce(appliance)`方法将家电添加到数据库,并返回受影响的行数。
7. 如果受影响的行数大于0,表示家电添加成功,将成功信息设置到request属性中,并返回`appliancesl`字符串,用于跳转到家电列表页面。
8. 如果受影响的行数小于等于0,表示家电添加失败,将错误信息设置到request属性中,并返回`addapp`字符串,用于跳转到添加家电页面。
所以,判断上架家电是否成功是通过返回的字符串来决定跳转到哪个页面,并在页面上显示相应的成功或失败信息。
相关问题
@RequestMapping("/login") public String login(@RequestBody User user, @RequestParam String checkCode, HttpServletRequest request) throws IOException { HttpSession session = request.getSession(); String checkCodeGen = (String) session.getAttribute("checkCodeGen"); if (checkCodeGen.equalsIgnoreCase(checkCode)){ User result = userService.login(user.getUserName(), user.getPassword()); if (result != null){ session.setAttribute("userName",result.getUserName()); return "success" ; } }else{ return "验证码错误"; } return "用户名或密码错误"; } @RequestMapping("/checkCode") public void checkCode(HttpServletRequest request, HttpServletResponse response) throws IOException { String checkCodeGen = CheckCodeUtil.generateVerifyCode(4); HttpSession session = request.getSession(); session.setAttribute("checkCodeGen",checkCodeGen); System.out.println(session.getId()); ServletOutputStream os = response.getOutputStream(); CheckCodeUtil.outputImage(100,40,os,checkCodeGen); } @RequestMapping("/checkLogin") public String checkLogin(HttpSession session){ return (String)session.getAttribute("userName"); } @RequestMapping("/logout") public String logout(HttpSession session){ session.setAttribute("userName",null); return "success"; }
这段代码是一个基于Spring MVC框架的用户登录、验证码验证、注销功能的实现。其中:
- @RequestMapping是一个注解,用于映射请求的URL路径和Controller方法。
- @RequestBody注解用于将request请求的body部分转换成Java对象,并且可以通过@RequestParam注解获取请求参数。
- HttpSession是一个接口,用于存储和获取当前会话的数据。
- CheckCodeUtil是一个工具类,用于生成和输出验证码图片。
具体实现逻辑如下:
1. 用户访问/login路径,请求会被映射到login方法。
2. login方法首先从request请求中获取用户提交的用户名和密码,以及验证码。
3. 然后从session中获取之前生成的验证码,并与用户提交的验证码进行比较,判断是否输入正确。
4. 如果验证码输入正确,则调用userService的login方法进行用户登录验证,如果成功则将用户名存入session,并返回"success"字符串表示登录成功。
5. 如果验证码输入错误,则直接返回"验证码错误"字符串。
6. 如果用户名或密码错误,则返回"用户名或密码错误"字符串。
7. 用户可以在页面上访问/checkCode路径来获取验证码图片,该请求会被映射到checkCode方法。该方法通过CheckCodeUtil工具类生成验证码图片,并将验证码存入session中。
8. 用户可以在页面上访问/checkLogin路径来检查当前用户是否已经登录,该请求会被映射到checkLogin方法。该方法从session中获取当前用户的用户名,并返回该值。
9. 用户可以在页面上访问/logout路径来退出登录,该请求会被映射到logout方法。该方法将session中的用户名设为null,并返回"success"字符串表示注销成功。
@RequestMapping("/allAppliance") //接口路径 public String allAppliance(HttpServletRequest request, HttpServletResponse response, Model model,HttpSession session) { //查询全部二手家电信息方法 Buyer buyer= (Buyer) session.getAttribute("buyer"); if (buyer== null) {//如果买家没有登录 request.setAttribute("error","请先登陆后再浏览家电");return "login";} List<Appliance>appliances= applianceService.selectallApp(); //调用applianceService中的selectallApp查询全部二手家电信息 request.setAttribute("appliances",appliances); return "applianceby";} //查询成功,返回二手家电信息
您的代码中的`@RequestMapping`注解指定了接口路径为"/allAppliance"。该方法的作用是查询全部二手家电信息并返回到前端页面。
在方法体内部,首先我们从`session`中获取`buyer`对象,判断买家是否已登录。如果买家未登录,则设置一个错误提示信息,并返回到登录页面。
接下来,我们调用`applianceService.selectallApp()`方法查询全部二手家电信息,将结果存储在名为"appliances"的请求属性中。
最后,我们返回一个名为"applianceby"的视图名,表示将渲染名为"applianceby.jsp"的视图页面,并将查询到的二手家电信息传递给该页面进行展示。
请注意,以上代码只是一个简单示例,实际情况中您可能需要根据具体业务需求进行适当的修改和扩展。
阅读全文
相关推荐
















