OA项目总结(附程序源码)

时间:2022-07-22
本文章向大家介绍OA项目总结(附程序源码),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

项目感知

利用思维导图概括项目实现过程以及所需要实现的各项功能

项目中重要知识点

MVC分层设计模式

mvc简介 m:model 模型层service层和dao层和实体类层 v:view 视图层jsp页面 c:controller 控制层servlet

好处: 1、各司其职,互不干扰。 2、有利于开发当中的分工 3、有利于组件中代码的重用

重定向与请求转发的区别

重定向: 1、客户端发送请求,服务器响应,待服务器响应后客户端又发送请求。两次请求,不共用request,地址改变为目标地址 2、重定向跳转的url采用的是绝对路径

请求转发: 1、一次请求,前后共用一个request,地址不变仍为当前地址 2、请求转发跳转的url采取的是相对路径

JSP中的四个作用域

PageContext 1、生命周期:当对JSP的请求时开始,当响应结束时销毁。 2、作用范围:整个JSP页面,是四大作用域中最小的一个,即超过这个页面就不能够使用了。

Request 1、生命周期:在service 方法调用前由服务器创建,传入service方法。整个请求结束,request生命结束。 2、作用范围:整个请求链(请求转发也存在)。 3、作用: 在整个请求链中共享数据。最常用到:在Servlet 中处理好的数据交给Jsp显示,此时参数就可以放置在Request域中带过去

Session 1、生命周期:在第一次调用 request.getSession() 方法时,服务器会检查是否已经有对应的session,如果没有就在内存 中创建一个session并返回。当一段时间内session没有被使用(默认为30分钟),则服务器会销毁该session。 如果服务器非正常关闭(强行关闭),没有到期的session也会跟着销毁。 如果调用session提供的invalidate(),可以立即销毁session。 2、作用范围:一次会话。 3、作用:HttpSession 在服务器中,为浏览器创建独一无二的内存空间,在其中保存会话相关的信息。

Application 1、生命周期:当Web应用被加载进容器时创建代表整个web应用的application对象,当服务器关闭或Web应用被移除时,application对象跟着销毁。 2、作用范围:整个Web应用。

所用插件

前端代码插件 Junit 各种工具类(Dbutil、验证码、ExcelOperate、自定义异常、DateUtil、Constants) 富文本编辑器kindEditor 日历插件My97DatePicker 数据导出为xls:POI 图表显示数据Echarts

项目中踩过的雷

1、更改项目后,需要重新部署相关项目,不然会出现各种访问错误

2、使用jquery时,一定不要忘记给id 选择器加 # 如:$("#btn1")

3、分行的时候一定一定要加空格,不加空格会导致产生sql语句未正确结束的错误,如下语句


 String sql="select dt.*,e.deptno,e.realname,d.deptname from duty dt "
 + "join employee e on dt.empid=e.empid "
 + “join dept d on e.deptno=d.deptno”;
 

4、接上个错误,如果遍历的时候,取的字段名错误,java.sql.SQLException: 列名无效

5、如果servlet发送的日期数据格式为"五月 20, 2019",则需要gson对其格式化,如下:


 Gson gson = new GsonBuilder().setDateFormat(“yyyy-MM-dd HH:mm:ss”).create();
 //按照 yyyy-MM-dd HH:mm:ss格式化。勿忘重启服务器
 

6、两种Date java.util.Date 时间格式: 年-月-日 时:分:秒.毫秒 java.sql.Date 时间格式:年-月-日 java.sql.Date转为java.util.Date java.sql.Date date=new java.sql.Date(); java.util.Date d=new java.util.Date (date.getTime());

7、在写ajax时,注意单词拼写问题,如果发现所有逻辑都一样但是就是不出结果过,这说明应该是自己的单词拼写的问题(datetype/dataType)


 /* date:{“empId”:empId,“deptno”:deptno,“dtDate”:dtDate},
 datetype:“text”,  */
 data:{“empId”:empId,“deptno”:deptno,dtDate:dtDate},
 dataType:“text”,
 

8、报非法参数错误,一般是由于在jsp页面中声明的变量名与下面传值的变量名不一致导致,注意仔细观察 如: var dtDate——>var dtDtate 但在href拼接是变量名残缺用dtDate

9、

String  typeArr[]=request.getParameterValues(“type”);  用于接收jsp页面的数组数据
String empId=request.getParameter(“empId”);            用于接收的单个数据

10、在jsp页面的书写中,使用el表达式应注意:

${param.expId} <==> request.getParameter(“expId”)
 request.setAttribute(“key”,value)???

11、在新建一个servlet项目时,在继承baseServleth后需要: 删注解(@override),改访问修饰符(propected 为 pulic,否则会404)

12、在Oracle中插入日期型数据: to_date(‘2014-02-14’,‘yyyy-mm-dd’) 在Oracle将(已存储的)日期型数据转换成字符型数据: to_char(dt.dtdate,‘YYYY-MM-DD’) 将数据库中的数据与jsp页面中的日期数据比较时,使用

13、Ajax书写格式

$.ajax({
url:" ",
type:“post”,
data:{“key”,value},
dataType:“text”,
success:function(data){
});

注:第一个:data:{key,value},可省略,用于控制层获取相关的值,request.getParameter(“key”); 第二个:data:形参,用于表示从控制层传来的值,一般会alert一下(alert(data);)

14、""" 作用: 输出双引号

System.out.println("""+a+""");-----》“a” 

项目源码分享

项目数据库表以及源码见百度云,下载后请根据修改db.properties 链接:https://pan.baidu.com/s/1tiNfz9HQNUaZjF_Mjyjkpg 提取码:83ip