当前位置: 首页 > news >正文

高度重视部门网站建设手机创建个人网站 免费

高度重视部门网站建设,手机创建个人网站 免费,备案之后怎样把 放到网站上,wordpress加入购买功能介绍 相信无论是前端还是后端开发#xff0c;都或多或少地被接口文档折磨过。前端经常抱怨后端给的接口文档与实际情况不一致。后端又觉得编写及维护接口文档会耗费不少精力#xff0c;经常来不及更新。其实无论是前端调用后端#xff0c;还是后端调用后端#xff0c;都期望…介绍 相信无论是前端还是后端开发都或多或少地被接口文档折磨过。前端经常抱怨后端给的接口文档与实际情况不一致。后端又觉得编写及维护接口文档会耗费不少精力经常来不及更新。其实无论是前端调用后端还是后端调用后端都期望有一个好的接口文档。但是这个接口文档对于程序员来说就跟注释一样经常会抱怨别人写的代码没有写注释然而自己写起代码起来最讨厌的也是写注释。所以仅仅只通过强制来规范大家是不够的随着时间推移版本迭代接口文档往往很容易就跟不上代码了。 发现了痛点就要去找解决方案。解决方案用的人多了就成了标准的规范这就是Swagger的由来。通过这套规范你只需要按照它的规范去定义接口及接口相关的信息。再通过Swagger衍生出来的一系列项目和工具就可以做到生成各种格式的接口文档生成多种语言的客户端和服务端的代码以及在线接口调试页面等等。这样如果按照新的开发模式在开发新版本或者迭代版本的时候只需要更新Swagger描述文件就可以自动生成接口文档和客户端服务端代码做到调用端代码、服务端代码以及接口文档的一致性。 Swagger官网https://swagger.io/ 框架说明 现在SWAGGER官网主要提供了几种开源工具提供相应的功能。可以通过配置甚至是修改源码以达到你想要的效果 Swagger Codegen: 通过Codegen 可以将描述文件生成html格式和cwiki形式的接口文档同时也能生成多钟语言的服务端和客户端的代码。支持通过jar包dockernode等方式在本地化执行生成。也可以在后面的Swagger Editor中在线生成。 Swagger UI:提供了一个可视化的UI页面展示描述文件。接口的调用方、测试、项目经理等都可以在该页面中对相关接口进行查阅和做一些简单的接口请求。该项目支持在线导入描述文件和本地部署UI项目。 Swagger Editor: 类似于markendown编辑器的编辑Swagger描述文件的编辑器该编辑支持实时预览描述文件的更新效果。也提供了在线编辑器和本地部署编辑器两种方式。 Swagger Hub集成了上面所有项目的各个功能你可以以项目和版本为单位将你的描述文件上传到Swagger Hub中。在Swagger Hub中可以完成上面项目的所有工作需要注册账号分免费版和收费版。 PS Springfox Swagger: Spring 基于swagger规范可以将基于SpringMVC和Spring Boot项目的项目代码自动生成JSON格式的描述文件。本身不是属于Swagger官网提供的在这里列出来做个说明方便后面作一个使用的展开。其实swagger是有两个版本的区别还挺大的一个是swagger-ui也就是swagger1;还有一个是springfox-swagger也就是swagger2; 总结 Swagger 是一个规范和完整的框架用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。使用Swagger就是把相关的信息存储在它定义的描述文件里面yml或json格式再通过维护这个描述文件可以去更新接口文档以及生成各端代码。而Springfox-swagger,则可以通过扫描代码去生成这个描述文件连描述文件都不需要再去维护了。所有的信息都在代码里面了。代码即接口文档接口文档即代码。总体目标是使客户端和文件系统作为服务器以同样的速度来更新。文件的方法参数和模型紧密集成到服务器端的代码允许API来始终保持同步。 作用 接口的文档在线自动生成功能测试 SpringBoot集成Swagger 初始实现步骤 1. 添加Maven依赖 dependencygroupIdio.springfox/groupIdartifactIdspringfox-swagger2/artifactIdversion2.9.2/version /dependency dependencygroupIdio.springfox/groupIdartifactIdspringfox-swagger-ui/artifactIdversion2.9.2/version /dependency 2. 编写HelloController测试确保运行成功 RestController public class SwapperControllerTest {GetMapping(/swapperTest)public String swapperTest(String name){return name;} } 3. 编写一个配置类-SwaggerConfig(或者通过在项目启动类上加EnableSwagger2注解)来配置 Swagger Configuration //配置类 EnableSwagger2// 开启Swagger2的自动配置 public class SwaggerConfig {} 启动类加注解 以上方法2选1即可 4. 访问测试 http://localhost:8080/swagger-ui.html 可以看到swagger的主界面 注意: 如果启动报错空指针是因为springboot2.6.0中将SpringMVC 默认路径匹配策略从AntPathMatcher 更改为PathPatternParser导致出错可以在启动类上加上EnableWebMvc注解或者在配置中切换为原先的AntPathMatcherspring.mvc.pathmatch.matching-strategyant_path_matcher 配置Swagger 1. Swagger实例Bean是Docket所以通过配置Docket实例来配置Swagger Bean //配置docket以配置Swagger具体参数 public Docket docket() {return new Docket(DocumentationType.SWAGGER_2); } 2. 可以通过apiInfo()属性配置文档信息 private ApiInfo createApiInfo(){Contact contact new Contact(testName,www.baidu.com,277277727727163.com);return new ApiInfo(Swagger学习, // 标题学习演示如何配置Swagger, // 描述v1.0, // 版本http://ape.com, // 组织链接contact, // 联系人信息Apach 2.0 许可, // 许可许可链接, // 许可连接new ArrayList()// 扩展); 3. Docket 实例关联上 apiInfo() Bean public Docket docket() {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()); } 4. 重启项目访问测试 http://localhost:8080/swagger-ui.html 看下效果 配置扫描接口 1. 构建Docket时通过select()方法配置怎么扫描接口 //配置swapper主页信息Beanpublic Docket docket(){return new Docket(DocumentationType.SWAGGER_2).apiInfo(createApiInfo()).select()// 通过.select()方法去配置扫描接口,RequestHandlerSelectors配置如何扫描接口.apis(RequestHandlerSelectors.basePackage(com.ape.springboot_swapper.controller)).build();} 2. 重启项目测试由于我们配置根据包的路径扫描接口所以我们只能看到一个类 3. 除了通过包路径配置扫描接口外还可以通过配置其他方式扫描接口这里注释一下所有的配置方式 any() // 扫描所有项目中的所有接口都会被扫描到 none() // 不扫描接口 // 通过方法上的注解扫描如withMethodAnnotation(GetMapping.class)只扫描get请求 withMethodAnnotation(final Class? extends Annotation annotation) // 通过类上的注解扫描如.withClassAnnotation(Controller.class)只扫描有controller注解的类中的接口 withClassAnnotation(final Class? extends Annotation annotation) basePackage(final String basePackage) // 根据包路径扫描接口 4. 除此之外我们还可以配置接口扫描过滤 // 配置如何通过path过滤,即这里只扫描请求以/apesource开头的接口 .paths(PathSelectors.ant(/apesource/**)) 5. 这里的可选值还有 any() // 任何请求都扫描 none() // 任何请求都不扫描 regex(final String pathRegex) // 通过正则表达式控制 ant(final String antPattern) // 通过ant()控制 配置API分组 1. 如果没有配置分组默认是default。通过groupName()方法即可配置分组 Bean public Docket docket(Environment environment) {return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).groupName(hello) // 配置分组// 省略配置.... } 2. 重启项目查看分组 3. 如何配置多个分组配置多个分组只需要配置多个docket即可 // 多个分组Bean Docket docket2(){return new Docket(DocumentationType.SWAGGER_2).groupName(test2);}Bean Docket docket3(){return new Docket(DocumentationType.SWAGGER_2).groupName(test3);}Bean Docket docket4(){return new Docket(DocumentationType.SWAGGER_2).groupName(test4);}Bean Docket docket5(){return new Docket(DocumentationType.SWAGGER_2).groupName(test5);} 拓展其他皮肤 我们可以导入不同的包实现不同的皮肤定义 1.默认的访问 http://localhost:8080/swagger-ui.html dependencygroupIdio.springfox/groupIdartifactIdspringfox-swagger-ui/artifactIdversion2.9.2/version /dependency bootstrap-ui 访问 http://localhost:8080/doc.html dependencygroupIdcom.github.xiaoymin/groupIdartifactIdswagger-bootstrap-ui/artifactIdversion1.9.1/version /dependency 常用注解 swagger通过注解生成接口文档包括接口名、请求方法、参数、返回信息的等等。 1. Api修饰整个类描述Controller的作用 语法Api(tags说明该类的作用可以在UI界面上看到的注解value /类的访问路径, description 类的文字描述) 2. ApiOperation描述一个类的一个方法说明方法的作用 语法ApiOperation(value “接口说明”, httpMethod “接口请求方式”, response “接口返回参数类型”, notes “接口发布说明” 3. ApiImplicitParam一个请求参数 语法ApiImplicitParam(required “是否必须参数”, name “参数名称”, value “参数具体描述”,dateType变量类型”,paramType请求方式” · header -- 请求参数的获取RequestHeader · query -- 请求参数的获取RequestParam · path用于restful接口-- 请求参数的获取 PathVariable · body不常用 · form不常用 4. ApiImplicitParams 多个请求参数 5. ApiParam单个参数描述 语法ApiParam(required “是否必须参数”, name “参数名称”, value “参数具体描 述”,dateType变量类型”,paramType请求方式” 6. ApiResponseHTTP响应其中1个描述,响应配置 语法ApiResponse(code 400, message Invalid user supplied) 7. ApiResponsesHTTP响应整体描述 语法ApiResponses({ ApiResponse(code 400, message Invalid Order) }) 8. ApiModel用对象实体来作为入参 9. ApiProperty用对象接实体收参数时描述对象的一个字段 10. ApiIgnore使用该注解忽略这个API 11. ApiError 发生错误返回的信息 测试 创建实体类与测试类并使用注解 NoArgsConstructor AllArgsConstructor Data ApiModel(value 控制器方法返回值,description 自定义结果集) public class Result {ApiModelProperty(name state,value 结果集状态,example true)private boolean state;ApiModelProperty(name message,value 消息,example abc)private String message;ApiModelProperty(name date,value 数据集)private Object date; } RestController Api RequestMapping(/user) public class SwapperControllerTest02 {GetMapping(/findByName)ApiOperation(value 根据用户名查询)public Result findByName(String name){if(name.equals(aaa)){return new Result(true,成功,aaa);}else {return new Result(false,失败,bbb);}} } 使用注解后效果如下 Swagger会自动识别接口请求方式参数类型个数返回结果等信息 点击Try it out测试接口 输入对应参数点击执行、 成功后返回相关信息
文章转载自:
http://www.morning.wtdyq.cn.gov.cn.wtdyq.cn
http://www.morning.wyjpt.cn.gov.cn.wyjpt.cn
http://www.morning.zrpbf.cn.gov.cn.zrpbf.cn
http://www.morning.nlhcb.cn.gov.cn.nlhcb.cn
http://www.morning.dcmnl.cn.gov.cn.dcmnl.cn
http://www.morning.wtcyz.cn.gov.cn.wtcyz.cn
http://www.morning.huarma.com.gov.cn.huarma.com
http://www.morning.zcnwg.cn.gov.cn.zcnwg.cn
http://www.morning.zgpgl.cn.gov.cn.zgpgl.cn
http://www.morning.rrwgh.cn.gov.cn.rrwgh.cn
http://www.morning.kcdts.cn.gov.cn.kcdts.cn
http://www.morning.xnyfn.cn.gov.cn.xnyfn.cn
http://www.morning.gfpyy.cn.gov.cn.gfpyy.cn
http://www.morning.fzwf.cn.gov.cn.fzwf.cn
http://www.morning.mmqng.cn.gov.cn.mmqng.cn
http://www.morning.kwwkm.cn.gov.cn.kwwkm.cn
http://www.morning.fzwf.cn.gov.cn.fzwf.cn
http://www.morning.bwqcx.cn.gov.cn.bwqcx.cn
http://www.morning.xhftj.cn.gov.cn.xhftj.cn
http://www.morning.lgmty.cn.gov.cn.lgmty.cn
http://www.morning.wbysj.cn.gov.cn.wbysj.cn
http://www.morning.qmbgb.cn.gov.cn.qmbgb.cn
http://www.morning.ogzjf.cn.gov.cn.ogzjf.cn
http://www.morning.tpchy.cn.gov.cn.tpchy.cn
http://www.morning.lmbm.cn.gov.cn.lmbm.cn
http://www.morning.mtdfn.cn.gov.cn.mtdfn.cn
http://www.morning.dmwbs.cn.gov.cn.dmwbs.cn
http://www.morning.pffqh.cn.gov.cn.pffqh.cn
http://www.morning.rggky.cn.gov.cn.rggky.cn
http://www.morning.skwwj.cn.gov.cn.skwwj.cn
http://www.morning.hjwkq.cn.gov.cn.hjwkq.cn
http://www.morning.nzhzt.cn.gov.cn.nzhzt.cn
http://www.morning.npgwb.cn.gov.cn.npgwb.cn
http://www.morning.plwfx.cn.gov.cn.plwfx.cn
http://www.morning.bqqzg.cn.gov.cn.bqqzg.cn
http://www.morning.bmlcy.cn.gov.cn.bmlcy.cn
http://www.morning.bqxxq.cn.gov.cn.bqxxq.cn
http://www.morning.lbxhy.cn.gov.cn.lbxhy.cn
http://www.morning.tqxtx.cn.gov.cn.tqxtx.cn
http://www.morning.wmdlp.cn.gov.cn.wmdlp.cn
http://www.morning.tkhyk.cn.gov.cn.tkhyk.cn
http://www.morning.dhbyj.cn.gov.cn.dhbyj.cn
http://www.morning.xqgfy.cn.gov.cn.xqgfy.cn
http://www.morning.msbpb.cn.gov.cn.msbpb.cn
http://www.morning.bmgdl.cn.gov.cn.bmgdl.cn
http://www.morning.bmqls.cn.gov.cn.bmqls.cn
http://www.morning.bxqpl.cn.gov.cn.bxqpl.cn
http://www.morning.rdzlh.cn.gov.cn.rdzlh.cn
http://www.morning.gbfzy.cn.gov.cn.gbfzy.cn
http://www.morning.trqzk.cn.gov.cn.trqzk.cn
http://www.morning.shuangxizhongxin.cn.gov.cn.shuangxizhongxin.cn
http://www.morning.mlfgx.cn.gov.cn.mlfgx.cn
http://www.morning.liyixun.com.gov.cn.liyixun.com
http://www.morning.rsxw.cn.gov.cn.rsxw.cn
http://www.morning.wgkz.cn.gov.cn.wgkz.cn
http://www.morning.kpxnz.cn.gov.cn.kpxnz.cn
http://www.morning.prddj.cn.gov.cn.prddj.cn
http://www.morning.smcfk.cn.gov.cn.smcfk.cn
http://www.morning.tjwfk.cn.gov.cn.tjwfk.cn
http://www.morning.fwblh.cn.gov.cn.fwblh.cn
http://www.morning.zcrjq.cn.gov.cn.zcrjq.cn
http://www.morning.dnqlba.cn.gov.cn.dnqlba.cn
http://www.morning.rgzc.cn.gov.cn.rgzc.cn
http://www.morning.pctsq.cn.gov.cn.pctsq.cn
http://www.morning.pxjp.cn.gov.cn.pxjp.cn
http://www.morning.bxqtq.cn.gov.cn.bxqtq.cn
http://www.morning.qyrnp.cn.gov.cn.qyrnp.cn
http://www.morning.skfkx.cn.gov.cn.skfkx.cn
http://www.morning.cjsrg.cn.gov.cn.cjsrg.cn
http://www.morning.kqwsy.cn.gov.cn.kqwsy.cn
http://www.morning.csxlm.cn.gov.cn.csxlm.cn
http://www.morning.cjmmn.cn.gov.cn.cjmmn.cn
http://www.morning.qrdkk.cn.gov.cn.qrdkk.cn
http://www.morning.xwgbr.cn.gov.cn.xwgbr.cn
http://www.morning.nsmyj.cn.gov.cn.nsmyj.cn
http://www.morning.ktxd.cn.gov.cn.ktxd.cn
http://www.morning.rksg.cn.gov.cn.rksg.cn
http://www.morning.fndmk.cn.gov.cn.fndmk.cn
http://www.morning.wcjgg.cn.gov.cn.wcjgg.cn
http://www.morning.lbqt.cn.gov.cn.lbqt.cn
http://www.tj-hxxt.cn/news/259602.html

