模型:一个或多个 JavaBean 对象,用于存储数据(实体模型,由 JavaBean 类创建)和处理业务逻辑(业务模型,由一般的 Java 类创建)。
视图:一个或多个 JSP 页面,向控制器提交数据和为模型提供数据显示,JSP 页面主要使用 HTML 标记和 JavaBean 标记来显示数据。
控制器:一个或多个 Servlet 对象,根据视图提交的请求进行控制,即将请求转发给处理业务逻辑的 JavaBean,并将处理结果存放到实体模型 JavaBean 中,输出给视图显示。
返回String资源
-
返回值类型为String 就表示资源为路径 (静态资源和服务器资源都可以)
-
演示返回静态资源
- 创建静态资源
- @Controller中配置web请求
@RequestMapping(value = “test4”)
public String test4() {
//返回路径,不带/:以当前请求路径为相对位置,查找同一级资源
// 带/,会去掉这个当前路径,以项目的部署路径为相对位置
return “/ok.html”;
}
- 访问
转发路径与重定向写法
返回路径,不带/:以当前请求路径为相对位置,查找同一级资源 , 带/,会去掉这个当前路径,以项目的部署路径为相对位置.
- 转发写法 : 返回"forward:资源路径"
@RequestMapping(value = “test5”)
public String test5() {
return “forward:test1”;
}
- 重定向写法: 返回"redirect:资源路径"
@RequestMapping(value = “test6”)
public String test6() {
return “redirect:test2”;
}
返回json数据资源
- 使用@ResponseBody注解 返回application/json的数据格式 返回值会自动序列化为json字符串
@RequestMapping(value = “/test1”, produces = MediaType.APPLICATION_JSON_UTF8_VALUE, method = {RequestMethod.GET})
//设置web请求的访问路径
// produces设置返回的数据格式是uft-8
// method设置可以访问的http方法为get
@ResponseBody
//设置以json格式返回结果
public Object test1() {
return test1;
}
- 注意如果返回的是null 或者已经是字符串 即使使用@ResponseBody注解, 不会自动序列化为json格式
@RequestMapping(“/test4”)
@ResponseBody
public Object test4(){
return null;//响应体为空===>配置ControllerAdvice时,不会进入重写响应体的方法
}
@RequestMapping(“/test5”)
@ResponseBody
public Object test5(){
return “ok”;//返回字符串,响应数据格式不再是application/json,而是text/plain,字符串内容
}
使用@PathVariable获取占位符路径变量
- URL中定义{变量名}作为占位符 ,使用@PathVariable获取对应的变量
//url为rest风格的请求
@RequestMapping(value = “test7/{key}”)//路径中使用变量占位符
@ResponseBody
public Object test7(@PathVariable(“key”) Integer k) { //如果类型不匹配会抛出异常
return k;
}
使用@RequestParam
- 使用@RequestParam可以获取URL中请求的数据
//请求GET /per/test8?k1=1&k2=2&k3=3
@RequestMapping(value = “test8”, method = {RequestMethod.GET})
@ResponseBody
public Object test8( //可以匹配url中的参数,请求体k1=v1&k2=v2格式的数据
//x-www-form-urlencoded和form-data的请求数据格式,都可以
@RequestParam(“k1”) String ksss,//写全的做法,通过注解值为key查找请求数据
@RequestParam String k2,//省略注解值的做法,默认以变量名为key查找请求数据
String k3 //最省略的做法:默认就是@RequestParam注解
) {
return ksss + “,” + k2 + “,” + k3;
}
- 使用@RequestParam定义的参数类型, 可以是基础类型 包装类型 自定义类型 , 都可以有多个参数, 自定义类型是通过请求数据的key映射到类型的字段中的
//请求数据自动映射到参数类型的属性中:/per/test9?name=詹姆斯&Id=123456789&age=37
//如果使用@RequestParam Person person 这种格式是不可以的因为这样就没有了自动映射
//这种是直接在parameter中获取person
@RequestMapping(value = “test9”, produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
@ResponseBody
public Object test9(Person person) {
return person;
}
讲解@RequestParam 和 @PathVariable 的差异
- @RequestParam 和 @PathVariable 注解是用于从request中接收请求的,两个都可以接收参数,关键点不同的是@RequestParam 是从request里面拿取值,而 @PathVariable 是从一个URI模板里面来填充.@RequestParam.
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
最后
基础知识是前端一面必问的,如果你在基础知识这一块翻车了,就算你框架玩的再6,webpack、git、node学习的再好也无济于事,因为对方就不会再给你展示的机会,千万不要因为基础错过了自己心怡的公司。前端的基础知识杂且多,并不是理解就ok了,有些是真的要去记。当然了我们是牛x的前端工程师,每天像背英语单词一样去背知识点就没必要了,只要平时工作中多注意总结,面试前端刷下题目就可以了。
什么?你问面试题资料在哪里,这不是就在你眼前吗(滑稽
解视频,并且会持续更新!**
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
[外链图片转存中…(img-qUUhf5fZ-1713558845543)]
最后
基础知识是前端一面必问的,如果你在基础知识这一块翻车了,就算你框架玩的再6,webpack、git、node学习的再好也无济于事,因为对方就不会再给你展示的机会,千万不要因为基础错过了自己心怡的公司。前端的基础知识杂且多,并不是理解就ok了,有些是真的要去记。当然了我们是牛x的前端工程师,每天像背英语单词一样去背知识点就没必要了,只要平时工作中多注意总结,面试前端刷下题目就可以了。
什么?你问面试题资料在哪里,这不是就在你眼前吗(滑稽