带有dojo工具包+ Spring Boot Controller的Ajax:使用curl进行测试,来自ajax json响应为空

如何解决带有dojo工具包+ Spring Boot Controller的Ajax:使用curl进行测试,来自ajax json响应为空

我正尝试测试通过xhrGet请求列表(在本例中为名称)的视图。我在Spring-Boot基本应用程序中使用Dojo Toolkit(webjars)。

波纹管方法返回卷曲:

 curl -i -X GET "http://localhost:8081/the-good-rest/ch3/xhrgame?game=2"
HTTP/1.1 202 
Transfer-Encoding: identity
Content-Type: application/json
Transfer-Encoding: chunked
Date: Sat,26 Sep 2020 20:35:25 GMT


   {"content":{"characters":["Sam","Sony","John","Sheila","Martha","Paul","Britney","Tom","Mark","Bruce"]}}
/*-----------------------------------------------------------------*/

此方法返回一个带有空列表的json对象:

/* This is the method in Controller */
        @RequestMapping(value="ch3/xhrgame",consumes= {MediaType.ALL_VALUE},produces= {MediaType.APPLICATION_JSON_VALUE})
            public ResponseEntity<Map<String,CharactersDto<String>>> dojoTraining4(@RequestParam(name="game") int level) {
                Map<String,CharactersDto<String>> model = new LinkedHashMap<String,CharactersDto<String>>();
                CharactersDto<String> characts = new CharactersDto<String>();
                DateFormat df = DateFormat.getDateInstance();
                if(level>1)
                characts.getCharacters().addAll(new ArrayList<String>(Arrays.asList("Sam","Martha")));
                if(level>=2)
                    characts.getCharacters().addAll(new ArrayList<String>(Arrays.asList("Paul","Bruce")));
                if(level>=3)
                    characts.getCharacters().addAll(new ArrayList<String>(Arrays.asList("Ann","Mary","Rose","James","Anthony")));
                
                model.put("content",characts);
                HttpHeaders headers = new HttpHeaders();
                headers.put("Content-Type",Arrays.asList("application/json"));
                headers.put("Transfer-Encoding",Arrays.asList("identity"));
                headers.put("Accept-Charset",Arrays.asList("utf-8));
                
ResponseEntity<Map<String,CharactersDto<String>>> entity = new  ResponseEntity <Map<String,CharactersDto<String>>>(model,headers,HttpStatus.ACCEPTED); 
                
                return entity;
                
        

}

代码道场: //不过何时从ajax调用:

功能(事件){

        var button = dojo.byId("idAdd");


        
        dojo.stopEvent(event);
        level = dojo.byId("idLevVal").innerHTML;

        var xhrArgs = {
                url:"/the-good-rest/ch3/xhrgame?game="+level,content: {"game":level},handleAs: "json",load: function(data){
                    var d = data.content;
                  if( d.characters.length>0){ 
 //d.characters.lenght is always 0!!!!!
                
                      for(i=0;i<d.characters.length;i++)
                        names.push( d.characters[i]);

                  }
                },error: function(error){
                    console.log(error);
                    dojo.byId("messages").innerHTML = "Names load failed";
                },handle: function(ioargs){
                    console.log("STATUS:" + ioargs);
                }
        };
        
        dojo.byId("messages").innerHTML= "Loading  names...";

        var deferred = dojo.xhrGet(xhrArgs);

    };

这是我解决问题的方法

  //So finally I'm using this implementation 
    @RequestMapping(value="ch3/xhrgame1",method=RequestMethod.GET,produces= {MediaType.APPLICATION_JSON_UTF8_VALUE})
        public ResponseEntity<String> dojoTraining7(@RequestParam(name="game") int level) {
            String body = "";
            if(level==1)
                body =  "{\"content\":{\"characters\":[\"Sam\",\"Sony\",\"John\",\"Sheila\",\"Martha\"]}}";
                if(level==2)
                body  = "{\"content\":{\"characters\":[\"Sam\",\"Martha\",\"Paul\",\"Britney\",\"Tom\",\"Mark\"]}}";
            if(level>=3)
                body  = "{\"content\":{\"characters\":[\"Sam\",\"Mark\",\"Bruce\",\"Ann\",\"Mary\",\"Rose\",\"James\",\"Anthony\",\"Priscila\",\"Ellise\",\"Kurt\",\"Daisy\",\"Jack\",\"Russell\"]}}";
            
            HttpHeaders headers = new HttpHeaders();
            headers.put("Content-Type",Arrays.asList(MediaType.APPLICATION_JSON_UTF8_VALUE));
            headers.put("Accept-Charset",Arrays.asList("UTF-8"));
        ResponseEntity<String> entity = new  ResponseEntity <String>(body,HttpStatus.OK); 
            
            return entity;
}
    

           

    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-