Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 350|回复: 0

spring boot之http,页面状态跳转与异常处理实战

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-4 21:50:53 | 显示全部楼层 |阅读模式

    Http使用

      http的使用主要是三个类:HttpServletRequest(向客户端取数据),HttpServletResponse(向客户端发数据),HttpSession(记录浏览器和服务器的长期交互)。

    HttpServletRequest

      取出http的请求头的参数和cookie数据:

     1     @RequestMapping(path= {"/request"})
     2     @ResponseBody
     3     public String request(HttpServletRequest request,
     4                                     HttpServletResponse response,
     5                                     HttpSession session) {
     6         StringBuilder sb = new StringBuilder();
     7         Enumeration<String> headerNames = request.getHeaderNames();
     8         while(headerNames.hasMoreElements()) {
     9             String name = headerNames.nextElement();
    10             sb.append(name + " ::::::::::::::::::::::::::::: " + request.getHeader(name) + "<br/>");
    11         }
    12         for (Cookie cookie : request.getCookies()) {
    13             sb.append("Cookie: ");
    14             sb.append(cookie.getName());
    15             sb.append(":");
    16             sb.append(cookie.getValue());
    17             sb.append("<br>");
    18         }
    19         return sb.toString();
    20     }

     

      显示结果:

    HttpServletResponse

      添加cookie并在页面上显示:

     1     @RequestMapping(value= {"/response"})
     2     @ResponseBody
     3     public String response( @CookieValue(value = "cookieid", defaultValue = "cookieId") String cookieId,
     4                             @RequestParam(value = "key", defaultValue = "key") String key,
     5                             @RequestParam(value = "value", defaultValue = "value") String value,
     6                             HttpServletResponse response) {
     7         response.addCookie(new Cookie(key, value));
     8         //response.addHeader(key, value);
     9         return "cookievalue: " + cookieId;
    10     }

     

     显示结果:

      备注:在url中把key写入cookieid,显示时,cookieid就会显示value值,随value的改变而改变。

    301,302页面跳转与HttpSession

      若访问/redirect/301,就永久跳转到/hello下(301),不经过判断。否则暂时性跳转(302)。

     1    //301永久性跳转
     2     //302暂时性跳转
     3     @RequestMapping(path = {"/redirect/{code}"})
     4     @ResponseBody
     5         public RedirectView redirect(@PathVariable("code") int code,
     6                                      HttpSession session) {
     7         RedirectView red = new RedirectView("/hello", true);
     8         if (code == 301)
     9             red.setStatusCode(HttpStatus.MOVED_PERMANENTLY);//301跳转
    10         //session,记录浏览器和服务器长期的交互。
    11         session.setAttribute("msg", "jump from redirect");
    12         return red;
    13     }

     

      其次,/hello路径:

     1     @RequestMapping(path = {"/hello"})
     2     @ResponseBody
     3     public String Hello_World(Model model,
     4                               HttpSession session) {
     5         model.addAttribute("aaa", "naive");
     6         model.addAttribute("l", "<br/>");
     7         List<String> ls = Arrays.asList(new String[] {"1","111", "2323a"});
     8         model.addAttribute("liststring", ls);
     9         model.addAttribute("user", new User("aw12"));
    10         logger.info("yeah,finally i learn how to use logger");
    11         //显示session的msg信息。
    12         return "session" + session.getAttribute("msg") + sss.show();
    13     }

      

    异常及异常处理

      当key的值不是admin时,抛出异常,在exception函数中处理异常。

     1 //异常
     2     @RequestMapping(path = {"/admin"})
     3     @ResponseBody
     4     public String error(@RequestParam(value = "key", required = false) String key) {
     5         if ("admin".equals(key))
     6             return "hello admin";
     7         throw new IllegalArgumentException("Key 错误");
     8     }
     9     //处理异常
    10     @ExceptionHandler
    11     @ResponseBody
    12     public String exception(Exception e) {
    13         return "error" + e.getMessage();
    14     }

      结果一,key=‘admin"时:

      

      结果二,key!="admin"时:

      

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-2 14:41 , Processed in 0.059367 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表