spring开发篇二:@RequestParam和@RequestBody与前端Get和Post请求传参详解附中文乱码解决方法

2023-05-16

1.先入为主:

1.1.在spring的controller中注解写法规则:

(a)同一个请求中,只能有一个@RequestBody;

(b)同一个请求中,可以有多个@RequestParam;

(c)同一个请求中,可以同时存在@RequestBody和@RequestParam;


1.2.前端后参数传入和接收规则:

(a)@RequestParam()指定的参数类型:普通元素、数组、集合等等

(b)当@RequestBody与@RequestParam()同时使用时,原SpringMVC接收参数的机制不变,RequestBody接收的是请求体里面的数据;

而RequestParam接收的是请求行中key-value参数它会被springMVC的切面进行处理从而可以用普通元素、数组、集合、对象等接收

(c)如果参数是放在请求体中:后台要用@RequestBody才能接收到

(d)如果参数放在请求行以?key=value形式传递:后台要用@RequestParam才能接收,或则形参不加@RequestParam注解也能接收。
         例如:
              @RequestParam() String xx             前端xx=StringValue

                                              String xx             前端xx=StringValue
              @RequestParam() int xx                   前端xx=intValue
              @RequestParam() Integer xx           前端xx=intValue
              @RequestParam() double xx           前端xx=10.12
              @RequestParam() boolean xx          前端xx=true false
              @RequestParam() Map xx                前端xx={k1=12,ssd="sd"}
              @RequestParam() List xx                 前端xx={k1=12,ssd="sd00"},{k1=1223,ssd="sd11"}.......


(e)如果参数前指定注解@RequestParam(value="key"),那么前端请求行中必须有对应的key(login.do?key=xxxx)

     例如:              

            public String login(@RequestParam(value = "token",required = false)String token)

            其中,required默认是true,请求行参数中必须有token=xx否则报400错误,若required设置为false则可以不传token。

(f)如果参数前指定注解@RequestParam(value="key"),那么就前端请求行中可以有也可以没有对应的key名字,若有key,则会自动匹配;若没有,请求也能正确发送。

(g)如果参数指定注解@RequestBody且参数是一个POJO对象或Map<String,Object>,那么,请求头必须设置application/json且前端请求体数据格式的字段名称必须与POJO类字段名称一致,否则报错400,前端传入的参数字段数量必须少于等于POJO类的字段数量

 

2.实验过程:

http请求规范说明:
常规操作下,Get在
请求行以?key=value形式传递参数(value可以是:[1,2,3],{a=s,k=oom,p="x"},{as:"xx",moo:00}等等);Post请求在请求体传递参数(string、json均可)。而经测试,Get其实也可以在请求体中传递参数的,但由于可能存在某些情况
下服务器不支持,如:缓存代理服务器。因此,我们通常在请求体中传递参数还是会使用Post请求方式。

上述引申的两个概念(请求行和请求体)请自行问度娘。

因此,下面的实验场景Get方式均不在请求体中传参。而post方式可在请求行也可在请求体传参。(牢记!)


前后端处理请求的各个场景:


场景1:


后台:
@ResponseBody
public String testAny1(String token)

请求:
get无参数访问:访问正常,响应正常,接收参数token为null
post无参数访问:访问正常,响应正常,接收参数token为null
get传参访问,请求行?token=xxx访问:访问正常,响应正常,接收参数token正常
post传参访问,请求行参数?token=xxx访问:访问正常,响应正常,接收参数token正常
post传参访问,请求体参数token访问:访问正常,响应正常,接收参数token为null
post传参访问,请求体参数{token:xxx}访问:访问正常,响应正常,接收参数token为null


正确使用小结:参数未指定任何注解时,请求使用Get或Post均可,token必须在请求行以?token=xx方式传递才能获取到,若不传递token参数不会报错。
注意:请求头使用默认即可,若设置其他请求头也不会报错

场景2:


后台:
@ResponseBody
public String testAny2(@RequestParam String token)

请求:
get无参数访问:报错400,(HTTP Status 400 - Required String parameter 'token' is not present)
post无参数访问:报错400,(HTTP Status 400 - Required String parameter 'token' is not present)
get传参访问,请求行?token=xxx访问:访问正常,响应正常,接收参数token正常
post传参访问,请求行参数?token=xxx访问:访问正常,响应正常,接收参数token正常
post传参访问,请求体参数token访问:报错400,(HTTP Status 400 - Required String parameter 'token' is not present)
post传参访问,请求体参数{token:xxx}访问:报错400,(HTTP Status 400 - Required String parameter 'token' is not present)

