Traveller2历险

Posted 闲鱼编程笔记

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Traveller2历险相关的知识,希望对你有一定的参考价值。

前段时间发布的Traveller项目,花费了不少精力,但是效果并不如意,根源在于瀑布式的开发思想不适合这种独立的学习项目。在项目初始就规划一个全面的web系统,,因为预设了一个前景,在心理上会想尽快看到效果,为了达到这样的目的,会找一些例子直接使用,不会花时间去思考为什么这么做。摊子铺得太开,随后丧失了全面维护的耐心,精力也跟不上了。

这个Decoration项目,在原来的项目基础上开发,我计划用一种新的思路。不做宏观的效果预设,从一个小的功能开始逐渐深入,直到发现要添加新的东西进来的时候,再去考虑通过小规模的演进迭代增加进来。这样的好处是每次迭代只关注一点,循序渐进,控制节奏,压力小一点,权当是业余练手。

因为是开发练习,尽可能省掉重量级的配套,直接用内存数据库H2代替mysql,用内置服务器代替Tomcat,这样更关注技能点的实现,少了外部的干扰。也不要急着传到GitHub上,等到有一定的雏形的时候再上传,上传之后,也不要改一点东西就更新,总之这些外部的东西都不是重点,重点是技术本身,抓大放小,有的放矢,不忘初心。

我会在这里陆续记录开发中遇到的各种坑,附带上坑的解决办法,这不是通用的开发教程,那种教程网上已经写得比较多了,我就不要再插一腿了。

4月7日之前的工作进展

1、基本的环境的设定

Eclipse(放弃了STS,采用了更通用的版本):配好maven路径

JDK8:设置环境变量

Maven:需要JAVA_HOME、MAVEN_HOME环境变量,为了更快地下载jar包,需要在配置文件中增加新的阿里镜像,以前需要等好几个小时的项目编译,现在5min搞定。

<mirrors>
    <mirror>
      <id>alimaven</id>
      <name>aliyun maven</name>
      <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
      <mirrorOf>central</mirrorOf>       
    </mirror>
  </mirrors>

 Spring:SpringBoot + SpringDataJPA + H2(内置数据库)

//热部署所用的依赖,这样改了代码不用重启内置服务器,方便太多了
org.springframework.springloaded 
//用户把项目打包成jar的依赖
spring-boot-maven-plugin
//定义实体的时候可以用@DATA省略掉对应的set和get方法,也很方便
org.projectlombok.lombok

 2、建立最基本的Repository、Controller

运行 mvn spring-boot:run,成功提示helloword

3、下面就是要讲数据真正写到数据并能够查出来了

第一步,现在系统启动之后能够默认插入进去一些数据,这样我们先可以查,因为查询总是最简单的,方法是用CommandLineRunner,实现这个借口的bean,会在application启动之后自动执行,我只需要在这个bean里面把预制的数据save到表里面。application关闭的时候就会自动清除这些数据。

第二步,H2数据库有个web终端,可以用图形的方式查看库里面的数据,先要打开配置application.properties,增加一条

spring.h2.console.enabled=true

然后访问,http://localhost:8080/h2-console

点击连接就能够登录到数据库,这是你会看到,我定义的实体已经默认生产了数据库结构,CommandLineRunner里面默认的数据也已经插入进去了。这里需要注意的是上图中的JDBC URL,默认的数据库为jdbc:h2:mem:h2db,要查询真正的本系统建立的数据库需要打开一个配置项,再从日志中找到真正的URL,这个配置项如下:

logging.level.org.hibernate=DEBUG

4、要在前台显示实体数据

(1)先要显示出一个正常的index.html来,那么普通的html非动态资源怎么显示呢,只要放到工程的resource/static或者resource/pubilc目录下就行了,搞定

(2)先用PostMan查一下,后端返回的数据到底是什么样的

PostMan是一个chrome的插件,用来方便地查看http的request和response,非常好用

请求返回的数据都是null的,在后台打印一下日志,明确到数据确实是查出来了,之所以返回没有查出来,应该是返回的四个对象没有按照json格式返回成字符串,我们下面的目标就是先把json的数据返回回来。

(3)用spring-boot内置的starter,添加pom依赖如下

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-rest</artifactId>
</dependency>

在Repository上增加注解@RepositoryRestResource,这个注解的意义是让Spring MVC在/people处创建RESTful入口点。这样一来,我们配置的controller就没有用了,先删掉。

@RepositoryRestResource(collectionResourceRel = "customer", path = "customer")
public interface CustomerRepository extends PagingAndSortingRepository<Customer, Long> {
    List<Customer> findByLastName(String lastName);
}

好,重新用PostMan测试一下

Json出来了,为什么没有显示表的内容呢,查看Customer.class反编译出来的源码,发现get/set方法没有,追逐原因,原来是@Data注解没有起作用,使用lombok需要用在Eclipse上进行安装才行,我之前没有安装,只是导入了pom依赖。但是我按照网上的方法安装后,Eclipse无法启动,于是我舍弃lombok(只要修改下eclipse.ini),反正Eclipse自己生产get/set也是点一下鼠标就能做到了,只是代码比较臃肿而已。这会应该没什么问题了:

 

以上是关于Traveller2历险的主要内容,如果未能解决你的问题,请参考以下文章

java历险记之引用类型

RT5350编译UBoot历险记

分布式Redis深度历险-复制

redis深度历险

Adventure 魔幻历险

ThreadPoolExecutor源码历险-主流程常用方法-submit