package com.nova.common;
import java.io.File;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.io.Reader;
import java.sql.CallableStatement;
import java.sql.Clob;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class DataSync
*/
@WebServlet("/dataSync")
public class DataSync extends HttpServlet {
private static final long serialVersionUID = 1L;
private Connection conn;
private String filePath;
private String orgProvinceId;
private String orgCityId;
private String orgDistrictId;
private String orgTownId;
private String orgVillageId;
/**
* @see HttpServlet#HttpServlet()
*/
public DataSync() {
super();
// TODO Auto-generated constructor stub
}
/**
* @param path
* @see HttpServlet#service(HttpServletRequest request, HttpServletResponse
* response)
*/
protected void service(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
PrintWriter out=response.getWriter();
out.print("1323443554qqqqqqqqqqq");
// orgProvinceId
orgProvinceId = request.getParameter("orgProvinceId");
// orgCityId
orgCityId = request.getParameter("orgCityId");
// orgDistrictId
orgDistrictId = request.getParameter("orgDistrictId");
// orgTownId
orgTownId = request.getParameter("orgTownId");
// orgVillageId
orgVillageId = request.getParameter("orgVillageId");
String fileName = orgProvinceId + orgCityId + orgDistrictId + orgTownId
+ orgVillageId+".sql";
filePath=request.getRealPath("/") + "/" + fileName;
filePath = new String(filePath.getBytes("ISO-8859-1"), "utf-8");
download(filePath, request, response);
}
private void getDBData() {
try {
Properties props = new Properties();
props.load(DataSync.class
.getResourceAsStream("/configs/database/oracle.properties"));
String driver = props.getProperty("db_driver");
String url = props.getProperty("db_url");
String username = props.getProperty("db_user_name");
String password = props.getProperty("db_password");
Class.forName(driver);
conn = DriverManager.getConnection(url, username, password);
String sql = "{call out_file(?,?,?,?,?,?)}";
CallableStatement cst = conn.prepareCall(sql);
// 输入参数的调用
cst.setString(1, orgProvinceId);
cst.setString(2, orgCityId);
cst.setString(3, orgDistrictId);
cst.setString(4, orgTownId);
cst.setString(5, orgVillageId);
// 输出参数的调用
cst.registerOutParameter(6, java.sql.Types.CLOB);
// 执行存储过程
cst.execute();
// 得到存储过程的输出参数值
Clob syncContent =cst.getClob(6);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
public HttpServletResponse download(String path,
HttpServletRequest request, HttpServletResponse response) {
Reader reader = null;
OutputStreamWriter writerClient = null;
try {
// path是指欲下载的文件的路径。
File file = new File(request.getRealPath("/") + "/" + path);
// 取得文件名。
String filename = file.getName();
// 以流的形式下载文件。
InputStream fis = new BufferedInputStream(new FileInputStream(path));
byte[] buffer = new byte[fis.available()];
fis.read(buffer);
fis.close();
// 清空response
response.reset();
// 设置response的Header
response.addHeader("Content-Disposition", "attachment;filename=" + new String(filename.getBytes()));
response.addHeader("Content-Length", "" + file.length());
OutputStream toClient = new BufferedOutputStream(response.getOutputStream());
response.setContentType("application/octet-stream");
toClient.write(buffer);
// 清空response
response.reset();
// 设置response的Header
response.addHeader("Content-Disposition", "attachment;filename="
+ new String(filename.getBytes("utf-8"), "ISO-8859-1"));
response.addHeader("Content-Length", "" + file.length());
response.setContentType("application/octet-stream");
Clob syncContent = getDBData();
reader = syncContent.getCharacterStream();
char[] buffer = new char[1024];
int length = 0;
writerClient = new OutputStreamWriter(response.getOutputStream());
while ((length = reader.read(buffer)) != -1) {
System.out.println(buffer);
writerClient.write(buffer, 0, length);
}
writerClient.flush();
} catch (IOException ex) {
ex.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
try {
writerClient.close();
reader.close();
conn.close();
} catch (Exception ex) {
ex.printStackTrace();
}
}
return response;
}
// <a href="fileDownLoadServlet?filename=通讯录.xls">哈哈,测试文件下载</a>
}
分享到:
相关推荐
在IT行业中,数据同步是一个关键任务,特别是在大数据领域。`datasync`是一个工具或概念,用于确保多个系统间的数据一致性。在这个场景下,我们关注的是使用Python编程语言来实现数据同步。Python因其丰富的库和易读...
SQL Azure DataSync是一项强大的数据同步服务,它不仅简化了本地和云端数据库之间的数据同步流程,还为开发者提供了灵活的数据管理选项。无论是构建混合应用程序、实现数据的地理分布,还是提升用户体验,SQL Azure ...
本主题聚焦于“C#数据同步源代码”,这是一个关键的编程实践,涉及到如何在多个数据源之间保持数据的一致性和完整性。下面将详细讨论相关知识点。 1. **数据同步**:数据同步是确保在不同位置或系统之间数据一致性...
DataSync 一个基于Rocket MQ的不同数据库之间数据实时同步的平台 watcher为监视数据更新的windows service 配置文件: 1.\Config\producerconfig.json -- rocket mq的生产者配置,用来将从数据库查询出来的数据推送...
总的来说,TR Data Sync是一款实用的开源数据同步工具,适用于那些需要在不同设备间保持文件一致性的用户。通过了解和掌握如何有效利用这款工具,用户可以提升工作效率,确保数据的安全性和完整性。由于其开源本质,...
【JAVA 数据同步软件Sync源代码】是一个专为JAVA初学者设计的本地数据同步工具,它模仿了云盘同步的功能,但并不依赖网络环境,而是通过本地文件系统的操作实现数据的同步与备份。这个项目对于想要深入理解JAVA编程...
标题 "DataSync.rar" 暗示我们正在处理一个与数据同步相关的项目,可能是通过C#编程语言实现的。这个工具或程序允许用户在Access数据库和SQL Server数据库之间进行数据同步,解决了在不同数据库系统间交换数据的问题...
《基于Quartz.net和Topshelf的数据同步服务开发详解》 在IT行业中,数据同步服务扮演着至关重要的角色,它能够确保多系统间的数据一致性,提高工作效率,并为数据分析提供准确的基础。本文将深入探讨如何利用Quartz...
`aws-cdk.aws-datasync-1.124.0.tar.gz`是一个包含AWS CDK中`aws-datasync`组件的特定版本(1.124.0)的软件包,用于利用AWS DataSync服务进行数据迁移和同步。开发者可以使用这个库通过Python代码定义和管理Data...
例如,开发者可以使用它来创建一个DataSync任务,指定源和目标位置,设置传输选项,并在后续的代码中查询任务的状态,以了解数据同步的进度。 下面是一个简化的示例,展示了如何使用mypy-boto3-datasync创建Data...
`aws_cdk.aws_datasync`库则是CDK对AWS DataSync服务的抽象和接口,帮助开发者更方便地在不同的存储位置之间进行数据同步。AWS DataSync是一种完全托管的服务,它的主要功能是高效、可靠地迁移和同步数据,无论是...
《PyPI官网下载的mypy-boto3-datasync-1.12.3.0.tar.gz:Python库解析与应用》 ...通过理解并熟练运用这个库,开发者可以更轻松地实现跨平台的数据同步任务,从而在数据管理上实现更高的自动化和可靠性。
2. **管理数据同步**:启动、暂停、停止或删除DataSync任务,以适应业务需求的变化。 3. **监控和日志**:集成AWS CloudWatch,收集和分析DataSync的性能指标,以优化数据迁移过程。 4. **自动化流程**:结合AWS ...
云原生强调微服务、容器化、持续交付和声明式API等技术,`mypy-boto3-datasync`作为AWS生态的一部分,很好地适应了云原生的开发模式,使得开发者在处理云上数据同步任务时,能够更加灵活且高效。 至于“zookeeper”...
DataSync支持多种数据源,包括文件系统、网络附加存储(NAS)、数据库和对象存储,可以用于一次性迁移或持续的数据同步。 **aws_cdk.aws_datasync库功能** - **定义DataSync任务**:使用Python代码创建和配置Data...
《PyPI上的aws_cdk.aws_datasync-1.138.0-py3-none-any.whl:Python在AWS云数据同步中的应用》 在现代的云计算领域,Amazon Web Services (AWS) 提供了丰富的服务,帮助开发者构建、部署和管理应用程序。其中,AWS ...
标题中的"sync_data.zip_Oracle data sync_oracle"暗示了这是一个关于Oracle数据库数据同步的工具或脚本,可能是一个zip压缩文件,包含了用于同步Oracle数据库数据的程序或配置。这个工具可能具有自动化特性,能够...
DataSync是由Amazon Web Services(AWS)提供的一个云服务,它的主要功能是帮助用户在本地存储、AWS S3、EFS(Amazon Elastic File System)、FSx(Amazon File Storage Service)等不同存储系统间高效地迁移和同步...
在这个场景下,`aws-cdk.aws-datasync-1.99.0`是一个关键的Python库,它为AWS CDK(Cloud Development Kit)添加了对AWS DataSync服务的支持,极大地简化了数据迁移和同步的任务。 首先,让我们了解一下AWS CDK。...
"SyncData.rar" 文件集合显然关注于使用Visual C++实现数据同步的解决方案。Visual C++是一种强大的开发工具,广泛用于创建桌面应用程序,尤其适用于底层编程和系统级任务,如数据同步。 数据同步的基本目标是确保...