正确使用小结:参数指定@RequestParam注解时,请求使用Get或Post均可,token必须传递且在请求行以?token=xx方式传递才不会报错且后台才能获取到。
注意:请求头使用默认即可,若设置其他请求头也不会报错

场景3:


后台:
@ResponseBody
public String testAny3(@RequestParam("token") String token)

请求:
get无参数访问:报错400,(HTTP Status 400 - Required String parameter 'token' is not present)
post无参数访问:报错400,(HTTP Status 400 - Required String parameter 'token' is not present)
get传参访问,请求行?token=xxx访问:访问正常,响应正常,接收参数token正常
post传参访问,请求行参数?token=xxx访问:访问正常,响应正常,接收参数token正常
post传参访问,请求体参数token访问:报错400,(HTTP Status 400 - Required String parameter 'token' is not present)
post传参访问,请求体参数{token:xxx}访问:报错400,(HTTP Status 400 - Required String parameter 'token' is not present)

正确使用小结:参数指定@RequestParam("token")注解时,请求使用Get或Post均可,token必须传递且在请求行以?token=xx方式传递才不会报错且后台才能获取到。
注意:请求头使用默认即可,若设置其他请求头也不会报错

场景4:


后台:
@ResponseBody
public String testAny4(@RequestBody String params)

请求:
get无参数访问:访问正常,响应正常,接收参数params为""
post无参数访问:访问正常,响应正常,接收参数params为""
get传参访问,请求行?params=xxx访问:访问正常,响应正常,接收参数为""
post传参访问,请求行?params=xxx访问:访问正常,响应正常,接收参数为""
post传参访问,请求体参数params(String)访问:访问正常,响应正常,接收参数为String值
post传参访问,请求体参数params(json)访问:访问正常,响应正常,接收参数为jsonString值

设置请求头Content-Type:application/json,报错:报错400,The request sent by the client was syntactically incorrect.
这里使用使用text请求头或默认请求头

正确使用小结:参数指定@RequestBody注解时,请求使用Get或Post均可,params必须在请求体传递后台才能获取到。(推荐post方式发送带有请求体参数请求)
注意:请求头使用默认即可,若设置Content-Type:application/json或Content-Type:text/html请求头会报错400,设置为其余请求头不会报错。

场景5:


后台:
@ResponseBody
public RequestPagination testAny5(@RequestBody RequestPagination params)

请求:
get无参数访问:肯定报错415或400,
post无参数访问:肯定报错415或400,
get传参访问,请求行?params=xxx访问:肯定报错415或400,
post传参访问,请求行?params=xxx访问:肯定报错415或400,
post传参访问,请求体参数params(String)访问:肯定报错415或400,
post传参访问,请求体参数params(json)访问:可能报错415或400,

未设置请求头Content-Type:application/json:报错415,The server refused this request because the request entity is in a format not supported by the requested resource for the requested method
设置请求头Content-Type:application/json,但不在请求体传参或传参格式不正确则报错:报错400,The request sent by the client was syntactically incorrect.

请求头Content-Type:application/json,设置后,在请求体传入正确格式json(字段与RequestPagination字段对应)才能访问正常,响应正常且参数接收正常。

正确使用小结:参数指定@RequestBody注解且参数为pojo对象时,请求使用Get或Post均可,params必须在请求体并且以json形式保持字段与后台参数pojo对象字段一致,才不会报错后台才能获取到。(推荐post方式发送带有请求体参数请求)。如果请求体中某个字段value没有值,那么可以不写入请求体的json中。
注意:请求头使用Content-Type:application/json,若设置其他请求头会报错415。

场景6:


后台:
@ResponseBody
public String testAny6(@RequestBody String params,@RequestParam("token") String token)

请求:
设置请求头Content-Type:application/json:
get无参数访问:肯定报错400,The request sent by the client was syntactically incorrect
post无参数访问:肯定报错400,The request sent by the client was syntactically incorrect
get传参访问,请求行?params=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求行?params=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(String)访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(json)访问:肯定报错400,The request sent by the client was syntactically incorrect

