swagger与springMVC、maven整合

最近使用swagger自动生成api文档遇到了不少坑,网上有许多教程,但都并不能顺利运行。现自己整理了一份,以备之后用到时使用。


在这之前需要注意的几个问题:

1.jar包是否引用完整;

2.是否下载了匹配版本的swagger-ui(该案例中使用了swagger-ui 2.2.10版本),jar包中swagger-springmvc版本为1.0.2。该问题若不注意可能引起以下问题:

No operations defined in spec!

3.applicationContext.xml配置文件中请按照以下顺序填写,否则可能引起扫描注入失败的报错.




4.spring-mvc.xml中必须配置以下两项



5.修改swagger-ui中的dist目录下index.html中读取url配置的路径为:当前部署路径+ 项目名+“/api-docs”
url = "http://localhost:5508/api-docs";
由于我的项目名设置为"/",因此这里直接忽略

附上运行结果图:

swagger与springMVC、maven整合_第1张图片



以下附上按照尽可能简单的最小依赖的写法:

1.配置pom.xml文件


	4.0.0
	com.swagger
	swagger
	0.0.1-SNAPSHOT
	war
	swagger自动生成api文档
	swagger与spring mvc结合自动生成api文档
	
		UTF-8
		4.3.4.RELEASE
		2.4.4
	
	
		
		
			org.springframework
			spring-core
			${spring.version}
		
		
			org.springframework
			spring-webmvc
			${spring.version}
		
		
		
			net.sf.json-lib
			json-lib
			2.4
			jdk15
		
		
		
			com.fasterxml.jackson.core
			jackson-core
			${jackson.version}
		
		
			com.fasterxml.jackson.core
			jackson-databind
			${jackson.version}
		
		
		
			com.mangofactory
			swagger-springmvc
			1.0.2
		
	
	
		swagger
		
			
				src/main/java
				
					**/*.properties
					**/*.xml
				
				false
			
			
				src/main/resources
			
		
		
			
				org.apache.maven.plugins
				maven-compiler-plugin
				
					1.7
					1.7
					UTF-8
					
						
						${project.basedir}\src\main\webapp\WEB-INF\lib
					
				
			
			
				org.apache.maven.plugins
				maven-war-plugin
				2.1.1
				
					
						
							webapp
						
					
				
			
			
				org.mortbay.jetty
				jetty-maven-plugin
				
					webapp
					
						true
					
					
						/
					
					webx
					9998
					
						
							5508
							60000
						
					
					
						target/access.log
						90
						false
						false
						GMT+8:00
					
				
			
		
	

2.配置web.xml文件


	swagger
	
	
		contextConfigLocation
		classpath:applicationContext.xml
	
	
		org.springframework.web.context.ContextLoaderListener
	
	
		org.springframework.web.util.IntrospectorCleanupListener
	
	
		SpringMVC
		org.springframework.web.servlet.DispatcherServlet
		
			contextConfigLocation
			classpath:spring-mvc.xml
		
		1
	
	
		SpringMVC
		/
	


3.配置applicationContext.xml文件





	
	


4.配置spring-mvc.xml文件



	
	


5.Controller核心代码

package com.controller;

import java.util.Date;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import com.swagger.vo.User;
import com.wordnik.swagger.annotations.Api;
import com.wordnik.swagger.annotations.ApiOperation;
import com.wordnik.swagger.annotations.ApiParam;

import net.sf.json.JSONObject;

@Controller
@RequestMapping("/Test")
public class TestController {
	
	/*其中@ApiOperation和@ApiParam为添加的API相关注解,个参数说明如下: 
	 * 
	@ApiOperation(value = "接口说明", httpMethod = "接口请求方式", response = "接口返回参数类型", notes = "接口发布说明") 
	@ApiParam(required = "是否必须参数", name = "参数名称", value = "参数具体描述")
	produces = "text/plain;charset=utf-8" 设置传入接收字符编码为utf-8
	*/
	@RequestMapping(value = "/demo_get", method = RequestMethod.GET, produces = "text/plain;charset=utf-8" )
	@ApiOperation(value = "GET请求", httpMethod = "GET", notes = "get请求案例")
	public @ResponseBody String demo_get(
			@ApiParam(required = true, name = "name", value = "用户名") 
			@RequestParam(required=false) String name){
		return "你输入的名字:"+name;
	}
	
	@RequestMapping(value = "/demo_post", method = RequestMethod.POST, produces = "text/plain;charset=utf-8" )
	@ApiOperation(value = "POST请求 键值对参数提交", httpMethod = "POST", notes = "post请求案例, 参数以键值对方式提交, 返回一个json对象", response = User.class)
	public @ResponseBody String demo_post(
			@ApiParam(required = true, name = "name", value = "用户名") 
			@RequestParam(required=false) String name){
		
		User user = new User();
        user.setId(String.valueOf(new Date().getTime()));
        user.setName(name);
        user.setAge(22);
        user.setCompany("人生有限公司");
        user.setGender(1);
        user.setIc("12345678910");
        user.setPhone("400800888");
        user.setSchool("北大还行");
        JSONObject object = JSONObject.fromObject(user);
        return object.toString();
	}
	
	@RequestMapping(value = "/demo_post2", method = RequestMethod.POST, produces = "application/json;charset=utf-8" )
	@ApiOperation(value = "POST请求 json格式参数提交", httpMethod = "POST", notes = "post请求案例, json格式参数提交, 返回一个json对象")
	public @ResponseBody String demo_post2(
			@ApiParam(required = true, name = "user", value = "用户对象json格式参数") 
			@RequestBody User user){
        JSONObject object = JSONObject.fromObject(user);
        JSONObject result = new JSONObject();
        result.put("result", 1);
        result.put("object", object);
        return result.toString();
	}
	
}


附上亲测代码demo:

http://download.csdn.net/download/baidu_36720706/10118720

由于该demo已经集成jetty,请直接使用jetty执行项目

eclipse环境中运行jetty步骤如下:

swagger与springMVC、maven整合_第2张图片

swagger与springMVC、maven整合_第3张图片



另外附上两个看了帮助较大的帖子链接:

http://blog.csdn.net/u011499992/article/details/53455144

java注解方式,非xml配置文件实现:

http://blog.csdn.net/gyb_csdn/article/details/75123575

你可能感兴趣的:(spring,mvc,swagger)