springboot中form-data传值,不用@Requestbody修饰入参对象时,swagger-ui该怎么聚合它的属性

1、环境描述:在springboot+swagger v_2.9.2的环境下
前后端分离,restful风格接口。

2、提问原因:前后端约定使用form-data进行数据传递,后台接口入参很多都是:
public String findPage(String pageNo, String pageSize, Batch entity)这样的,

调试好swagger接口文档后发现:如果将参数Batch用@Requestbody修饰,接口文档中的参数parameter就是聚合显示,如果后台没有使用@Requestbody修饰,那么swagger将递归该参数对象Batch的所有属性,包括其中的Page,具体如下图:

(两种接收参数方式对swagger-ui的影响

图片描述:(不知道图片看的清不)

同一个接口,仅仅只是入参对象的修饰语不同,在swagger上居然区别这么大

左边的swagger上看起来是正常的,网络上很多人都是用这种@Requestbody方式,但是我们约定的是form-data,所以不能使用@Requestbody接收参数。而如果不用,那么swagger文档上看到的都是全部铺开的,不是很方便使用。

3、我尝试过的方法

1.我想过两个方向,一个是修改后台swagger处理数据的拼装逻辑,另一个方向是在页面端修改数据的位置和逻辑,也就是修改api-doc接口返回的数据,

==第一个方向:修改后台swagger处理数据的拼装结构,借鉴了(https://blog.csdn.net/u010579482/article/details/79990536) 中的一个思路,重写子类覆盖swagger主要处理参数数据的ModelAttributeParameterExpander,到目前为止还没有解决。

==第二个方向:修改页面端api-doc接口返回的数据,根据图上两种方式的对比,我们可以发现:

被@Requestbody修饰的入参对象,在swagger-ui的definitions中已经有了一个对象的定义或声明:

被@Requestbody修饰
图片说明

而没有被@Requestbody修饰的返回结果,在swagger-ui里返回结果就直接是在path.post.parameters中平铺在一起,也就是不方便所在,如果入参对象里有子对象,那递归出来就是一大片了。如下图:

图片说明

4、现状:到目前为止,还没有解决这个问题,各位大佬有时间的话教育下小弟,小弟在线等着,还望大佬们不吝赐教,[感激][感激][感激]

5个回答

明白你的意思了,按照你的意思做了一下,篇幅有限,只展示主要代码

自定义注解

@Target({ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
public @interface FormData {
}

覆盖springfox.documentation.spring.web.readers.operation.OperationParameterReader

@Component
@Order(Ordered.HIGHEST_PRECEDENCE)
public class OperationParameterReaderSub extends OperationParameterReader {
    private final ModelAttributeParameterExpander expander;
    private final EnumTypeDeterminer enumTypeDeterminer;

    @Autowired
    private DocumentationPluginsManager pluginsManager;

    @Autowired
    public OperationParameterReaderSub(
            ModelAttributeParameterExpander expander,
            EnumTypeDeterminer enumTypeDeterminer,
            ApplicationContext applicationContext) {
        super(expander, enumTypeDeterminer);
        this.expander = expander;
        this.enumTypeDeterminer = enumTypeDeterminer;
        /*
         * 删除父类bean定义
         * DocumentationPluginsManager中使用ParameterBuilderPlugin类型获取bean,而不是OperationParameterReader类型
         * 所以@Primary注解并不能覆盖父类
         */
        DefaultListableBeanFactory defaultListableBeanFactory = (DefaultListableBeanFactory) applicationContext.getAutowireCapableBeanFactory();
        defaultListableBeanFactory.removeBeanDefinition("operationParameterReader");
    }

    private boolean shouldExpand(final ResolvedMethodParameter parameter, ResolvedType resolvedParamType) {
        return !parameter.hasParameterAnnotation(RequestBody.class)
                && !parameter.hasParameterAnnotation(FormData.class) // 加上自定义的注解
                && !parameter.hasParameterAnnotation(RequestPart.class)
                && !parameter.hasParameterAnnotation(RequestParam.class)
                && !parameter.hasParameterAnnotation(PathVariable.class)
                && !isBaseType(typeNameFor(resolvedParamType.getErasedType()))
                && !enumTypeDeterminer.isEnum(resolvedParamType.getErasedType())
                && !isContainerType(resolvedParamType)
                && !isMapType(resolvedParamType);

    }

    // 其他省略,直接从父类复制

}

覆盖springfox.documentation.spring.web.readers.operation.OperationModelsProvider

@Component
@Order(Ordered.HIGHEST_PRECEDENCE)
public class OperationModelsProviderSub extends OperationModelsProvider {

    private static final Logger LOG = LoggerFactory.getLogger(OperationModelsProvider.class);
    private final TypeResolver typeResolver;

    @Autowired
    public OperationModelsProviderSub(TypeResolver typeResolver, ApplicationContext applicationContext) {
        super(typeResolver);
        this.typeResolver = typeResolver;
        /*
         * 删除父类bean定义
         * DocumentationPluginsManager中使用OperationModelsProviderPlugin类型获取bean,而不是OperationModelsProvider类型
         * 所以@Primary注解并不能覆盖父类
         */
        DefaultListableBeanFactory defaultListableBeanFactory = (DefaultListableBeanFactory) applicationContext.getAutowireCapableBeanFactory();
        defaultListableBeanFactory.removeBeanDefinition("operationModelsProvider");
    }

    private void collectParameters(RequestMappingContext context) {
        LOG.debug("Reading parameters models for handlerMethod |{}|", context.getName());

        List<ResolvedMethodParameter> parameterTypes = context.getParameters();
        for (ResolvedMethodParameter parameterType : parameterTypes) {
            if (parameterType.hasParameterAnnotation(RequestBody.class)
                    || parameterType.hasParameterAnnotation(FormData.class) // 加上自定义的注解
                    || parameterType.hasParameterAnnotation(RequestPart.class)) {
                ResolvedType modelType = context.alternateFor(parameterType.getParameterType());
                LOG.debug("Adding input parameter of type {}", resolvedTypeSignature(modelType).or("<null>"));
                context.operationModelsBuilder().addInputParam(modelType);
            }
        }
        LOG.debug("Finished reading parameters models for handlerMethod |{}|", context.getName());
    }

    // 其他省略,直接从父类复制

}

示例controller

像使用RequestBody一样使用FromData,只变文档,没有其他副作用

    @GetMapping
    @ApiOperation(value = "测试")
    public String test(@FormData User user) {
        System.out.println(user);
        return "随便返回点什么";
    }
Driver_tu
Driver_tu 好的,已经发送好友邀请了,这个地方各个回复的测试结果不对,是因为自定义注解需要放置在同一个扫描的包下,这样可以了,但是还需要禁用它本身的递归??
6 个月之前 回复
qq_35433926
薛凌康 回复Driver_tu: 我QQ号,574290057
6 个月之前 回复
qq_35433926
薛凌康 我QQ号,574290057
6 个月之前 回复
Driver_tu
Driver_tu 方便的话,可以用QQ联系您吗?
6 个月之前 回复
Driver_tu
Driver_tu 您好,我按照您的方式测试了一下,发现还是不对,我的想法就是您说的这个意思,让Swagger知道我的参数是个已知类型对象,并且和@RequestBody的文档一样
6 个月之前 回复
Driver_tu
Driver_tu 回复薛凌康: 大佬,我先看看,稍作回复,我用editor.swagger.io调试了两种情况,发现只有一处不同,没有使用了@RequestBody时,api-docs的接口将我的入参对象识别为String,所以不能把属性聚合,
6 个月之前 回复
qq_35433926
薛凌康 回复Driver_tu: 有问题继续回复就行
6 个月之前 回复
qq_35433926
薛凌康 回复Driver_tu: 看看我更新的评论是不是你要的东西
6 个月之前 回复
Driver_tu
Driver_tu 您好,您的这篇blog我看过几遍了,它主要讲的是如何ignore不想要入参对象中递归的子对象,而在这里,我想要的是如何不使用@RequestBody,也能让swagger-ui有用了的感觉,也就是视图能够像用了@RequestBody一样,谢谢啦
6 个月之前 回复

我使用的是springfox-swagger2,2.2.2版本
可以实现Swagger官方提供的插件:https://springfox.github.io/springfox/docs/snapshot/#plugins
我尝试了实现OperationBuilderPlugin,ParameterBuilderPlugin,OperationModelsProviderPlugin并在其中添加自定义的注解;
最后只留下了实现OperationModelsProviderPlugin的方法,这样可以展开DTO里的参数,和RequestBody效果相同;
不过我没有深入去了解这些,功能实现了就OK了,有空写一篇博客记录一下

Driver_tu
Driver_tu 期待你的博客~
2 个月之前 回复

不用@Requestbody,用@ModelAttribute可以么

Driver_tu
Driver_tu 不生效,而且@ApiModel和@APIModelProperties失效,无法在swagger-ui上显示已配置的信息
6 个月之前 回复
Driver_tu
Driver_tu 不生效,而且@ApiModelh
6 个月之前 回复

我们公司是这么处理的,新建一个param包,专门用来存放接收参数的实体类,然后用@ApiModel,@ApiModelProperty加文档注释,不知道这样不用@RequestBody是什么样,没试过

Driver_tu
Driver_tu 这个博客我看了5+,没有我想要的答案,我的想法就是楼下薛大佬的描述那样,嘿嘿嘿嘿
6 个月之前 回复
qq_37243472
热爱编程,热爱生活 https://blog.csdn.net/aa292016616/article/details/86013037 @ModelAttribute 试试,能用告我一声
6 个月之前 回复
Driver_tu
Driver_tu 有想过这样的解决方案,新建一个model<T>,入参加上@RequestBody,但是我传输数据的方式是form-data,与SpringMVC的@RequestBody冲突,所以用不了
6 个月之前 回复

既然想要自己组装的返回格式又不想用@RequestBody,那就自己在后台写个json的组装工具然后通过response.getWriter().write(json);写出去不就行了

Driver_tu
Driver_tu 先谢谢啦
6 个月之前 回复
Driver_tu
Driver_tu 那么请问下大佬,怎么改变swagger里面的这种数据返回方式啊,或者说swagger里返回数据的接口在哪
6 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
vb.net关于Http的form-data提交的问题
以下在Postman中的c#代码是这样的,求解在**VB.net**中要怎么写? ``` var client = new RestClient("http://192.168.1.106:8888/register_user"); var request = new RestRequest(Method.POST); request.AddHeader("Postman-Token", "df983deb-2867-4c82-b0c5-d9985d18a364"); request.AddHeader("cache-control", "no-cache"); request.AddHeader("Content-Type", "application/x-www-form-urlencoded"); request.AddHeader("content-type", "multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW"); request.AddParameter("multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW", "------WebKitFormBoundary7MA4YWxkTrZu0gW\r\nContent-Disposition: form-data; name=\"ID\"\r\n\r\n1\r\n------WebKitFormBoundary7MA4YWxkTrZu0gW\r\nContent-Disposition: form-data; name=\"idNumber\"\r\n\r\n121213121\r\n------WebKitFormBoundary7MA4YWxkTrZu0gW\r\nContent-Disposition: form-data; name=\"name\"\r\n\r\nMy\r\n------WebKitFormBoundary7MA4YWxkTrZu0gW\r\nContent-Disposition: form-data; name=\"imgPath\"; filename=\"C:\\Users\\Administrator\\Desktop\\DSC_0128.png\"\r\nContent-Type: image/png\r\n\r\n\r\n------WebKitFormBoundary7MA4YWxkTrZu0gW--", ParameterType.RequestBody); IRestResponse response = client.Execute(request); ```
springboot接口 接收参数为实体对象跟MultipartFile对象报错。
springboot接口 接收参数为实体对象跟文件对象报错。 方法参数为 A a, B b, @RequestParam MultipartFile frontImg, @RequestParam MultipartFile backImg 如上是可以接受到2个文件到,但是A,B实体类接受不到 @Requestbody A a, @Requestbody B b, @RequestParam MultipartFile frontImg, @RequestParam MultipartFile backImg 这样到话 报错信息如下 ``` { "timestamp": 1532321861450, "status": 415, "error": "Unsupported Media Type", "exception": "org.springframework.web.HttpMediaTypeNotSupportedException", "message": "Content type 'multipart/form-data;boundary=----WebKitFormBoundarywczeDlb5Y86wuQSJ;charset=UTF-8' not supported", "path": "/personalCenter/saveUserRealInfo" } ``` ## 重金求人解决问题
Spring MVC WEB工程中前后台post传值事该不该用@RequestBody?
最近在做一个项目,BS架构用的SpringMVC,在做前后台交互时用post将前台的数据发送到后台,对action里面的@RequestBody有点迷糊,求教各位大神。 ``` @RequestMapping(value = "/something", method = RequestMethod.POST) public void handle(@RequestBody User user, Writer writer) throws IOException { writer.write(body); } ``` 这样用AJAX提交时必须是下面这种才能成功 ``` var user={'name':name,'passwd':passwd} $.ajax({ url : "http://localhost:8080/something", type : "POST", contentType: "application/json", data : JSON.stringify(user), dataType : "json", success : function(result) { }, error:function(msg){ } }); ``` 如果后台action里面取掉@RequestBody,就像下面这样 ``` @RequestMapping(value = "/something", method = RequestMethod.POST) public void handle( User user, Writer writer) throws IOException { writer.write(body); } ``` 前台post数据的时候直接这样就行了 ``` var user={'name':name,'passwd':passwd} $.ajax({ url : "http://localhost:8080/something", type : "POST", data : user, success : function(result) { }, error:function(msg){ } }); ``` 这样就可以收到前台传过来的值,但是按照前面的就不行了。 这个里面@RequestBody到底有什么作用,我的本意是后台直接接收一个User对象,如果按照第一种方法,感觉像是我前台先创建一个User对象,然后把它转成了JSON串再post到后台,然后通过@RequestBody再将JSON串转换成User对象,这感觉有点多此一举。而第二种方法感觉就是直接把对象传到后台的。那么这里@RequestBody的作用是什么。感觉第二种更加的方便,可是我看了一些人说的和一些项目中例子,用的第一种的比较多,这是为什么,百思不得其解?
SoapUI工具调用有@RequestBody类型的Rest接口如何传值?
SoapUI工具调用有@RequestBody类型的Rest接口如何传值? 使用Spring MVC在Controller中类中有个接口的入参用的是@RequestBody注解,想通过Soap UI工具测试这个接口如何调用
spring4mvc-ajax-requestbody解析不了arraylist报415错误
直接上代码 script代码: ``` function sendMsg3(){ var test=new Array(); test[0]="呵呵1"; test[1]="呵呵2"; test[2]="呵呵3"; test[3]="呵呵4"; test[4]="呵呵5"; var userJsonStr=JSON.stringify(test); $.ajax({ type:"POST", data:userJsonStr, url:"getJson3.spring?t="+new Date().getTime(), dataType:"json", contentType:"application/json" }); alert(userJsonStr); } ``` java里的代码: ``` @RequestMapping("/getJson3") public String getJson3(@RequestBody ArrayList<String> list) { for (String str : list) { System.out.println(str); } System.out.println("呵呵come here"); return "index.jsp"; } ``` spring-mvc配置: ``` <beans xmlns="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd"> <context:component-scan base-package="controller"/> <mvc:annotation-driven /> </beans> ``` lib包里有jack-all的包如图: ![图片说明](https://img-ask.csdn.net/upload/201506/14/1434262350_209816.png) 触发ajax方法后,控制台 那边愣是没啥反应,客户端这边报415的错误unsupported media type,求各路大神支援
@RequestBody 实体类接收不到数据,但是用com.alibaba.fastjson.JSONObject可以
``` @RequestMapping(value = "/getTest", method = {RequestMethod.POST}) public @ResponseBody CommonResponse getTest(@RequestBody TestForm form { ``` 后台这样写,使用postman测试 请求会直接报400, ``` <!doctype html> <html lang="en"> <head> <title>HTTP Status 400 – Bad Request</title> <style type="text/css"> h1 { font-family: Tahoma, Arial, sans-serif; color: white; background-color: #525D76; font-size: 22px; } h2 { font-family: Tahoma, Arial, sans-serif; color: white; background-color: #525D76; font-size: 16px; } h3 { font-family: Tahoma, Arial, sans-serif; color: white; background-color: #525D76; font-size: 14px; } body { font-family: Tahoma, Arial, sans-serif; color: black; background-color: white; } b { font-family: Tahoma, Arial, sans-serif; color: white; background-color: #525D76; } p { font-family: Tahoma, Arial, sans-serif; background: white; color: black; font-size: 12px; } a { color: black; } a.name { color: black; } .line { height: 1px; background-color: #525D76; border: none; } </style> </head> <body> <h1>HTTP Status 400 – Bad Request</h1> <hr class="line" /> <p><b>Type</b> Status Report</p> <p><b>Description</b> The server cannot or will not process the request due to something that is perceived to be a client error (e.g., malformed request syntax, invalid request message framing, or deceptive request routing). </p> <hr class="line" /> <h3>Apache Tomcat/8.5.42</h3> </body> </html> ``` 如果后台改为 ``` public CommonResponse getTest(@RequestBody JSONObject jsonObject) { ``` 用JSONObject接收则没有问题,请各位大佬告知原因
关于retrofit2传值服务器接收的问题
现在要做一个类似发说说的功能,所以图片是不固定的,现在客户端那边是这样的: @Multipart @POST("/LovelyPet/{link}") Call<String> uploadImage(@Path("link") String link, @Query("description") String description,@PartMap Map<String, RequestBody> img); 调用的时候: Map<String, RequestBody> photos=new HashMap<String, RequestBody>(); if(mPhotoSnpl.getData().size()>0){ for (int i=0;i<mPhotoSnpl.getData().size();i++){ photos.put("photos"+i+"\";filename=\"icon.png",RequestBody.create(MediaType.parse("multipart/form-data"),new File(mPhotoSnpl.getData().get(i)))); } } 我现在不太懂服务器那段要怎么接收,服务器那段没有什么框架,就是单纯的sevlet,还有就是我这个传过去的key到底是什么啊?~
ajax如何用get传requestbody
ajax如何用get方式向后台传 requestbody? 用post可以很贱的传,想请问如何用get传,找了很多说可以但是没有给出具体的方法。
SpringMVC的@Requestbody接收不到json的值
控制层 @Controller @RequestMapping("/task") public class TaskAction { @RequestMapping("/run") public @ResponseBody TaskConnects runTask(@RequestBody TaskConnects connects)throws Exception{ System.out.println("----------------------" + "\n" + connects); return connects; } } js的代码 $.ajax({ type: "post", url: "task/run.action", contentType:'application/json;charset=utf-8', data: '{"ConnectionId":"con_12","SourceId":"circle-1","TargetId":"roundedRect-3"}', datatype: "json", success: function () { alert("send successfully") } SpringMVC配置文件也加了json转换器 <!-- json转换器 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <ref bean="mappingJackson2HttpMessageConverter" /> </list> </property> </bean> <bean id="mappingJackson2HttpMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/html;charset=UTF-8</value> <value>text/json;charset=UTF-8</value> <value>application/json;charset=UTF-8</value> </list> </property> </bean> <mvc:annotation-driven />
分布式,用mybastis-plus自带分页出现问题,求大佬们看看怎么解决
``` Cannot construct instance of `com.baomidou.mybatisplus.core.metadata.IPage` (no Creators, like default construct, exist): abstract types either need to be mapped to concrete types, have custom deserializer, or contain additional type information at [Source: (PushbackInputStream); line: 1, column: 1]] with root cause ``` ``` 服务端Service代码 /******************************************************************************** * @Title: getlist * @Description: 通过条件获取系统日志表分页列表 ********************************************************************************/ @PostMapping(value = "/list/page/{pageNum}/{pageSize}") @ApiOperation(value = "获取系统日志表详情", notes = "通过条件获取系统日志表详情") public IPage<SysLog> getlist(@RequestBody SysLog sysLog, @PathVariable int pageNum, @PathVariable int pageSize) throws BaseException { IPage<SysLog> page = new Page<SysLog>(pageNum, pageSize); return sysLogDao.selectPage(page, new QueryWrapper<SysLog>(sysLog)); }
AJAX怎么同时传递一个对象和一个字符串,不在对象里存对象,直接就一个对象,一个字符串
后台代码 ``` @RequestMapping("/login") @ResponseBody public ReturnType login(@RequestBody UserModel userModel,String verify) { System.out.println(userModel.toString()); System.out.println(userModel1.toString()); UserModel user = new UserModel(); user.setId(1); UserModel user1 = loginService.Login(user); System.out.println(123); return ReturnType.create(user1); } ``` 后台像这样的,前台AJAX怎么传递值 或者后台这样的 ``` @RequestMapping("/login") @ResponseBody public ReturnType login(@RequestBody UserModel userModel,@RequestBody UserModel userModel1,String verify) { System.out.println(userModel.toString()); System.out.println(userModel1.toString()); UserModel user = new UserModel(); user.setId(1); UserModel user1 = loginService.Login(user); System.out.println(123); return ReturnType.create(user1); } ```
stringboot @Requestbody 和@Valid自定义校验方法配合使用问题
string boot ``` @RequestMapping("/forget") public JsonUtil forget(@RequestBody Map<String,String> map, @Valid ForgetpwdValidate bean, BindingResult bindingResult){ if (bindingResult.hasErrors()) { String messages = bindingResult.getAllErrors() .stream() .map(ObjectError::getDefaultMessage) .reduce((m1, m2) -> m1 + ";" + m2) .orElse("参数输入有误!"); return JsonUtil.error(messages); } return userService.forgetPwd(map); } ``` 在ForgetpwdValidate获取不到参数
springboot项目,在linux上,上传文件(导入word、excel文档)时报错SocketTimeoutException:null ;在本地正常,怎么解决?
2019-11-28 15:26:09.461 ERROR 3740 --- [nio-8898-exec-6] c.g.p.c.util.KoalaHttpRequestWrapper     : Wrap requestBody failed 2019-11-28 15:26:09.461 ERROR 3740 --- [nio-8898-exec-6] o.a.c.c.C.[.[.[.[dispatcherServlet]      : Servlet.service() for servlet [dispatcherServlet] in context with path [/platform] threw exception [Request processing failed; nested exception is org.springframework.web.multipart.MultipartException: Could not parse multipart servlet request; nested exception is java.io.IOException: org.apache.tomcat.util.http.fileupload.FileUploadException] with root cause java.net.SocketTimeoutException: null     at org.apache.tomcat.util.net.NioBlockingSelector.read(NioBlockingSelector.java:201)     at org.apache.tomcat.util.net.NioSelectorPool.read(NioSelectorPool.java:235)     at org.apache.tomcat.util.net.NioSelectorPool.read(NioSelectorPool.java:216)     at org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.fillReadBuffer(NioEndpoint.java:1233)     at org.apache.tomcat.util.net.NioEndpoint$NioSocketWrapper.read(NioEndpoint.java:1182)     at org.apache.coyote.http11.Http11InputBuffer.fill(Http11InputBuffer.java:713)     at org.apache.coyote.http11.Http11InputBuffer.access$300(Http11InputBuffer.java:40)     at org.apache.coyote.http11.Http11InputBuffer$SocketInputBuffer.doRead(Http11InputBuffer.java:1063)     at org.apache.coyote.http11.filters.IdentityInputFilter.doRead(IdentityInputFilter.java:140)     at org.apache.coyote.http11.Http11InputBuffer.doRead(Http11InputBuffer.java:257)     at org.apache.coyote.Request.doRead(Request.java:574)     at org.apache.catalina.connector.InputBuffer.realReadBytes(InputBuffer.java:326)     at org.apache.catalina.connector.InputBuffer.checkByteBufferEof(InputBuffer.java:642)     at org.apache.catalina.connector.InputBuffer.read(InputBuffer.java:349)     at org.apache.catalina.connector.CoyoteInputStream.read(CoyoteInputStream.java:183)     at java.io.FilterInputStream.read(FilterInputStream.java:133)     at org.apache.tomcat.util.http.fileupload.util.LimitedInputStream.read(LimitedInputStream.java:132)     at org.apache.tomcat.util.http.fileupload.MultipartStream$ItemInputStream.makeAvailable(MultipartStream.java:977)     at org.apache.tomcat.util.http.fileupload.MultipartStream$ItemInputStream.read(MultipartStream.java:881)     at java.io.InputStream.read(InputStream.java:101)     at org.apache.tomcat.util.http.fileupload.util.Streams.copy(Streams.java:98)     at org.apache.tomcat.util.http.fileupload.util.Streams.copy(Streams.java:68)     at org.apache.tomcat.util.http.fileupload.MultipartStream.readBodyData(MultipartStream.java:571)     at org.apache.tomcat.util.http.fileupload.MultipartStream.discardBodyData(MultipartStream.java:595)     at org.apache.tomcat.util.http.fileupload.MultipartStream.skipPreamble(MultipartStream.java:613)     at org.apache.tomcat.util.http.fileupload.FileUploadBase$FileItemIteratorImpl.findNextItem(FileUploadBase.java:874)     at org.apache.tomcat.util.http.fileupload.FileUploadBase$FileItemIteratorImpl.<init>(FileUploadBase.java:854)     at org.apache.tomcat.util.http.fileupload.FileUploadBase.getItemIterator(FileUploadBase.java:256)     at org.apache.tomcat.util.http.fileupload.FileUploadBase.parseRequest(FileUploadBase.java:280)     at org.apache.catalina.connector.Request.parseParts(Request.java:2871)     at org.apache.catalina.connector.Request.parseParameters(Request.java:3215)     at org.apache.catalina.connector.Request.getParameter(Request.java:1145)     at org.apache.catalina.connector.RequestFacade.getParameter(RequestFacade.java:381)     at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:75)     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)     at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197)     at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)     at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)     at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)     at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)     at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)     at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478)     at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)     at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80)     at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)     at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)     at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:799)     at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)     at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)     at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1455)     at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)     at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)     at java.lang.Thread.run(Thread.java:748)
Okhttp RequestBody不支持传数组,但我需要传一个数组给服务器我该怎么做?
Okhttp RequestBody不支持传数组,但我需要传一个数组给服务器我该怎么做?
springboot JPA保存报错
用户类 ``` @Entity @SecondaryTable(name="sys_user_extend") @GenericGenerator(name = "jpa-uuid", strategy = "uuid") public class SysUser implements UserDetails { /** * */ private static final long serialVersionUID = 1L; public SysUser() { } public SysUser(String loginName, String password) { super(); this.loginName = loginName; this.password = password; } @Id @GeneratedValue(generator = "jpa-uuid") private String id; @Column(unique=true ,nullable = false) private String loginName; @Column(nullable = false) private String password; @Column(unique=true ,nullable = false) private String name; @Column(unique=true) private String email; @Column(unique=true) private String phone; @Column private String remark; @Column private String lastLoginTime; @Column(nullable = false) private String isActive = "true"; @Column(table="sys_user_extend") private String level; @Column(table="sys_user_extend") private String currentExperience; @Column(table="sys_user_extend") private String totalExperience; @ManyToMany(cascade = { CascadeType.REFRESH }, fetch = FetchType.EAGER) private List<SysRole> roles; @Override public Collection<? extends GrantedAuthority> getAuthorities() { List<GrantedAuthority> authorities = new ArrayList<>(); List<SysRole> roles = this.getRoles(); for (SysRole role : roles) { authorities.add(new SimpleGrantedAuthority(role.getName())); } return authorities; } //省略get、set方法 } ``` ``` public interface SysUserRepository extends JpaRepository<SysUser, Long> { SysUser findByLoginName(String loginname); SysUser findByPhone(String phone); SysUser findByEmail(String email); } ``` controller层的添加方法 ``` //添加 @ResponseBody @RequestMapping(value="/user",method=RequestMethod.POST) public Object post(@RequestBody SysUser user){ BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); String encodedPassword = passwordEncoder.encode(user.getPassword()); user.setPassword(encodedPassword); userserivce.saveUser(user); return user; } ``` ![数据库用户表](https://img-ask.csdn.net/upload/201909/24/1569312948_464905.png) ![数据库用户扩展信息表](https://img-ask.csdn.net/upload/201909/24/1569313009_372653.png) 报错信息: > org.springframework.http.converter.HttpMessageNotWritableException: Could not write JSON: (was java.lang.NullPointerException); nested exception is com.fasterxml.jackson.databind.JsonMappingException: (was java.lang.NullPointerException) (through reference chain: com.sakuraSmiles.alpha.security.model.SysUser[\"authorities\"])" 测试json {"loginName":"test123","name":"测试","password":"123456","level":"5"} 项目使用了spring security,通过postman模拟请求,debug跟了下发现controller层的user是能拿到我传的对象的,但是里面也没有authorities字段。网上找了好久也没看到有跟我这个类似的,请问有人碰到过相似的问题吗?或者有大佬帮忙看一看吗? 感谢1楼和3楼大牛的解答帮助,十分感谢两位的帮助。分想要两位都给的,没办法只能选择一个采纳,就先给了1楼。问题已经解决了,定位到就是如3楼大牛所说,因为实现UserDetails 接口会有getAuthorities方法,在进行序列化时发现有带getXX开始的方法会自动去找XX的属性, 但是发现并没这个属性,所以报错。网上搜索了一下jpa有没有能够让系统能够忽视这个get方法的注释,在getAuthorities方法上面添加了@JsonIgnore就执行save不会报错了,目前没看出对于其他地方有没有影响。 ``` @Override @JsonIgnore public Collection<? extends GrantedAuthority> getAuthorities() { List<GrantedAuthority> authorities = new ArrayList<>(); List<SysRole> roles = this.roles; for (SysRole role : roles) { authorities.add(new SimpleGrantedAuthority(role.getName())); } return authorities; } ``` ![图片说明](https://img-ask.csdn.net/upload/201909/24/1569316069_705652.png)
springboot项目中使用了mybatisplus的baseMapper中的方法,却提示报错自己的mapper中没有这个方法
报错信息如下: Invalid bound statement (not found): cn.itsource.fastgo.mapper.EmployeeMapper.selectOne 这是service层的接口实现类 @Service @Transactional(readOnly = true,propagation = Propagation.SUPPORTS) public class EmployeeServiceImpl extends ServiceImpl<EmployeeMapper,Employee> implements IEmployeeService { @Override public Employee login(String username, String password) { return baseMapper.selectOne(new QueryWrapper<Employee>() .eq("username",username) .eq("password",password)); } } 这是mapper @Mapper public interface EmployeeMapper extends BaseMapper<Employee> { } 这是controller @RestController public class LoginController { @Autowired private IEmployeeService employeeService; @PostMapping("/login") @ApiOperation(value = "登录接口" + "") public AjaxResult login(@RequestBody Map<String,Object> params){ String username = (String) params.get("username"); String password = (String) params.get("password"); Employee employee = employeeService.login(username,password); if(null!=employee){ //登录成功 return AjaxResult.me(); } //登录失败 return AjaxResult.me().setSuccess(false).setMessage("用户名或密码错误!"); } } 请问大神们为什么调用的是basemapper的selectOne方法,但是会报错employeeMapper找不到selectOne
springMVC中的@ReponseBody和@RequestBody是不是相斥啊?
``` <mvc:annotation-driven> <!-- 配置json相关 --> <!-- <mvc:message-converters register-defaults="false"> --> <!-- 避免IE执行AJAX时,返回JSON出现下载文件 --> <!-- <bean id="fastJsonHttpMessageConverter" class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter"> --> <!-- <property name="supportedMediaTypes"> --> <!-- <list> --> <!-- 这里顺序不能反,一定先写text/html,不然ie下出现下载提示 --> <!-- <value>text/html;charset=UTF-8</value> --> <!-- <value>application/json;charset=UTF-8</value> --> <!-- </list> --> <!-- </property> --> <!-- </bean> --> <!-- </mvc:message-converters> --> </mvc:annotation-driven> ``` 在mvc:annotation-driven加上我注释的那一段后 RequestBody能行 但是ReponseBody报406错误 去掉那段注释后 ReponseBody能行 RequestBody报NoSuchMethodError的错误 百度了好久 该有的jar包也全都加上了 ![图片说明](https://img-ask.csdn.net/upload/201704/20/1492692617_851644.png)
ajax发送请求为什么后台@RequestBody String data接收的数据乱码
$.ajax({ url :"", type : "POST", cache : false, data : data, contentType : "text/html;charset=UTF-8", dataType : "json", success : function(result) { }, error : function(xhr, ajaxOptions, thrownError) { } });
mybatis plus removeById(Serializable id)方法, Serializable类的对象如何映射成对象的id值?
mybatis plus中 removeById(Serializable id)的 API如下: ``` /** * <p> * 根据 ID 删除 * </p> * * @param id 主键ID */ boolean removeById(Serializable id); ``` 要传入的是主键ID的值, 但在项目中,调用removeById方法时传入的是对象,这个对象的类实现了Serializable接口,调用方法的代码如下: ``` @RequestMapping(value ="/delete", method=RequestMethod.DELETE) public Result delete( @ApiParam(name="BaseWsdYhbzcs",required=true) @RequestBody BaseWsdYhbzcs baseWsdYhbzcs) { baseWsdYhbzcsService.removeById(baseWsdYhbzcs); return ResultUtils.wrapSuccess(); } ``` 不明白是如何将类的对象转换成id值的?
130 个相见恨晚的超实用网站,一次性分享出来
相见恨晚的超实用网站 持续更新中。。。
我花了一夜用数据结构给女朋友写个H5走迷宫游戏
起因 又到深夜了,我按照以往在csdn和公众号写着数据结构!这占用了我大量的时间!我的超越妹妹严重缺乏陪伴而 怨气满满! 而女朋友时常埋怨,认为数据结构这么抽象难懂的东西没啥作用,常会问道:天天写这玩意,有啥作用。而我答道:能干事情多了,比如写个迷宫小游戏啥的! 当我码完字准备睡觉时:写不好别睡觉! 分析 如果用数据结构与算法造出东西来呢? ...
字节跳动视频编解码面经
三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时想着能进去就不错了,管他哪个岗呢,就同意了面试...
win10系统安装教程(U盘PE+UEFI安装)
一、准备工作 u盘,电脑一台,win10原版镜像(msdn官网) 二、下载wepe工具箱 极力推荐微pe(微pe官方下载) 下载64位的win10 pe,使用工具箱制作启动U盘打开软件, 选择安装到U盘(按照操作无需更改) 三、重启进入pe系统 1、关机后,将U盘插入电脑 2、按下电源后,按住F12进入启动项选择(技嘉主板是F12) 选择需要启...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Linux(服务器编程):15---两种高效的事件处理模式(reactor模式、proactor模式)
前言 同步I/O模型通常用于实现Reactor模式 异步I/O模型则用于实现Proactor模式 最后我们会使用同步I/O方式模拟出Proactor模式 一、Reactor模式 Reactor模式特点 它要求主线程(I/O处理单元)只负责监听文件描述符上是否有事件发生,有的话就立即将时间通知工作线程(逻辑单元)。除此之外,主线程不做任何其他实质性的工作 读写数据,接受新的连接,以及处...
HAL 硬件抽象层介绍
和你一起终身学习,这里是程序员Android本篇文章主要介绍Android开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:和你一起终身学习,这里是程序员 Android本篇文章主要介绍Android开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:一、HAL 概述一、HAL 概述HAL定义了供硬件供应商实施的标准接口,该接口使Android无需考虑底层驱动程序的实现。使用HA...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的回答,对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalking,作者吴晟、刘浩杨 等等 仓库地址: apache/skywalking 更...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
使用 Angular 打造微前端架构的 ToB 企业级应用
这篇文章其实已经准备了11个月了,因为虽然我们年初就开始使用 Angular 的微前端架构,但是产品一直没有正式发布,无法通过生产环境实践验证可行性,11月16日我们的产品正式灰度发布,所以是时候分享一下我们在使用 Angular 微前端这条路上的心得(踩过的坑)了额,希望和 Angular 社区一起成长一起进步,如果你对微前端有一定的了解并且已经在项目中尝试了可以忽略前面的章节。 什么是微前...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
拿下微软、Google、Adobe,印度为何盛产科技圈 CEO?
作者 | 胡巍巍 出品 | CSDN(ID:CSDNnews) 世界500强中,30%的掌舵人,都是印度人。 是的,你没看错。这是近日《哈佛商业评论》的研究结果。 其中又以微软CEO萨提亚·纳德拉(Satya Nadella)、和谷歌CEO桑达尔·皮查伊(Sundar Pichai,以下简称劈柴)最为出名。 微软CEO萨提亚·纳德拉(Satya Nadella) 其他著名印度...
Linux(内核剖析):19---中断总体概述
一、为什么要引入中断? 任何操作系统内核的核心任务,都包含有对连接到计算机上的硬件设备进行有效管理,如硬盘、蓝光碟机、键盘、鼠标、3D 处理器,以及无线电等。而想要管理这些设备,首先要能和它们互通音信才行。众所周知,处理器的速度跟外围硬件设备的速度往往不在一个数量级上,因此,如果内核采取让处理器向硬件发出一个请求,然后专门等待回应的办法,显然差强人意。既然硬件的响应这么慢,那么内核就应该在此期间...
程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
深度学习笔记------卷积神经网络
深度学习笔记------卷积神经网络
一文带你入门Linux
文章目录1.1 Linux的概述:1.1.1 什么是Linux:1.1.1.1 学习Linux之前先了解Unix1.1.1.2 Linux的概述:1.1.1.3 Linux的历史:1.1.1.4 Linux系统的应用:1.1.1.5 Linux的版本1.1.1.6 Linux的主流版本1.2 Linux的安装:1.2.1 虚拟机安装:1.2.1.1 什么是虚拟机1.2.1.2 安装VmWare1....
普通三本毕业,我怎么一路艰辛进入阿里的
英雄不问出处? 自古以来就有这样一句话,真的英雄不问出处吗?这句话太挫了。普通三本院校的我,大四的时候居然都不知道什么是校招,所以出处太重要了。这也是没有机会参加阿里校招的原因,毕竟校招门槛比社招还是要低的,最重要的是校招进入阿里能让你的起点比别人更高。 有幸可以社招进入阿里,了解了校招的思路,赶紧介绍给学弟们,现在我们三本院校的小学弟今年居然有 3 个人通过了阿里的校招。下面我也把这份宝贵的经...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
强烈推荐10本程序员在家读的书
很遗憾,这个春节注定是刻骨铭心的,新型冠状病毒让每个人的神经都是紧绷的。那些处在武汉的白衣天使们,尤其值得我们的尊敬。而我们这些窝在家里的程序员,能不外出就不外出,就是对社会做出的最大的贡献。 有些读者私下问我,窝了几天,有点颓丧,能否推荐几本书在家里看看。我花了一天的时间,挑选了 10 本我最喜欢的书,你可以挑选感兴趣的来读一读。读书不仅可以平复恐惧的压力,还可以对未来充满希望,毕竟苦难终将会...
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。
疫情数据接口api
返回json示例 { "errcode":0,//0标识接口正常 "data":{ "date":"2020-01-30 07:47:23",//实时更新时间 "diagnosed":7736,//确诊人数 "suspect":12167,//疑是病例人数 "death":170,//死亡人数 "cur...
智力题(程序员面试经典)
NO.1  有20瓶药丸,其中19瓶装有1克/粒的药丸,余下一瓶装有1.1克/粒的药丸。给你一台称重精准的天平,怎么找出比较重的那瓶药丸?天平只能用一次。 解法 有时候,严格的限制条件有可能反倒是解题的线索。在这个问题中,限制条件是天平只能用一次。 因为天平只能用一次,我们也得以知道一个有趣的事实:一次必须同时称很多药丸,其实更准确地说,是必须从19瓶拿出药丸进行称重。否则,如果跳过两瓶或更多瓶药...
疫情防控,开发者集结出战!
作者 | 屠敏出品 | CSDN(ID:CSDNnews)2020 年伊始,病毒肆虐,人心惶惶。截止北京时间 1 月 31 日 15 时 30 分,全国确诊新型冠状病毒肺炎的数字已达到了...
相关热词 c# 为空 判断 委托 c#记事本颜色 c# 系统默认声音 js中调用c#方法参数 c#引入dll文件报错 c#根据名称实例化 c#从邮件服务器获取邮件 c# 保存文件夹 c#代码打包引用 c# 压缩效率
立即提问