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

我使用的是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上显示已配置的信息
5 个月之前 回复
Driver_tu
Driver_tu 不生效,而且@ApiModelh
5 个月之前 回复

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

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

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

Driver_tu
Driver_tu 先谢谢啦
5 个月之前 回复
Driver_tu
Driver_tu 那么请问下大佬,怎么改变swagger里面的这种数据返回方式啊,或者说swagger里返回数据的接口在哪
5 个月之前 回复
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工具测试这个接口如何调用
分布式,用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)); }
@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接收则没有问题,请各位大佬告知原因
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,求各路大神支援
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); } ```
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)
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获取不到参数
关于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 />
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
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值的?
springboot前后端分离跨域403
以前创建项目springboot跨域是使用如下方式配置跨域可以成功 ``` @Configuration public class CorsConfig { private CorsConfiguration buildConfig() { CorsConfiguration corsConfiguration = new CorsConfiguration(); corsConfiguration.addAllowedOrigin("http://web.xiao-e.net:80"); // 1允许任何域名使用 corsConfiguration.addAllowedHeader("*"); // 2允许任何头 corsConfiguration.addAllowedMethod("*"); // 3允许任何方法(post、get等) return corsConfiguration; } @Bean public CorsFilter corsFilter() { UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); source.registerCorsConfiguration("/**", buildConfig()); // 4 return new CorsFilter(source); } } ``` 但是这次新建的项目同样使用上述方式配置跨域,却出现403错误 ![图片说明](https://img-ask.csdn.net/upload/201906/07/1559846549_588796.png) 奇怪的是如果在springboot中不配置任何跨域设置,则可以正常请求。 以下是前端配置代码和后端controller代码 ``` proxyTable: { '/api': { target: 'http://api.xiao-e.net:8080', changeOrigin: true, pathRewrite: { '^/api': '' } } }, ``` ``` @RestController @RequestMapping("user") public class UserController { @Autowired UserService userService; @PostMapping("register") public User register(@RequestBody User user){ return userService.addUser(user); } } ``` api.xiao-e.net和web.xiao-e.net都是解析的127.0.0.1,为了测试跨域使用的
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)
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、PDF搜索网站推荐 对于大部
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Vue + Spring Boot 项目实战(十四):用户认证方案与完善的访问拦截
本篇文章主要讲解 token、session 等用户认证方案的区别并分析常见误区,以及如何通过前后端的配合实现完善的访问拦截,为下一步权限控制的实现打下基础。
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入  假设现有4个人
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 目录一、杨辉三角的介绍二、杨辉三角的算法思想三、代码实现1.第一种写法2.第二种写法 一、杨辉三角的介绍 百度
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
SQL-小白最佳入门sql查询一
一 说明 如果是初学者,建议去网上寻找安装Mysql的文章安装,以及使用navicat连接数据库,以后的示例基本是使用mysql数据库管理系统; 二 准备前提 需要建立一张学生表,列分别是id,名称,年龄,学生信息;本示例中文章篇幅原因SQL注释略; 建表语句: CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // dosho
漫话:什么是平衡(AVL)树?这应该是把AVL树讲的最好的文章了
这篇文章通过对话的形式,由浅入深带你读懂 AVL 树,看完让你保证理解 AVL 树的各种操作,如果觉得不错,别吝啬你的赞哦。 1、若它的左子树不为空,则左子树上所有的节点值都小于它的根节点值。 2、若它的右子树不为空,则右子树上所有的节点值均大于它的根节点值。 3、它的左右子树也分别可以充当为二叉查找树。 例如: 例如,我现在想要查找数值为14的节点。由于二叉查找树的特性,我们可...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
      11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI 算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下
《C++ Primer》学习笔记(六):C++模块设计——函数
专栏C++学习笔记 《C++ Primer》学习笔记/习题答案 总目录 https://blog.csdn.net/TeFuirnever/article/details/100700212 —————————————————————————————————————————————————————— 《C++ Primer》习题参考答案:第6章 - C++模块设计——函数 文章目录专栏C+...
8年经验面试官详解 Java 面试秘诀
    作者 | 胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。   Java程序员准备和投递简历的实
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车? 某胡同口的煎饼摊一年能卖出多少个煎饼? 深圳有多少个产品经理? 一辆公交车里能装下多少个乒乓球? 一
so easy! 10行代码写个"狗屁不通"文章生成器
前几天,GitHub 有个开源项目特别火,只要输入标题就可以生成一篇长长的文章。背后实现代码一定很复杂吧,里面一定有很多高深莫测的机器学习等复杂算法不过,当我看了源代码之后这程序不到50
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
相关热词 c# clr dll c# 如何orm c# 固定大小的字符数组 c#框架设计 c# 删除数据库 c# 中文文字 图片转 c# 成员属性 接口 c#如何将程序封装 16进制负数转换 c# c#练手项目
立即提问