jeecg的开发api接口之旅(http)
一、接口测试工具
1、postman下载地址:https://download.csdn.net/download/qq_35792159/11898005
2、谷歌浏览器插件:https://www.cnblogs.com/guohu/p/11111911.html
二、第一次测试成功
1、模仿系统的登录接口,在登陆成功页面的F12查看接口地址
2、在postman里测试,发现返回的是jsp页面,本来想偷懒不用写接口的,看来还是需要自己写。
3、于是模仿系统里的登录接口,根据客户要求的字段写了一个简单的登陆接口,结果在访问的时候被拦截了
4、在JEECG的官方文档的疑难解答里有排除拦截的设置:http://www.jeecg.org/forum.php?mod=viewthread&tid=1830&extra=page%3D1
在spring-mvc.xml中以下位置添加了自己的地址:
然后就可以使用http://localhost:8080/项目名/appController.do?appLogin&参数测试成功了
三,出现问题,修改再次测试
在我请求网址里,方法是以参数的形式请求的,给客户测试是发现无法请求成功。再看看以前别人给自己的接口中好像都是http://localhost:8080//app/method这种的
1、研究@RequestMapping
开发者需要在控制器内部为每一个请求动作开发相应的处理方法。org.springframework.web.bind.annotation.RequestMapping 注解类型指示Spring用哪一个类或方法处理请求动作,该注解可用于类和方法。
@RequestMapping可以用来注释一个控制器类,在这种情况下,所有方法都将映射为相对于类级别的请求,表示该控制器处理的所有请求都被映射到value属性所指示的路径下 参数参数
参数介绍参考网址:https://blog.csdn.net/qq_36285124/article/details/54289312
我只用到了value和params两个参数,所以就记录下这两个吧。
- value的使用
@RequestMapping(value="list") public String getEmployeeData(ModelAndView mav,HttpServletRequest request,HttpServletResponse response){ System.out.println("============"); return "test"; }
访问的地址可以是/xx项目名/xxcontroller名/list
- params的使用
@RequestMapping(value="list",params="one",method=RequestMethod.GET) public String getEmployeeData(ModelAndView mav,HttpServletRequest request,HttpServletResponse response){ System.out.println("============"); return "test"; }
这种方式如果两个方法的value值相同,只需要加上参数one即可区别,访问的地址为/xx项目名/xxcontroller名/list?one
或者
@RequestMapping(params="list",method=RequestMethod.GET) public String getEmployeeData(ModelAndView mav,HttpServletRequest request,HttpServletResponse response){ System.out.println("============"); return "test"; }
这种方式要访问该方法的地址为:/xx项目名/xxcontroller名?list,没错,这里没有方法名,list只是参数。
2、一开始以为换了参数使用value,还是像之前的配置呢样配置过滤,结果却发现不管怎么配置,都是无法找到网页。
3、请教了一个使用这个框架很熟练的大神,才知道应该在web.xml中配置
<!-- API开放接口配置 --> <servlet> <servlet-name>APISpringMvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <description>spring mvc 配置文件</description> <param-name>contextConfigLocation</param-name> <param-value>classpath*:spring-mvc.xml</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>APISpringMvc</servlet-name>
<url-pattern>/appController/*</url-pattern> </servlet-mapping>
备注:最好不要用<url-pattern>/</url-pattern>,可能会导致其他页面被拦截
4、测试源码:
@Controller @RequestMapping("/appController") public class AppController { // 设置方法下的子路经 @JAuth(auth=Permission.SKIP_AUTH)//放开权限 @RequestMapping("/method") @ResponseBody public String helloworld() { return "helloWorld"; } }
- 请求网址:http://localhost/项目名/appController/method
- @JAuth(auth=Permission.SKIP_AUTH)的作用是设置不让系统拦截请求
- @ResponseBody 的使用和不使用的区别:不使用的话只能返回界面,无法返回数据,像例子中的请求是无法返回的。
四、拓展
1、@RequestMapping @ResponseBody 和 @RequestBody 注解的用法与区别
2、使用框架时,在web.xml中配置servlet时,拦截请求/和/*的区别。
3、Java测试接口,参数为对象的简单测试方式 (这个我一开始有用过,但是后来发现好像不用也可以直接传参数,留着下次看)