相关文章:

  • 微信公众号做微网站吗福建省建设干部培训中心网站首页
  • 企业多语言网站开发备案名 网站名
  • 查询网站到期时间阿里万网怎么做网站
  • 义乌网站建设托管平面图怎么画
  • 外贸网站营销方案中国菲律宾足球直播
  • 长沙网站设计报价wordpress 主机和域名绑定域名
  • 手机网站发布页电脑版网站滑块验证怎么做
  • 网站打开速度慢优化济南市规划局官网
  • 济南企业网站建设哪家好寿光建设局网站
  • 万维网站续费多少一年电竞网站方案设计
  • 做代收的网站有哪些网站报错 500
  • 西安专业做网站公司屏山县龙华镇中心村建设招标网站
  • 亚马逊网站链接兰州手机网站制作公司哪家好
  • 哪些网站可以免费做代码网站开发公司怎么接单子
  • 建设网站美海房地产免费域名qq空间申请
  • 零六年自助建设网站站内关键词排名软件
  • 企腾做的网站怎么样天津品牌网站建设是什么
  • 网站建设 推神网络asp网站相册
  • 简述电子商务网站开发流程企业网站必须备案吗
  • 网站优化的监测评价晋中城市建设招标网站
  • php做网站需要学的东西服务器机柜
  • 公司网站建设费用会计处理网友
  • 百度推广登陆wordpress商品分类标题seo
  • 公司免费招聘网站如果想看网站的收费电影应该怎么做
  • 四川住房和城乡建设厅网站题库html编辑器怎么用
  • 莱芜手机网站设计公司wordpress文章如何去除p节点
  • pagekit和wordpress青岛网站seo
  • 石油大学 网页设计与网站建设wordpress edit_post
  • 手机pc微信三合一网站云服务器网站崩溃的原因
  • 做汽车微信广告视频网站有哪些清理大师