BOS物流项目问题汇总
1 请描述一下这个系 统?
从两个方面回答,
第一个方面:系统背景及系统概述
本系统是基于B/S架构而设计开发的,是某物流公司的一个后台管理系统,属于物流公司整个ERP平台的一个组成部分。本系统是此物流公司的一个二期改造项目,原来此公司存在一个C/S架构的系统,后来业务不断扩大,所以公司决定进行改造。该系统主要有基础设置、取派、中转、路由、报表几大部分组成。
第二个方面:系统包括的业务模块及主业务流程
本系统包括了:基础设置、取派、中转、路由、报表几大部分组成。
扩展问题:
这个系统你做了哪些模块?
负责系统管理模块、基础设置模块的开发。其他模块没有接触到,所以不太清楚。
2 项目周期是多长?团队人数多少?
整个项目周期大概是一年的时间,其中编码阶段大概有4个多月,团队人数20多个人。
3 说说系统的架构?spring的作用?
n 功能架构:
本系统是基于B/S架构而设计开发的,是某物流公司的一个后台管理系统,属于物流公司整个ERP平台的一个组成部分。本系统是此物流公司的一个二期改造项目,原来此公司存在一个C/S架构的系统,后来业务不断扩大,所以公司决定进行改造。该系统主要有基础设置、取派、中转、路由、报表几大部分组成。
n 技术架构:
本系统采用ssh框架开发(struts2.3.24、spring4.2、hibernate5.0.7),web层使用struts2、持久层采用hibernate5,spring管理web层 的action、业务层的service、持久层的dao。前台使用jQuery EasyUI进行页面展示。
spring的作用:
spring管理web层 的action、业务层的service、持久层的dao,对struts的action采用多例的方式管理,对service和dao采用单例方式。
本系统采用声明式事务控制方式对service层进行事务控制,spring和hibernate整合后, spring在service方法开发执行前创建session,开启事务,方法结束提交事务,关闭session。
spring和shiro进行整合开发,spring管理shiro框架的securityManager、realm等bean,另外spring通过cglib方式生成action的代理对象,实现权限控制。
spring和CXF框架整合开发远程调用接口。
4 项目中如何进行事务管理的?
这个项目的事务管理是通过spring的声明式事务进行管理的,具体做法是使用spring提供的事务注解,为Service创建代理对象,由代理对象进行事务控制。
5 这个系统hibernate是怎么用的?或这个系统持久层如何实现的?
本系统使用hibernate5.0.7 版本。
本系统使用hibernate的QBC和HQL两种方式开发。使用hibernate可以大大简化持久层开发。
本系统对Dao层进行封装,采用泛型封装BaseDao,在spring定义bean的配置中通过BaseDao的构造方法动态获得操作的实体类型,这样做的好处是只需要在系统定义一个BaseDao即可,根据模型的不同在spring的配置文件定义不同的Dao。
6 在开发中是否遇到hibernate延迟加载问题?怎么解决的?
在开发中遇到延迟加载问题了,通过spring的OpenSessionInViewFilter过滤器解决这个问题。但这个还不够,比如在页面中使用easyUI的datagrid展示数据,这时在服务端查询到数据后,需要转为json返回给datagrid,这时如果查询到的对象内部引用了关联对象,而这个关联对象是延迟加载的,就无法转为json,这时就需要使用立即加载策略。
7 在你们开发过程中是否使用到了hibernate自动建表功能?
没有使用到,我们所有的数据表都是通过sql自己创建的。
8 这个项目中是否使用到了hibernate的二级缓存?
没有使用到二级缓存,因为虽然缓存可以起到优化的作用,但我们项目要求的都是实时数据,所以没有使用缓存。
ehcache
9 这个系统struts是怎么用的?
本系统采用模型驱动方式编写action,视图层采用jsp。
开发中封装BaseAction,采用泛型由子类指定具体的模型对象类型。
struts中的所有action对象都交由spring创建。
10 这个项目中是否用到struts2的值栈了?
没有用到值栈,因为整个项目页面列表数据展示,都是基于easyUI中datagrid展示的,发送的都是ajax请求,也就是说在服务端都是返回json数据展示到datagrid中,所以不需要值栈。
11 这个系统UI使用什么框架?都用到jquery easy ui的哪些组件?
系统UI使用Jquery easy UI,及jquery库。
系统框架布局使用layout,系统标签窗口采用tabs,系统菜单使用方accordion,数据列表采用datagrid,
弹出窗口 window
消息提示:messager
菜单:menubutton
下拉框:combobox
12 这个系统的认证和授权是怎么实现的?如何使用shiro的?
本系统使用了Apache Shiro框架完成认证和授权。shiro框架中的对象创建由spring负责创建。
shiro框架共提供了4中权限控制方式,本系统中使用到前3种方式:
1、URL拦截权限控制,通过shiro框架提供的过滤器实现
2、方法注解权限控制,通过为Action创建代理对象实现
3、页面标签权限控制,通过shiro框架提供的标签实现
4、代码级别权限控制,通过在程序中调用shiro的API完成权限控制
你们如何使用shiro?
1、自定义了realm,从数据库查询用户密码和用户的权限信息,为了避免多次查询realm使用ehcache缓存。
2、使用shiro主要是要在shiroFilter中配置过虑规则,哪些可以匿名访问,哪些必须要认证。
认证:applicationcode – subject(login)---securityManger—realm
授权:在realm中获得授权信息
原因:只要是要进行权限校验,每次请求都要经过realm授权的方法,授权方法每次都要查询数据库,效率低。
如果将第一次查询到权限放入缓存中,效率可以搞。Shiro已经跟ehcache整合好,我们只需要进行配置。
13 系统中有导入、导出功能吗?怎么实现的?
系统有导入导出功能,对区域数据实现导入和分区数据实现导出。
使用Apache POI组件完成导入和导出Excel
jxl也可以操作Excel
14 作过接口吗?怎么做的?采用什么技术?
在业务受理、自动分单时,bos系统需要调用物流公司的crm系统获取客户信息。
我参考接口文档进行开发,参考接口文档中的参数定义编写代码。
采用CXF框架实现远程调用,由于接口同步的数据量不大,hessian采用框架定义的二进行协议传输数据,速度很快,本系统采用CXF。
在开发时将服务端的接口拷贝至本系统,在 spring的配置文件中配置代理接口,在本系统的service中直接注入调用,非常方便。
15 你了解的还有哪些接口技术?
对于大数据量传输的,自己的系统之间一般我们就直接使用socket的方式传输了。
对于一些公开的接口(不同公司的系统之间的调用),大多采用http的方式定义接口,对于服务端现在流行使用rest方式,对于客户端我们一般使用httpclient调用服务端。
还有一些接口采用webservice(soap协议),这个我们使用过cxf这个框架开发。
axis
hessian
dubbo
16 你是如何和测试人员配合工作的?
每天定时登录项目管理平台,查看有没有自己名下bug,如果有根据测试人员描述的测试场景进行测试,如果存在bug会及时修改,修改完成将bug提交。如果根据测试人员描述的测试场景进行测试,bug不存在,和测试人员沟通。
如果遇到bug来回驳回,我去现场和测试人员进行沟通,针对测试场景看看双方是否一致。
17 你参与过系统维护吗?系统维护的流程是?
参与过,系统维护流程如下:
18 这个项目开发过程中遇到了哪些问题?
遇到的问题很多,有技术方面的,也有非技术方面的:
1、开发工程师的技术水平参差不齐,有些技术稍差的工程师经常不能按时完成项目经理分配的任务,还需要其他人帮忙,导致项目进度缓慢
2、和测试人员沟通困难,有些时候测试人员会提交一些bug,但在我们开发看来根本就不是bug
3、人员不稳定,如果有人离职,新招进来的人不能立即上手,导致项目推进缓慢
19 从这个项目中你收获了什么?
1、整个项目下来,使自己的技术得到了一定的提升
2、虽然自己只是一个开发工程师,但是可以体会到应该站在更高的层次来看待整个项目
3、意识到沟通的重要性
4、结识了一帮兄弟,一起加班一起奋斗