设置请求头Content-Type:text 或 Content-Type:text/plain 或 默认:
get无参数访问:HTTP Status 400 - Required String parameter 'token' is not present,
post无参数访问:HTTP Status 400 - Required String parameter 'token' is not present
get传参访问,请求行?token=xxx&params=xx访问:正常访问、响应、接收参数params为""
post传参访问,请求行?token=xxx&params=xxx访问:正常访问、响应、接收参数params为""
post传参访问,请求体参数params(String)且请求行参数token=xxx访问:正常访问、响应、接收参数正常。
post传参访问,请求体参数params(json)且请求行参数token=xxx访问:正常访问、响应、接收参数正常。


正确使用小结:同时存在参数指定@RequestBody注解,和参数指定@RequestParam("xxx")注解时候,请求使用Get或Post均可,params必须在请求体传递并且在请求行以?token=xx传递,才不会报错后台才能获取到两参数。(推荐post方式发送带有请求体参数请求)
注意:请求头使用默认即可,若设置Content-Type:application/json或Content-Type:text/html请求头会报错400,设置为其余请求头不会报错。

场景7:


后台:
@ResponseBody
public String testAny7(@RequestBody RequestPagination params,@RequestParam("token") String token)

请求:
设置请求头Content-Type:application/json:
get无参数访问:肯定报错400,The request sent by the client was syntactically incorrect
post无参数访问:肯定报错400,The request sent by the client was syntactically incorrect
get传参访问,请求行?params=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求行?params=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(String)访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(json)访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(json且字段与RequestPagination字段对应),且请求行参数token=xxx访问才能访问正常,响应正常且参数接收正常。


设置请求头Content-Type:text 或 Content-Type:text/plain 或 默认:
get无参数访问:415,The server refused this request because the request entity is in a format not supported by the requested resource for the requested method
post无参数访问:同上
get传参访问,请求行?token=xxx&params=xx访问:同上
post传参访问,请求行?token=xxx&params=xxx访问:同上
post传参访问,请求体参数params(String)且请求行参数token=xxx访问:同上
post传参访问,请求体参数params(json)且请求行参数token=xxx访问:同上


正确使用小结:同时存在参数指定@RequestBody注解且为pojo对象,和参数指定@RequestParam("xxx")注解时候,请求使用Get或Post均可,params必须在请求体并且以json形式保持字段与后台参数pojo对象字段一致并且在请求行以?token=xx传递,才不会报错后台才能获取到两参数。(推荐post方式发送带有请求体参数请求)。如果请求体中某个字段value没有值,那么可以不写入请求体的json中。
注意:请求头使用Content-Type:application/json,若设置其他请求头会报错415。

场景8:


后台:
@ResponseBody
public String testAny8(@RequestBody String params,String token)

请求:
设置请求头Content-Type:application/json:
get无参数访问:肯定报错400,The request sent by the client was syntactically incorrect
post无参数访问:肯定报错400,The request sent by the client was syntactically incorrect
get传参访问,请求行?params=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求行?params=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(String)访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(json)访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(json),且请求行参数token=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect


设置请求头Content-Type:text 或 Content-Type:text/plain 或 默认:
get无参数访问:请求访问正常、响应正常。
post无参数访问:请求访问正常、响应正常。
get传参访问,请求行?token=xxx&params=xx访问:请求访问正常、响应正常,token接收正常,params接收为""
post传参访问,请求行?token=xxx&params=xxx访问:请求访问正常、响应正常,token接收正常,params接收为""
post传参访问,请求体参数params(String或json)访问:请求访问正常、响应正常,token接收为null,params接收正常
post传参访问,请求体参数params(String或json)且请求行参数token=xxx访问:请求访问正常、响应正常,token接收为正常,params接收正常

正确使用小结:同时存在参数指定@RequestBody注解,和参数指定token时候,请求使用Get或Post均可,params必须在请求体传递而在请求行中传递?token=xx,才能获取到两参数。(推荐post方式发送带有请求体参数请求),这里值得留意的是?token=xx也可以不传递,不会报错。
注意:请求头使用默认即可,若设置Content-Type:application/json或Content-Type:text/html请求头会报错400,设置为其余请求头不会报错。

场景9:


后台:
@ResponseBody
public String testAny9(@RequestBody String params,@RequestParam String token)

请求:    
设置请求头Content-Type:application/json:
get无参数访问:肯定报错400,The request sent by the client was syntactically incorrect
post无参数访问:肯定报错400,The request sent by the client was syntactically incorrect
get传参访问,请求行?params=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求行?params=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(String)访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(json)访问:肯定报错400,The request sent by the client was syntactically incorrect
post传参访问,请求体参数params(json),且请求行参数token=xxx访问:肯定报错400,The request sent by the client was syntactically incorrect


