资讯专栏INFORMATION COLUMN

读取@RequestMapping生成路径列表

PiscesYE / 3471人阅读

摘要:引言在试用时,使用进行路径映射。特别是移动端,需要对映射路径进行打印,生成表格,以便其他平台进行模板调用。于是我们来讨论一下基本配置对该项目需要整理的路径的基本读取配置。这里选用项目路径,路径包,输出的位置,是否直接覆盖文件这四个配置项。

引言

在试用springmvc时,使用@RequestMapping进行路径映射。特别是移动端,需要对映射路径进行打印,生成表格,以便其他平台进行模板调用。于是我们来讨论一下

基本配置

对该项目需要整理的路径的基本读取配置。
这里选用项目路径,路径包,输出的位置,是否直接覆盖文件这四个配置项。

    //项目路径
    private static String PROJECT_PATH = "F:/eclipse/workspace/created/src/";
    //扫描包
    private static String SACNNER_PACKAGE = "com/create/api/";
    //输出文件的映射路径的位置
    private static String WRITE_TXT_PATH = "F:/mapper.txt";
    //是否直接覆盖文件
    private static boolean RE_WRITE = true;
主体代码

以下为主题代码内容

    /**
     * 写出文档
     */
    private void writerMapper(){
        File write_file = new File(WRITE_TXT_PATH);
        if(write_file.exists()&&!RE_WRITE){
            System.out.println("文件已存在  "+write_file.getAbsolutePath());
            return;
        }
        
        if(RE_WRITE){
            System.out.println("文件覆盖写入...");
        }
        
        String[] filepathes = getFilePathes(PROJECT_PATH+SACNNER_PACKAGE);
        Writer w= null;
        try {
            w = new FileWriter(write_file);
            for (int i = 0; i < filepathes.length; i++) {
                File f = new File(PROJECT_PATH+SACNNER_PACKAGE+filepathes[i]);
                try {
                    w.write("
");
                    w.write("[======="+filepathes[i]+"========]
");
                    w.write(readMapper(f));
                    w.flush();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
            w.close();
        } catch (IOException e1) {
            e1.printStackTrace();
        }
    
        System.out.println("文件写入完成  "+write_file.getAbsolutePath());
    }
    /**
     * 获取目标路径下所有的文件名称
     * @param parentPath
     * @return
     */
    private String[] getFilePathes(String parentPath){
        File f = new File(parentPath);
        String[] fiel = f.list();
        return fiel;
    }
    /**
     * 读取文件下的@RequestMapper注解,将整理好的路径内容返回
     * @param parentPath
     */
    private String readMapper(File f) throws IOException{
        BufferedReader br = new BufferedReader(new FileReader(f));
        StringBuffer sb = new StringBuffer();
        int i = 0;
        String classpath = "";
        while (br.ready()){
            String mapper = br.readLine();
            mapper = trim(mapper);
            if(mapper.startsWith("@RequestMapping")){
                String m = mapper.substring("@RequestMapping(".length(),mapper.length()-1);
                m = m.replace("value=", "");
                m = m.replace("method=RequestMethod.", "");
                m = m.replace(""", "");
                if(i==0){
                    classpath = m;
                    i++;
                    continue;
                }else{
                    sb.append(i+". ");
                }
                sb.append(classpath);
                sb.append(m);
                if(i>0)
                    if(!(m.endsWith("GET")||m.endsWith("POST")))
                        sb.append(",GET");
                String nextLine = br.readLine();
                nextLine = trim(nextLine);
                String ending = "    页面跳转";
                if(nextLine.startsWith("@ResponseBody")){
                    ending="    获取数据 ";
                }
                sb.append(ending);
                sb.append("  [ ]");
                sb.append("
");
                i++;
            } 
        }
        br.close();
        return sb.toString();
    }
去掉空白字符
在操作时需要对空白字符全部去除,空白字符包括

 回车(u000a) 
	 水平制表符(u0009)
s 空格(u0008) 

 换行(u000d)

具体操作

    /**
     * 去掉空白字符
     * @param str
     * @return
     */
    private String trim(String str){
        str = str.replace(" ", "")
        .replace("	", "")
        .trim();
        return str;
    }

至此已经完成内容

内容扩展

在内容上面需要扩展的部分

写的时候发现,导出的路径方式需要提供内容描述,但是本文中只提供了[] 符号,用于填写路径描述,所以该部分不够完善。

因此,在完成这部分时,需要添加注释注解 @title 或者此外的任意便于识别的注释注解,在读取时,就将标题内容读取出来,在读取到该部分的时候将标题插入。

去掉的字符应该包括 [value=] [param=]两组  

更多扩展需要自己拓展。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/64956.html

相关文章

  • 慕课网_《解密JAVA实现Excel导入导出》学习总结

    时间:2017年07月06日星期四说明:本文部分内容均来自慕课网。@慕课网:http://www.imooc.com教学源码:无学习源码:https://github.com/zccodere/s... 第一章:课程介绍 1-1 预备知识 基础知识 struts2框架(上传下载功能) xml解析技术(导入模板) JQuery EasyUI(前台美观) 课程目录 实现方式 定制导入模版 导入文件 导...

    enrecul101 评论0 收藏0
  • Spring实战5-基于Spring构建Web应用

    摘要:的框架用于解决上述提到的问题,基于模型,可以帮助开发人员构建灵活易扩展的应用。在这一章中,将专注于构建该应用的层,创建控制器和显示,以及处理用户注册的表单。类有两个静态接口,代表两种模拟服务的方式独立测试和集成测试。 主要内容 将web请求映射到Spring控制器 绑定form参数 验证表单提交的参数 写在前面:关于Java Web,首先推荐一篇文章——写给java web一年左右...

    sourcenode 评论0 收藏0
  • 关于 express 路由管理的几种自动化方法

    摘要:在方法装饰器的编写上,由于装饰器的行为相似,因此我们可以编写一个抽象函数,用来生成不同请求方法的不同装饰器。文章博客地址关于路由管理的几种自动化方法 前言 我们平时在使用express写代码的过程中,会根据类别,将路由分为多个不同的文件,然后在项目的入口文件(例如app.js)中将其依次挂载,例如: const index = require(./routes/index) const...

    chaosx110 评论0 收藏0
  • Spring Boot QuickStart (3) - Web & Restful

    摘要:不过可以切换到版本,兼容性未知。注解一旦添加了依赖会判断这是一个应用,并启动一个内嵌的容器默认是用于处理请求。注意中空字符串与的区别。 环境:Spring Boot 1.5.4 基于 Spring Boot 可以快速创建一个Web & Restful 应用,在开始应用之前,至少要了解以下用法: 定义路由,定义 HTTP 方法 获取Header、GET、POST、路径等参数 Cooki...

    chnmagnus 评论0 收藏0
  • SpringMVC之源码分析--HandlerMapping(四)

    摘要:默认支持该策略。以上是对的宏观分析,下面我们进行内部细节分析。整体流程一通过实现接口,完成拦截器相关组件的初始化调用类的方法。总结本文主要分析了的初始化过程,希望对大家有帮助。随着学习的深入,后面有时间在分析下期中涉及的关键,比如等等。 概述 本节我们继续分析HandlerMapping另一个实现类ReqeustMappingHandlerMapping,该类是我们日常开发中使用最多的...

    imccl 评论0 收藏0

发表评论

0条评论

PiscesYE

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<