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 ...
随机推荐
- hdu 1159 Common Subsequence 【LCS 基础入门】
链接: http://acm.hdu.edu.cn/showproblem.php?pid=1159 http://acm.hust.edu.cn/vjudge/contest/view.action ...
- kafka 自启脚本
每次使用的时候都要手动去启动真头痛! 解决办法,自启吧! 方法一: 方法一: /etc/rc.local中添加 文件地址记得替换掉 ,我没使用这种,发现不是每次都行,就换了第二种方法 /usr/loc ...
- epoll浅析以及nio中的Selector
出处: https://my.oschina.net/hosee/blog/730598 首先介绍下epoll的基本原理,网上有很多版本,这里选择一个个人觉得相对清晰的讲解(详情见reference) ...
- Linux基础命令(四)
作业一:1) 开启Linux系统前添加一块大小为15G的SCSI硬盘 [root@bogon ~]# fdisk -l Disk /dev/sda: 21.5 GB, 21474836480 byte ...
- elastic search使用
elastic使用 使用python时注意保持一个好习惯:不要使用类似str.type这样的变量名,很容易引发错误: https://blog.csdn.net/lifelegendc/article ...
- pandas 修改指定列中所有内容
如下图: 读取出来的 DataFrame “code” 列内容格式为:“浪潮信息(000977.XSHE)” 格式,目标效果是:000977.XSHE 代码: df["code"] ...
- gophercloud openstack networking 源码分析
1.network 部分 // Package networks contains functionality for working with Neutron network resources. ...
- CentOS7编译安装MariaDB
一.环境信息: 操作系统版本:CentOS Linux release 7.3.1611 (Core) 内核版本:3.10.0-514.el7.x86_64 MariaDB版本:mariadb-10. ...
- Appium 输入中文
文章出处 http://www.cnblogs.com/ljfight/p/6089163.html 在做app自动化过程中会踩很多坑,咱们都是用中文的app,所以首先要解决中文输入的问题!本篇通过屏 ...
- Bootstrap实现的页面
实现的效果如图,使用bootstrap需要至少三个文件 去bootstrap网上下载,然后使用这三个文件可以了 使用方式,通过标签,class命名来引用已经定制好的html样式 <!DOCTYP ...