学习计划安排如下:
使用axios发送请求,当然为了后续方便,axios被封装到了自定义的common组件中。
所以后续需要发送请求时,直接使用ly.http即能发送请求,就等价于使用axios一样。
自定义组件中配置了axios的基础请求路径baseURL,所以请求的完整路径是baseURL加上post方法中编写的请求路径。
其中存在有一个跨域问题,目前来说我们一共定义了4个域名:
当然这些域名目前都是假的,但是真实的开发中会使用到真的域名。
无论是后台管理系统还是前台门户系统,它们发送请求时都要跨域到网关,所以需要解决跨域问题。
在第144天学习笔记中有解决跨域问题的完整方案,我做一个简单的说明:
本来是要使用cors调用api给各个相关属性设定值,但是在springBoot中可以使用yam配置文件说明。
上述就是给各个属性设定了对于的值,核心属性就是allowedOrigins,意味着允许跨域的域名。
因为都是要跨域到网关,所以需要在网关微服务中做好配置。
1请求相关说明
①请求参数
因为请求参数为json数据,所以创建一个实体类SearchRequest和其对应。
在controller层中使用注解@RequestBody将请求参数转换成SearchRequest对象。
其中要注意的是:
在后台管理系统中管理人员可以自行设定分页大小,但是在前台门户系统中一般分页大小都会设定好一个固定的值,不会让用户自行决定。
②请求方式和请求路径
Post请求,真实路径为page。
③返回值
为商品分页数据,关于分页实体类很早的时候就配置在了common微服务中。
但凡是需要分页的,直接调用该实体类即可。
2service层代码
①获取请求参数并校验
我们昨天就以京东为例说明过,搜索参数不能为空,如果为空会查不到数据。
key字段虽然在前端也有校验不能为空,但是前端校验只能防君子不能防小人,所以后台最好也要加一个校验。
②原生的查询
queryBuilder这个对象可以链式编程,说明查询相关,api都是以with开头:
③搜索查询结果
通过goodsRepository调用search查询,参数即为queryBuilder调用build()方法。
反正这种以Builder为后缀的类,最后要用build()方法结尾。
3关于Repository
Repository本身就是仓库、资源库的意思,其就相当于以前一直接触的mapper层。
只不过在索引库搜索中是使用Repository,继承ElasticsearchRepository接口即可使用了。
上述代码中索引库的原生查询在第162天学习笔记中就详细学过,如果忘记了可以做一个回顾。
至于前端拿到响应的数据后,如何完成页面的渲染就不说明,暂且没时间学完这些。