当前位置:首页 > 科技  > 软件

SpringBoot3之Web编程

来源: 责编: 时间:2023-08-09 23:02:25 234观看
导读一、简介基于web包的依赖,SpringBoot可以快速启动一个web容器,简化项目的开发;在web开发中又涉及如下几个功能点:拦截器:可以让接口被访问之前,将请求拦截到,通过对请求的识别和校验,判断请求是否允许通过;页面交互:对于服务端

一、简介

基于web包的依赖,SpringBoot可以快速启动一个web容器,简化项目的开发;PxR28资讯网——每日最新资讯28at.com

在web开发中又涉及如下几个功能点:PxR28资讯网——每日最新资讯28at.com

拦截器:可以让接口被访问之前,将请求拦截到,通过对请求的识别和校验,判断请求是否允许通过;PxR28资讯网——每日最新资讯28at.com

页面交互:对于服务端的开发来说,需要具备简单的页面开发能力,解决部分场景的需求;PxR28资讯网——每日最新资讯28at.com

Swagger接口:通过简单的配置,快速生成接口的描述,并且提供对接口的测试能力;PxR28资讯网——每日最新资讯28at.com

Junit测试:通过编写代码的方式对接口进行测试,从而完成对接口的检查和验证,并且可以不入侵原代码结构;PxR28资讯网——每日最新资讯28at.com

二、工程搭建

1、工程结构

图片图片PxR28资讯网——每日最新资讯28at.com

2、依赖管理

<!-- 基础框架组件 --><dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-web</artifactId>    <version>${spring-boot.version}</version></dependency><!-- 接口文档组件 --><dependency>    <groupId>org.springdoc</groupId>    <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>    <version>${springdoc.version}</version></dependency><!-- 前端页面组件 --><dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-thymeleaf</artifactId>    <version>${spring-boot.version}</version></dependency><!-- 单元测试组件 --><dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-test</artifactId>    <version>${spring-boot.version}</version>    <exclusions>        <exclusion>            <groupId>org.slf4j</groupId>            <artifactId>slf4j-api</artifactId>        </exclusion>    </exclusions></dependency><dependency>    <groupId>junit</groupId>    <artifactId>junit</artifactId>    <version>${junit.version}</version></dependency>

三、Web开发

1、接口开发

编写四个简单常规的接口,从对资源操作的角度,也就是常说的:增Post、删Delete、改Put、查Get,并且使用了swagger注解,可以快速生成接口文档;PxR28资讯网——每日最新资讯28at.com

@RestController@Tag(name = "Rest接口")public class RestWeb {    @Operation(summary = "Get接口")    @GetMapping("rest/get/{id}")    public String restGet(@PathVariable Integer id) {        return "OK:"+id;    }    @Operation(summary = "Post接口")    @PostMapping("/rest/post")    public String restPost(@RequestBody ParamBO param){        return "OK:"+param.getName();    }    @Operation(summary = "Put接口")    @PutMapping("/rest/put")    public String restPut(@RequestBody ParamBO param){        return "OK:"+param.getId();    }    @Operation(summary = "Delete接口")    @DeleteMapping("/rest/delete/{id}")    public String restDelete(@PathVariable Integer id){        return "OK:"+id;    }}

2、页面交互

对于服务端开发来说,在部分场景下是需要进行简单的页面开发的,比如通过页面渲染再去生成文件,或者直接通过页面填充邮件内容等;PxR28资讯网——每日最新资讯28at.com

数据接口PxR28资讯网——每日最新资讯28at.com