设置请求头Content-Type:text 或 Content-Type:text/plain 或 默认:
get无参数访问:HTTP Status 400 - Required String parameter 'token' is not present
post无参数访问:HTTP Status 400 - Required String parameter 'token' is not present
get传参访问,请求行?token=xxx&params=xx访问:请求访问正常、响应正常,token接收正常,params接收为""
post传参访问,请求行?token=xxx&params=xxx访问:请求访问正常、响应正常,token接收正常,params接收为""
post传参访问,请求体参数params(String或json)访问:HTTP Status 400 - Required String parameter 'token' is not present
post传参访问,请求体参数params(String或json)且请求行参数token=xxx访问:请求访问正常、响应正常,token接收为正常,params接收正常

正确使用小结:同时存在参数指定@RequestBody注解,和参数指定token时候,请求使用Get或Post均可,params必须在请求体传递而在请求行中传递?token=xx,才能获取到两参数。(推荐post方式发送带有请求体参数请求)。
注意:请求头使用默认即可,若设置Content-Type:application/json或Content-Type:text/html请求头会报错400,设置为其余请求头不会报错。

 

3.补充说明响应返回场景

场景1:String + @ResponseBody

@ResponseBody
public String testAny9()

将以字符串String形式传给HttpServletResponse返回给前端

 

场景2:对象 + @ResponseBody

@ResponseBody
public User testAny9()

先自动转换成JSON形式传给HttpServletResponse返回给前端,json对象

场景3:String
public String testAny9()

寻找视图进行跳转

场景4:void + request+response
public String testAny9(HttpServletRequest request,HttpServletResponse response)

方法体中将使用request获取参数、response跳转或输出数据给前端

场景5:ModelAndView

public ModelAndView(){

    List<String> dataList = new ArrayList<String>(); 
    ModelAndView modelAndView = new ModelAndView();
    //将数据放入modelAndView对象
    modelAndView.addObject("dataList", dataList);
    //将返回的逻辑视图名称放入modelAndView对象
    modelAndView.setViewName("home");

    return modelAndView;
}

前端通过request.getAttribute("dataList")或${dataList}获取传递的数据

 

 

总结

400错误:参数格式不对,例如:{id:"dds"} 正解:{"id":"dds"};例如:后台封装的对象没有参数中的字段等等。

406错误:后台返回给前端的是对象而非字符串,需配置下json的转换。

 

4.中文乱码问题


后台代码:
@RequestMapping(value = "/demo1")
@ResponseBody
public String demo1(){
    return "我是中文测试";
}

就是这样一个简单的方法,直接返回字符串, 但是在界面上就发现中文乱码了,配置文件中<mvc:annotation-driven/>的形式开启的.

其实这个,也不涉及到Json字符串的乱码问题,因为没有使用到json的HttpMessageConverter.

 
解决方案一:

<mvc:annotation-driven conversion-service="conversionService">
    <mvc:message-converters register-defaults="true">
        <bean class="org.springframework.http.converter.StringHttpMessageConverter">
            <property name="defaultCharset" value="UTF-8"/>
            <property name="writeAcceptCharset" value="false"/>
        </bean>
    </mvc:message-converters>
</mvc:annotation-driven>

说明:替换其中的StringHttpMessageConverter,它是用来将String写到response中;

修改的两个属性说明:defaultCharset改为UTF-8(项目字符集)即可正确显示中文,因为默认是ISO-8859-1格式;

writeAcceptCharset修改为false,即可看到响应头清爽很多,节省资源;

 
解决方案二:

@RequestMapping(value = "/demo1",produces = {"text/plain;charset=utf-8","text/html;charset=utf-8"})
    @ResponseBody
    public String demo1(){
        return "我是中文测试";
    }

说明:指定响应的字符集为utf-8,就不会再用StringHttpMessageConverter的字符集了;

 
解决方案三:

@RequestMapping(value = "/demo1",produces = {"application/json;charset=utf-8"})
@ResponseBody
public String demo1() throws JsonProcessingException {
    return new ObjectMapper().writeValueAsString("我是中文测试");
}

