srm开发(基于ssh)(3)
联系人管理
(1)客户和联系人一对多配置(重点)
(2)新增联系人
-新增功能实现
-Struts2实现文件上传
(3)联系人列表
-no session问题
(4)客户和联系人级联删除
联系人管理模块
1 客户和联系人关系
(1)客户和联系人是一对多关系
(2)客户:百度、新浪、阿里巴巴
联系人:百度里面有很多员工
新增联系人页面
//1 到新增联系人页面的方法
public String toAddPage(){
//1.1查询所有客户,把所有客户List集合传递到页面中显示(放到域对象)
//调用客户service里的方法
List<Customer> listCustomer = customerService.findAll();
ServletActionContext.getRequest().setAttribute("listCustomer",listCustomer); return "toAddPage";
}
添加联系人的方法
//2 添加数据到数据库的方法
public String addLinkMan(){
/**
* 可以封装联系人基本信息
* 但是有cid是客户id值不能直接封装的
* 把cid封装LinkMan实体类里面customer对象里面
*
*/
//原始方式实现
String scid = ServletActionContext.getRequest().getParameter("cid");
int cid = Integer.parseInt(scid); //创建customer对象
Customer c = new Customer();
c.setCid(cid);
linkMan.setCustomer(c);
return "addLinkMan";
}
添加联系人还可以这样做
<!-- 把域对象所有客户的list显示到下拉列表中 -->
<select name="customer.cid">
<c:forEach var="customer" items="${listCustomer }">
<option value="${customer.cid }">${customer.custName }</option>
</c:forEach>
</select>
name=customer.cid这样做也是可以的,就可以不用写上面的代码了,它的底层是用上面的代码实现的。
Struts实现文件上传
1 之前web阶段实现上传,使用组件FileUpload,使用 struts2实现文件上传,struts2对之前的FileUpload进行封装
2 如何对上传进行封装
(1)struts2里面使用拦截器对上传进行封装


(2)使用struts2框架方便实现文件上传
3 使用文件上传功能时,form表单要修改enctype属性
<FORM id=form1 name=form1
action="${pageContext.request.contextPath }/linkman_addLinkMan.action"
method=post enctype="multipart/form-data">

* 还有一个变量,上传文件的mime类型
* 服务器只认扩展名所对应的mime类型