@Controllerpublic class PageWeb {    @RequestMapping("/page/view")    public ModelAndView pageView (HttpServletRequest request){        ModelAndView modelAndView = new ModelAndView() ;        // 普通参数        modelAndView.addObject("name", "cicada");        modelAndView.addObject("time", "2023-07-12");        // 对象模型        modelAndView.addObject("page", new PageBO(7,"页面数据模型"));        // List集合        List<PageBO> pageList = new ArrayList<>() ;        pageList.add(new PageBO(1,"第一页"));        pageList.add(new PageBO(2,"第二页"));        modelAndView.addObject("pageList", pageList);        // Array数组        PageBO[] pageArr = new PageBO[]{new PageBO(6,"第六页"),new PageBO(7,"第七页")} ;        modelAndView.addObject("pageArr", pageArr);        modelAndView.setViewName("/page-view");        return modelAndView ;    }}

页面解析:分别解析了普通参数,实体对象,集合容器,数组容器等几种数据模型;PxR28资讯网——每日最新资讯28at.com

<style="text-align: center">    <hr/>    <h5>普通参数解析</h5>    姓名:<span th:text="${name}"></span>    时间:<span th:text="${time}"></span>    <hr/>    <h5>对象模型解析</h5>    整形:<span th:text="${page.getKey()}"></span>    字符:<span th:text="${page.getValue()}"></span>    <hr/>    <h5>集合容器解析</h5>    <table style="margin:0 auto;width: 200px">        <tr>            <th>Key</th>            <th>Value</th>        </tr>        <tr th:each="page:${pageList}">            <td th:text="${page.getKey()}"></td>            <td th:text="${page.getValue()}"></td>        </tr>    </table>    <hr/>    <h5>数组容器解析</h5>    <table style="margin:0 auto;width: 200px">        <tr>            <th>Key</th>            <th>Value</th>        </tr>        <tr th:each="page:${pageArr}">            <td th:text="${page.getKey()}"></td>            <td th:text="${page.getValue()}"></td>        </tr>    </table>    <hr/></div>

效果图展示PxR28资讯网——每日最新资讯28at.com

图片图片PxR28资讯网——每日最新资讯28at.com

四、拦截器

1、拦截器定义

通过实现HandlerInterceptor接口,完成对两个拦截器的自定义,请求在访问服务时,必须通过两个拦截器的校验;PxR28资讯网——每日最新资讯28at.com

/** * 拦截器一 */public class HeadInterceptor implements HandlerInterceptor {    private static final Logger log  = LoggerFactory.getLogger(HeadInterceptor.class);    @Override    public boolean preHandle(HttpServletRequest request, HttpServletResponse response,                             Object handler) throws Exception {        log.info("HeadInterceptor:preHandle");        Iterator<String> headNames = request.getHeaderNames().asIterator();        log.info("request-header");        while (headNames.hasNext()){            String headName = headNames.next();            String headValue = request.getHeader(headName);            System.out.println(headName+":"+headValue);        }        // 放开拦截        return true;    }    @Override    public void postHandle(HttpServletRequest request,HttpServletResponse response,                           Object handler, ModelAndView modelAndView) throws Exception {        log.info("HeadInterceptor:postHandle");    }    @Override    public void afterCompletion(HttpServletRequest request,HttpServletResponse response,                                Object handler, Exception e) throws Exception {        log.info("HeadInterceptor:afterCompletion");    }}/** * 拦截器二 */public class BodyInterceptor implements HandlerInterceptor {    private static final Logger log  = LoggerFactory.getLogger(BodyInterceptor.class);    @Override    public boolean preHandle(HttpServletRequest request,HttpServletResponse response,                             Object handler) throws Exception {        log.info("BodyInterceptor:preHandle");        Iterator<String> paramNames = request.getParameterNames().asIterator();        log.info("request-param");        while (paramNames.hasNext()){            String paramName = paramNames.next();            String paramValue = request.getParameter(paramName);            System.out.println(paramName+":"+paramValue);        }        // 放开拦截        return true;    }    @Override    public void postHandle(HttpServletRequest request,HttpServletResponse response,                           Object handler, ModelAndView modelAndView) throws Exception {        log.info("BodyInterceptor:postHandle");    }    @Override    public void afterCompletion(HttpServletRequest request,HttpServletResponse response,                                Object handler, Exception e) throws Exception {        log.info("BodyInterceptor:afterCompletion");    }}

2、拦截器配置

自定义拦截器之后,还需要添加到web工程的配置文件中,可以通过实现WebMvcConfigurer接口,完成自定义的配置添加;PxR28资讯网——每日最新资讯28at.com

@Configurationpublic class WebMvcConfig implements WebMvcConfigurer {    /**     * 添加自定义拦截器     */    @Override    public void addInterceptors(InterceptorRegistry registry) {        registry.addInterceptor(new HeadInterceptor()).addPathPatterns("/**");        registry.addInterceptor(new BodyInterceptor()).addPathPatterns("/**");    }}

五、测试工具

1、Swagger接口

添加上述的springdoc依赖之后,还可以在配置文件中简单定义一些信息,访问IP:端口/swagger-ui/index.html即可;PxR28资讯网——每日最新资讯28at.com

@Configurationpublic class WebMvcConfig implements WebMvcConfigurer {    /**     * 接口文档配置     */    @Bean    public OpenAPI openAPI() {        return new OpenAPI()                .info(new Info().title("【boot-web】").description("Rest接口文档-2023-07-11")                .version("1.0.0"));    }}

图片图片PxR28资讯网——每日最新资讯28at.com

2、Junit测试

在个人的习惯上,Swagger接口文档更偏向在前后端对接的时候使用,而Junit单元测试更符合开发的时候使用,这里是对RestWeb中的接口进行测试;PxR28资讯网——每日最新资讯28at.com

@RunWith(SpringRunner.class)@SpringBootTest@AutoConfigureMockMvcpublic class RestWebTest {    @Autowired    private MockMvc mockMvc;    @Test    public void testGet () throws Exception {        // GET接口测试        MvcResult mvcResult = mockMvc                .perform(MockMvcRequestBuilders.get("/rest/get/1"))                .andReturn();        printMvcResult(mvcResult);    }    @Test    public void testPost () throws Exception {        // 参数模型        JsonMapper jsonMapper = new JsonMapper();        ParamBO param = new ParamBO(null,"单元测试",new Date()) ;        String paramJson = jsonMapper.writeValueAsString(param) ;        // Post接口测试        MvcResult mvcResult = mockMvc.perform(MockMvcRequestBuilders.post("/rest/post")                .contentType(MediaType.APPLICATION_JSON)                .accept(MediaType.APPLICATION_JSON).content(paramJson)).andReturn();        printMvcResult(mvcResult);    }    @Test    public void testPut () throws Exception {        // 参数模型        JsonMapper jsonMapper = new JsonMapper();        ParamBO param = new ParamBO(7,"Junit组件",new Date()) ;        String paramJson = jsonMapper.writeValueAsString(param) ;        // Put接口测试        MvcResult mvcResult = mockMvc.perform(MockMvcRequestBuilders.put("/rest/put")                .contentType(MediaType.APPLICATION_JSON)                .accept(MediaType.APPLICATION_JSON).content(paramJson)).andReturn();        printMvcResult(mvcResult);    }    @Test    public void testDelete () throws Exception {        // Delete接口测试        MvcResult mvcResult = mockMvc                .perform(MockMvcRequestBuilders.delete("/rest/delete/2"))                .andReturn();        printMvcResult(mvcResult);    }    /**     * 打印【MvcResult】信息     */    private void printMvcResult (MvcResult mvcResult) throws Exception {        System.out.println("请求-URI【"+mvcResult.getRequest().getRequestURI()+"】");        System.out.println("响应-status【"+mvcResult.getResponse().getStatus()+"】");        System.out.println("响应-content【"+mvcResult.getResponse().getContentAsString(StandardCharsets.UTF_8)+"】");    }}

六、参考源码

文档仓库:https://gitee.com/cicadasmile/butte-java-note源码仓库:https://gitee.com/cicadasmile/butte-spring-parent

本文链接:http://www.28at.com/showinfo-26-5120-0.htmlSpringBoot3之Web编程

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 只会使用Swagger?不妨试试YApi进行接口文档管理

下一篇: 弹性研发团队的探索

标签:
  • 热门焦点
  • 消息称迪士尼要拍真人版《魔发奇缘》:女主可能也找黑人演员

    消息称迪士尼要拍真人版《魔发奇缘》:女主可能也找黑人演员

    8月5日消息,迪士尼确实有点忙,忙着将不少动画改成真人版,继《美人鱼》后,真人版《白雪公主》、《魔发奇缘》也在路上了。据外媒消息称,迪士尼将打造真人版
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • 把LangChain跑起来的三个方法

    把LangChain跑起来的三个方法

    使用LangChain开发LLM应用时,需要机器进行GLM部署,好多同学第一步就被劝退了,那么如何绕过这个步骤先学习LLM模型的应用,对Langchain进行快速上手?本片讲解3个把LangChain跑起来
  • 学习JavaScript的10个理由...

    学习JavaScript的10个理由...

    作者 | Simplilearn编译 | 王瑞平当你决心学习一门语言的时候,很难选择到底应该学习哪一门,常用的语言有Python、Java、JavaScript、C/CPP、PHP、Swift、C#、Ruby、Objective-
  • 这款新兴工具平台,让你的电脑效率翻倍

    这款新兴工具平台,让你的电脑效率翻倍

    随着信息技术的发展,我们获取信息的渠道越来越多,但是处理信息的效率却成为一个瓶颈。于是各种工具应运而生,都在争相解决我们的工作效率问题。今天我要给大家介绍一款效率
  • 电视息屏休眠仍有网络上传 爱奇艺被质疑“薅消费者羊毛”

    电视息屏休眠仍有网络上传 爱奇艺被质疑“薅消费者羊毛”

    记者丨宁晓敏 见习生丨汗青出品丨鳌头财经(theSankei) 前不久,爱奇艺发布了一份亮眼的一季报,不仅营收和会员营收创造历史最佳表现,其运营利润也连续6个月实现增长。自去年年初
  • 破圈是B站头上的紧箍咒

    破圈是B站头上的紧箍咒

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之每年的暑期档都少不了瞄准追剧女孩们的古偶剧集,2021年有优酷的《山河令》,2022年有爱奇艺的《苍兰诀》,今年却轮到小破站抓住了追
  • 2天涨粉255万,又一赛道在抖音爆火

    2天涨粉255万,又一赛道在抖音爆火

    来源:运营研究社作者 | 张知白编辑 | 杨佩汶设计 | 晏谈梦洁这个暑期,旅游赛道彻底火了:有的「地方」火了&mdash;&mdash;贵州村超旅游收入 1 个月超过 12 亿;有的「博主」火了&m
  • 到手价3099元起!iQOO Neo8 Pro今日首销:安卓性能最强旗舰

    到手价3099元起!iQOO Neo8 Pro今日首销:安卓性能最强旗舰

    5月23日,iQOO如期举行了新品发布会,全新的iQOO Neo8系列也正式与大家见面,包含iQOO Neo8和iQOO Neo8 Pro两个版本,其中标准版搭载高通骁龙8+,而Pro版更
Top