说明:自己转换成JSON写回客户端,因为返回值类型还是写的String,所以仍然使用的是StringHttpMessageConverter,
但是return  “我是中文测试” ; 这个返回值不是JSON类型的,
客户端无法解析(即使指定了produces也没用);所以需要我们手动转换成JSON格式字符串,这样客户端接收到的就是JSON格式的响应了.

 
 
比较说明:
解决方案一、二返回给浏览器的类型都是text/plain或 text/html类型的文本,
而解决方案三返回的是application/json类型,但是返回结果也不是JSON,所以在我看来三种方式区别都不大吧。

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

spring开发篇二:@RequestParam和@RequestBody与前端Get和Post请求传参详解附中文乱码解决方法 的相关文章

  • github pages搭建博客的域名解析(简单有效)

    折腾了一个小时终于把域名解析弄好了 xff0c 还顺带了解了不少关于http的知识 xff0c 亲手实践还是最有效的方法 xff0c 哈哈 这里记录一下自己的步骤 注意 xff1a 如果只需要解析主域名 xff0c 那么只做第一步就行 xf
  • 用nginx实现反向代理,实现外网访问内网的服务

    环境背景 xff0c 服务器为Ubuntu xff1a 一台可以连接公网和内网的服务器A xff0c 公网IP地址 xff1a 61 174 xff0c 另一台内网服务器B上安装jenkins服务 xff0c 内网的IP地址192 168
  • g++ is not recognized as an internal or external command解决方法,初用MinGW碰到的坑

    之前一直用Qt或者CodeBlocks上带的MinGW xff0c 这次自己装了一个 xff0c 碰到一堆问题 一 在用g 43 43 编译的时候报错 xff1a stddef h No such file or directory std
  • Ubuntu 20.04: harfbuzz version too old解决方法

    参考链接 xff1a unix stackexchange com 现象 在ubuntu20 04上安装了Ao xff08 可以看做Microsoft todo的linux版 xff09 xff0c 从终端启动时报错 xff1a Faile
  • 图像处理:理想低通滤波器、butterworth滤波器(巴特沃斯)、高斯滤波器实现(python)

    对图像进行频域滤波的几种常用低通滤波器 xff0c python opencv实现 xff1a 低通滤波器 xff08 Low pass filter xff09 容许低频信号通过 xff0c 但减弱频率高于截止频率的信号的通过 对于不同滤
  • 图像处理:迭代阈值分割算法实现(python)

    使用迭代的方法对图像全局的阈值进行估计 xff0c 效果优于传统的双峰阈值分割 算法流程 xff1a 给定初始值 T 0 T 0 T 0 xff0c 最好是全局灰度平均值根据阈值
  • filter- 条件合并

    发现一个很好用的用法 可以根据前端传来的数据判断 xff0c 数据筛选的条件 可以先新建一个列表 xff1a filter 61 根据条件 xff0c 给这个列表加条件 比如 xff1a if status filter append Us
  • HC-05蓝牙模块主从连接配置(无坑)

    做课程设计要用到两个HC 05连接 xff0c 之前用过HC 06 xff0c 拿原来那个方法配还是有些坑 xff0c 搞了一下午最后还是成功了 尝试了两个方案 xff0c 一是用usb转TTL配置 xff1b 二是用Arduino xff
  • PyQt 自定义气泡弹窗

    效果图 xff1a 用来做弹窗提醒 xff0c 气泡弹窗会自动关闭 xff0c 持续时间1600ms xff0c 在750ms时开始逐渐透明 xff0c 1600ms时消失 窗口继承的是QDialog 设置背景透明 无标题栏 无边框 xff
  • pyinstaller打包PyQt程序 + 制作安装包

    打包发布PyQt5程序 xff0c 制作安装文件 以自己的密码管理器为例 用到的工具 xff1a 平台 xff1a Windows10python 3 7 6 xff08 安装好所需的包 xff09 pyinstallerupx xff08
  • 树莓派开机自动发送邮件脚本

    开机联网后自动获取本机内网IP xff0c 并通过邮件或者server酱发送自己的内网IP span class token keyword import span smtplib span class token keyword from
  • C++ STL Map按照value排序

    xff08 记录一下 xff09 STL的map底层实现一般是红黑树 xff0c 会自动按照key排序 xff0c 按照value排序好像也没有更好的方法了 xff0c 只能将map转成vector lt pair gt 再进行排序了 sp
  • typescript

    TypeScript TypeScript 是一种给 JavaScript 添加特性的语言扩展 支持es6 xff0c 是微软提出的一种编程语言 TypeScript 设计目标是开发大型应用 xff0c 它可以编译成纯 JavaScript
  • 串口打印中途无log出来,显示console:$字样,一段时间后才再显示

    调试时 xff0c 我们在外接串口打印log时 xff0c 发现lk打印完成后跳转到kernel阶段 xff0c 显示console 字样 xff0c 过一段时间后才重新开始打印log xff0c 这样导致我们抓取的log不全 xff0c
  • 【Hexo】域名绑定篇

    关于Hexo的一切 我的Hexo专栏 零 前言 继上篇 xff0c 本篇主要讨论购买域名以及如何绑定并进行解析 一 购买 我这里只推荐两个平台 xff1a 阿里云官网和 腾讯云官网 xff0c 选择你中意的即可 我买的是一个很辣鸡的域名ww
  • 配置一个好看的PowerShell

    工作生活中用到 PowerShell 的时刻其实有很多 xff0c 但是那深蓝色的背景实在让人想吐槽几句 今天我们就来美化一下它 xff0c 几十种花里胡哨的主题任你选择 用到的是oh my posh xff0c 跟oh my zsh类似
  • scikit-learn介绍-非常流行的python机器学习库

    scikit learn是一个建立在Scipy基础上的用于机器学习的Python模块 在不同的应用领域中 xff0c 已经大展出为数众多的基于Scipy的工具包 xff0c 他们统称为Scikits 而在所有的分支版本中 xff0c sci
  • redis

    redis Redis 是一个Key Value 数据库 xff0c 主要用于存储缓存 redis支持的数据类型 xff1a String字符串 xff1a 设置key值 xff1a set key value string类型是二进制安全
  • 多生产者——多消费者问题

    问题背景 假设有四个人 xff1a 父亲 母亲 女儿 儿子 xff0c 和一个空盘子 xff0c 里面最多放一个水果 父亲每次向盘子中放一个苹果 xff0c 女儿只会吃苹果 母亲每次向盘子中放一个橘子 xff0c 儿子只会吃橘子 这个问题可
  • Android-MVVM-Databinding的原理、用法与封装

    前言 说起 DataBinding ViewBinding 的历史 xff0c 可谓是一波三折 xff0c 甚至是比 Dagger Hilt 还要传奇 说起依赖注入框架 Dagger2 Hilt xff0c 也是比较传奇 xff0c 刚出来

