名称:酒店订餐系统 目的:常见的javaweb的一些写法总结 说明:未使用javaweb框架,数据使用mysql,根目录下有sql脚本,用户名密码写在c3p0配置文件中
工具类JdbcUtils中实现常用操作 c3p0配置中,创建连接时指定数据库发送sql语句采用的编码
jdbc:mysql:///hotel?useUnicode=true&characterEncoding=utf8
具体写法:(1)转义字符&
(2)CDATA批量转义
<property name="jdbcUrl">jdbc:mysql://localhost:3306/hotel?useUnicode=true&characterEncoding=utf8</property>
<![CDATA[jdbc:mysql://localhost:3306/hotel?useUnicode=true&characterEncoding=utf8]]>
Food类
BeanFactory类中实现
BeanFactory工厂类中定义getInstance方法读取对应的Dao实现类名,供service层调用创建实例
FoodTypeDao dao = new FoodTypeDao();//直接实例化
IFoodTypeDao dao = new FoodTypeDao();//对象创建不能写死
IFoodTypeDao dao = BeanFactory.getInstance("foodTypeDao", IFoodTypeDao.class) ;//声明接口的引用变量,指向通过配置文件实例化的实现该接口的类
WebUtils中定义,servlet调用
//定义方法
private void goTo(HttpServletRequest request, HttpServletResponse response,Object uri)
throws ServletException, IOException {
if(uri instanceof RequestDispatcher){
((RequestDispatcher) uri).forward(request, response);
}else{
response.sendRedirect(request.getContextPath()+(String)uri);
}
}
//定义参数
uri = request.getRequestDispatcher("/sys/foodtype/cuisineList.jsp");
uri = "/error/error.jsp";
//调用方法
goTo(request, response, uri);
抽取出BaseServlet优化servlet BaseServlet继承HttpServlet,其他所有servlet继承BaseServlet继承HttpServlet 父类通过反射getDeclaredMethod方法调用子类方法,只要子类中不重写父类中方法,则调用父类中方法 注意,父类中首先实例化的service对象用protected修饰,private修饰需要对得到的参数method设置method.setAccessible(true);
查询条件封装类Condition再次封装在PageBean中作为参数,在FoodServlet中封装参数,传递给FoodDao实现查询
sql语句格式化,参数list、条件append
BeanUtils:(FoodTypeDao类)BeanHandler、BeanListHandler
定义TableStatus实体类(枚举),在DinnerTableDao中判断
${pageContext.request.contextPath },写成相对路径
foodtype_list.jsp
web.xml中配置拦截条件filter-mapping和filter,一个特殊的servlet EncodingFilter中需要区分GET和POST请求
FoodServlet中update方法仅用来说明文件的上传
没有全局变量即可设为单例,防止线程安全问题,如FoodTypeDao可设为单例