实现文件上传代码
//1 上传文件
//变量的名称需要和表单里面文件上传项的name值一样
private File upload; //2 上传文件名称 表单里面文件上传项的name值FileName
private String uploadFileName; //生成get和set方法
public File getUpload() {
return upload;
} public void setUpload(File upload) {
this.upload = upload;
} public String getUploadFileName() {
return uploadFileName;
} public void setUploadFileName(String uploadFileName) {
this.uploadFileName = uploadFileName;
} //2 添加数据到数据库的方法
public String addLinkMan() throws IOException{
//判断是否需要上传文件
if(upload != null){
//写上传代码
//在服务器文件夹里面创建文件
File serverFile = new File("F:/ssh_uploadfile"+"/"+uploadFileName);
//把上传文件复制到服务器文件里面
FileUtils.copyFile(upload, serverFile);
}
4 问题
如果上传文件超过2M,就会出现异常

页面中出现提示
没有input结果定义

(1)使用struts2做文件上传文件大小默认有限制的,默认2M
(2)可以设置上传文件大小
-struts2里面有常量,在struts.xml中进行常量配置,默认常量位置如下图所示:

文件中设置文件上传大小具体位置如下。

struts常量
struts.multipart.maxSize
在struts.xml中修改该值
<!-- 设置上传文件大小 -->
<constant name="struts.multipart.maxSize" value="209715200"></constant>
(3)页面中input处理(上传文件大小可能会超过200M)

-input是struts2里面错误处理机制,如果上传文件超过设置的大小之后,自动返回结果,结果名称是input
-解决:配置input结果,到错误页面。
在响应的action配置如下所示:
<!-- 配置input结果 -->
<result name="input">/jsp/error.jsp</result>
联系人列表功能
1 查询所有的联系人,显示每个联系人所属的客户名称
<td>${linkman.customer.custName }</td>
no session问题

在web.xml中配置如下所示:
<filter>
<filter-name>openSessionInViewFilter</filter-name>
<filter-class>org.springframework.orm.hibernate5.support.OpenSessionInViewFilter</filter-class>
</filter> <filter-mapping>
<filter-name>openSessionInViewFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
2 修改数据
<input type="hidden" name="linkid" value="${linkman.linkid }"/>
利用隐藏项把联系人id传过来。
这是对联系人进行修改。
对客户进行修改时,联系人相应的客户也叫进行修改。如果没有修改,那么联系人的客户会为空。
客户和联系人级联删除
双向维护外键
1 hibernate外键双向维护
(1)在客户和联系人这两端都需要维护外键
(2)解决方式:让其中的一方放弃关系维护(让一的那一方放弃)
<!-- 表示客户所有联系人 -->
<set name="setLinkMan" inverse="true">
inverse默认值是false。
这样做了修改之后,客户修改之后,联系人客户也会进行修改。
2 删除客户后,联系人也删除
hibernate默认会将联系人的外键设为null,然后将再删除客户。
Hibernate:
update
t_linkman
set
clid=null
where
clid=?
Hibernate:
delete
from
t_customer
where
cid=?
把联系人外键设置为null。
要实现级联删除,只要添加属性cascade="delete"即可。
<!-- 表示客户所有联系人 -->
<set name="setLinkMan" cascade="delete">
进行修改之后,可以实现级联删除。
如果只有inverse="true"就会放弃关系维护,删除数据不会设置为null,会报错。
第一个,如果inverse属性值false,表示不放弃
1 删除客户之后,把客户所有的联系人也删除

把联系人外键设置null,删除客户。
第二个 如果inverse属性值true,删除客户时候,出现异常
(0)如果把inverse属性设置为true之后,不能直接删除有关数据,做级联删除,否则
报错如下所示:

(1)在根据客户删除联系人,在客户的映射文件中配置,cascade值delete.
(2)规范写法

srm开发(基于ssh)(3)的更多相关文章
- 基于ssh框架的在线考试系统开发的质量属性
我做的系统是基于ssh框架的在线考试系统.在线考试系统有以下几点特性:(1)系统响应时间需要非常快,可以迅速的出题,答题.(2)系统的负载量也需要非常大,可以支持多人在线考试(3)还有系统的安全性也需 ...
- 实现基于SSH的门票管理系统开发的质量属性
我要做的是一个基于SSH的门票售卖系统,在系统中常见的质量属性有:可用性.可修改性.性能.安全性.易用性. 可用性方面: 可用性是指系统正常运行时间的比例,是通过两次故障之间的时间长度或在系统崩溃情况 ...
- 基于SSH框架的在线考勤系统开发的质量属性
我要开发的是一个基于SSH框架的在线考勤系统. 质量属性是指影响质量的相关因素,下面我将分别从6个系统质量属性(可用性,易用性,可修改性,性能,安全性,可测试性)来分析我的系统,以及如何实现这些质量属 ...
- 基于SSH框架开发的《高校大学生选课系统》的质量属性的实现
基于SSH框架开发的<高校大学生选课系统>的质量属性的实现 对于可用性采取的是错误预防战术,即阻止错误演变为故障:在本系统主要体现在以下两个方面:(1)对于学生登录模块,由于初次登陆,学生 ...
- 基于SSH框架的网上书店系统开发的质量属性
基于SSH框架的网上书店系统开发的质量属性 对于我的基于SSH框架的网上书店系统的开发要实现的质量属性有可用性.可修改性.性能.安全性.易用性和可测试性. 1.对于可用性方面的战术: 可用性(Avai ...
- 基于SSH框架的学生公寓管理系统的质量属性
系统名称:学生公寓管理系统 首先介绍一下学生公寓管理系统,在学生公寓管理方面,针对学生有关住宿信息问题进行管理,学生公寓管理系统主要包含了1)学生信息记录:包括学号.姓名.性别.院系.班级:2)住宿信 ...
- 基于ssh反向代理实现的远程协助
本文描述了怎么通过ssh反向代理实现远程协助,并提供了相关代码. 可满足web开启远程协助功能后,维护人员能够通过ssh和http登录客户机器(包括在nat环境下) web开启该功能后,ssh才能登录 ...
- 【Ansible】 基于SSH的远程管理工具
[Ansible] 参考文档:[http://www.ansible.com.cn/docs/intro.html] 和ansible类似的工具还有saltstack,puppet,sshpass等, ...
- 基于SSH的高校网上选课系统的质量属性的实现
我对于基于SSH的高校网上选课系统的质量属性的实现是从可用性.性能.安全性.可维护性.易用性五个方面进行的实现. 可用性方面: 实现方式:(1)当系统试图超出限制范围来进行课程查询或选课时必须进行错误 ...
- 基于SSH的网上图书商城-JavaWeb项目-有源码
开发工具:Myeclipse/Eclipse + MySQL + Tomcat 项目简介: 技术:Java:JSP:JDBC,struts2,spring,hibernate数据库: mysqlweb ...
随机推荐
- Grammar Rules
Grammar Rules Here are 20 simple rules and tips to help you avoid mistakes in English grammar. For m ...
- C# WinForm 中进行UrlEncode
public static string ToUrlEncode(string strCode) { StringBuilder sb = new StringBuilder(); byte[] by ...
- iOS中nil 、NULL、 Nil 、NSNull
nil,定义一个空的实例,指向OC中对象的空指针. 示例代码: NSString *someString = nil; NSURL *someURL = nil; id someObject = ni ...
- learnyou 相关网站
http://learnyouahaskell.com/ http://learnyouahaskell-zh-tw.csie.org/ http://learnyousomeerlang.com/
- 我的Android进阶之旅------>如何解决Android 5.0中出现的警告: Service Intent must be explicit:
我的Android进阶之旅-->如何解决Android 5.0中出现的警告: java.lang.IllegalArgumentException: Service Intent must be ...
- Feature Pyramid Networks for Object Detection
Feature Pyramid Networks for Object Detection 特征金字塔网络用于目标检测 论文地址:https://arxiv.org/pdf/1612.03144.pd ...
- [ngClass]、[ngStyle]的基本使用(转载)
1.ngStyle 基本用法 <div [ngStyle]="{'background-color':'green'}"></<div> 判断添加 & ...
- MySQL查询操作
查询执行路径中的组件:查询缓存.解析器.预处理器.优化器.查询执行引擎.存储引擎SELECT语句的执行流程: FROM Clause --> WHERE Clause --> GROUP ...
- Hadoop的分布式架构改进与应用
1. 背景介绍 谈到分布式系统,就不得不提到Google的三驾马车:GFS[1],MapReduce[2]和BigTable[3]. 虽然Google没有开源这三个技术的实现源码,但是基于这三篇开源 ...
- http的请求流程
# !/usr/bin/env python # coding:utf-8 import socket def handle_request(client): buf = client.recv(10 ...