随机推荐

  • day03 Python基础

    day03 Python基础 版权声明 xff1a 本博客转载自路飞学城Python全栈开发培训课件 xff0c 仅用于学习之用 xff0c 严禁用于商业用途 xff0c 未经授权 xff0c 严禁转载 欢迎访问路飞学城官网 xff1a h
  • 最新Spire.pdf Spire.Doc Spire.Xls等无水印使用

    Aspose与Spire功能都很强大 xff0c 为什么要选择Spire xff0c Spire支持WPF组件 xff0c Aspose默认没有 新建 net6控制台程序 xff0c 用NuGet包添加Spire PDF引用 添加代码 us
  • 使用Pyinstaller发布带界面的程序(解决找不到文件问题)

    Pyinstaller Pyinstaller可以用来打包python代码 xff0c 生成可执行文件 xff08 主流平台都可以 xff09 xff0c 介绍就不说了 xff0c 可以百度或者去官网看看 xff1a https www p
  • 动态分配内存——new/delete

    动态分配内存 1 使用new分配内存2 使用delete释放内存3 例子 xff1a 数组编译时分配内存和运行时分配内存4 动态数组补充 xff1a 程序的内存分配 1 使用new分配内存 使用格式 xff1a span class tok
  • Spring学习(一) Spring环境配置

    工具原料 xff1a JDK Eclipse IDEA 开始学Spring xff0c 应该已经安好java环境了 xff0c 这里我就不赘述了 xff0c 直接开始开始下一步的教程 配置spring环境需要导入spring相关的jar包
  • vue-lottie动画效果(进阶篇)

    vue lottie动画效果 以下是个人见解部分 个人见解 xff1a 优点 xff1a 简单高效 xff0c 动画文件小 xff0c 丝滑流畅 xff0c 动画可控性强 缺点 xff1a 依赖包非常重 xff0c 对动画要求不高的项目不太
  • Ubuntu18.04设置开机自启动自己的程序、脚本

    Ubuntu18 04设置开机自启动自己的程序 脚本 本文使用的机器是win10 43 Ubuntu18 04双系统 xff0c 虚拟机上的Ubuntu18 04操作一样 xff0c 均可参考此文 参考链接 xff0c 言简意赅 xff0c
  • 【Qt】【QDebug】【日志】实用的Qt日志打印-打印时间-线程-数据等信息

    Qt QDebug 日志 实用的Qt日志打印 打印时间 线程 数据等信息 在开发audio和video相关软件时 xff0c 收发速率很关键 xff0c 我们需要打印时间和线程等相关信息等日志 include lt QDebug gt 获取
  • DNS(域名解析协议)详解

    DNS协议 我们之前已经了解过ARP协议 如果说ARP协议是用来将IP地址转换为MAC地址 xff0c 那么DNS协议则是用来将域名转换为IP地址 xff08 也可以将IP地址转换为相应的域名地址 xff09 我们都知道 xff0c TCP
  • Mybatis之使用注解开发CRUD

    上一篇演示了如何使用XML来操作Mybatis实现CRUD xff0c 但是大量的XML配置文件的编写是非常烦人的 因此 Mybatis也提供了基于注解的配置方式 xff0c 下面我们来演示一下使用接口加注解来实现CRUD的的例子 首先是创
  • 查看windows服务器的I/O的3种方法

    http blog chinaunix net uid 20344928 id 5597137 html 碎碎念 xff1a 感觉第二种简单 windows查看I O的方法有3种 xff1a 1 任务管理器 打开任务管理器 xff0c 点击
  • 【Tensorflow】辅助工具篇——scikit-image介绍

    很多时候我们跑deep learning算法的难点不在于搭建网络 xff0c 而是数据获取与处理 xff0c 当你看到大量的数据却无从下手时该是怎样的心情 xff01 这几篇我将为大家介绍目前很多paper代码复现中比较流行的辅助工具 首先
  • 一劳永逸,wsl2出现“参考的对象类型不支持尝试的操作”的解决办法

    wsl在使用是会出现 参考的对象类型不支持尝试的操作 的故障导致无法使用 出现上述问题原因是使用代理软件 xff0c 或游戏加速服务 xff0c winsock出现问题 可以通过注册表的方式 xff0c 排除从winsock中排除wsl即可
  • Python中的路径获取方法总结

    遍历文件夹下文件 xff1a os walk dir path def getFlist path for root dirs files in os walk file dir print 39 root dir 39 root 当前路径
  • Android Studio设置了断点却无法进入断点调试(多进程调试)

    有的时候在Android Studio中明明设置了断点 xff0c 也确认了代码会走到断点处 xff0c 但是执行Debug后 xff0c 断点处会显示打钩 xff0c 却不能但不调试 xff0c 好像代码已经执行过去了 这种问题大概率就是
  • mysql16

    常见面试题 MySQL 中有哪些存储引擎 xff1f InnoDB 存储引擎 InnoDB 是 MySQL 的默认事务型引擎 xff0c 也是最重要 使用最广泛的存储引擎 它被设计用来处理大量的短期 short lived 事务 xff0c
  • CSDN 博客备份工具

    前言 核心 登录模块 备份模块 博文扫描模块 演示 如何使用 效果 总结 前言 近段时间以来 听群友博友都在谈论着一件事 CSDN博客怎么没有备份功能啊 这其实也在一定程度上表征着大家对于文章这种知识性产品的重视度越来越高 也对于数据的安全
  • 如何在 Linux 中查找一个文件

    导读对于新手而言 xff0c 在 Linux 中使用命令行可能会非常不方便 没有图形界面 xff0c 很难在不同文件夹间浏览 xff0c 找到需要的文件 本篇教程中 xff0c 我会展示如何在 Linux 中查找特定的文件 第一步要做的是通
  • [Android 调试] 解决linux系统不识别设备、手机问题方法

    最近在开发过程中linux不识别开发板设备 手机 xff0c 看了下dev guide xff0c 现在把方法提供给大家 1 If you 39 re developing on Ubuntu Linux you need to add a
  • spring开发篇二:@RequestParam和@RequestBody与前端Get和Post请求传参详解附中文乱码解决方法

    1 先入为主 xff1a 1 1 在spring的controller中注解写法规则 xff1a xff08 a xff09 同一个请求中 xff0c 只能有一个 64 RequestBody xff1b xff08 b xff09 同一个