using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.IO;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using Common;
using Common.Assignment;
using Common.Attachment;
using Common.Log;
using Common.TBL;
using websiteCore.LINQ.ULT;
using websiteCore.LINQ.ATC;
using websiteCore.Common;
namespace WebPartLib._layouts.website_Resources.ExtPages
{
public partial class UploadService : System.Web.UI.Page
{
protected string strJson = "";
protected void Page_Load(object sender, EventArgs e)
{
string id = Request["Id"];
string action = Request["action"];
string knowledge_id = Request["lid"];
if (action != null)
{
if ("upload".Equals(action))
{
UploadAttachment(HttpContext.Current, knowledge_id);
//UoloadAttachment2(HttpContext.Current, knowledge_id);
}
else if ("DownLoad".Equals(action))
{
DownLoadAttachment(HttpContext.Current, id);
}
}
}
/// <summary>
/// 下载附件
/// </summary>
/// <param name="context"></param>
/// <param name="knowledge_id"></param>
private void DownLoadAttachment(HttpContext context, string attachmentId)
{
try
{
if (!string.IsNullOrEmpty(attachmentId))
{
using (var atcContext = ATCDBHelper.DataContext)
{
//CommonUtil.AddAppErrorLog("CHG000001136", "BPS", "BEGIN_DOWNLOAD" + attachmentId, null);
var obj = atcContext.Usp_ATC_DownLoadAttachmentContent(attachmentId).FirstOrDefault();
//CommonUtil.AddAppErrorLog("CHG000001136", "BPS", "END_DOWNLOAD", null);
string attachmentName = obj.AttachmentName;
byte[] data = obj.AttachmentContent.ToArray();
//获得文件后缀
int index = attachmentName.LastIndexOf(".");
string suffixal = attachmentName.Substring((index + 1), attachmentName.Length - (index + 1));
string contextType = "";
switch (suffixal)
{
case "xls":
case "xlsx":
contextType = "application/vnd.ms-excel";
break;
case "jpeg":
case "jpg":
case "jpe":
case "png":
case "tif":
case "tiff":
case "gif":
contextType = "image/jpeg";
break;
case "docx":
case "doc":
contextType = "application/msword";
break;
case "pdf":
contextType = "application/pdf";
break;
case "ppt":
contextType = "application/vnd.ms-powerpoint";
break;
case "js":
contextType = "application/x-javascript";
break;
case "zip":
contextType = "application/zip";
break;
default:
contextType = "application/octet-stream";
break;
}
context.Response.ContentType = contextType;
context.Response.Charset = "GB2312";
context.Response.ContentEncoding = System.Text.Encoding.UTF8;
//string srcName = System.Web.HttpUtility.UrlEncode(attachmentName);
//string tagName = System.Web.HttpUtility.UrlDecode(srcName, System.Text.Encoding.UTF8);
//System.Text.Encoding uft8 = System.Text.Encoding.UTF8;// GetEncoding(65001);
////System.Text.Encoding gb2312 = System.Text.Encoding.GetEncoding("GB2312");
//byte[] strTemp1 = System.Text.Encoding.Default.GetBytes(attachmentName); ;
//byte[] strTemp2 = System.Text.Encoding.Convert(System.Text.Encoding.Default, System.Text.Encoding.UTF8, strTemp1);
//string FileName = uft8.GetString(strTemp2);
//if (strTemp.Length > 150)
//{
//}
//System.Text.Encoding iso8859, gb2312;
//iso8859 = System.Text.Encoding.GetEncoding("ISO8859-1");
//gb2312 = System.Text.Encoding.UTF8;
//byte[] gb2;
//gb2 = gb2312.GetBytes(attachmentName);
//string iso = iso8859.GetString(gb2);
Response.AddHeader("Content-Disposition", "attachment;filename=" + Server.UrlEncode(attachmentName));
//Response.AddHeader("Content-Disposition", "attachment;filename=" + tagName);
Response.AddHeader("Content-Length", data.Length.ToString());
if (data.Length > 0)
{
Response.BinaryWrite(data);
}
context.ApplicationInstance.CompleteRequest();
}
}
}
catch(Exception err)
{
CommonUtil.AddAppErrorLog("CHG000001136", "BPS", "DOWNLOAD_ERROR" + err.Message, null);
Response.StatusCode = 500;
}
}
//上传附件控件2
private void UoloadAttachment2(HttpContext context, string knowledge_id)
{
JSONHelper jsonHelper = new JSONHelper();
string account = CommonMethods.IdentityName();
string strFileName = Path.GetFileName(context.Request.Files[0].FileName);
string strExtension = Path.GetExtension(context.Request.Files[0].FileName).ToLower();
string strFileNameNoExt = Path.GetFileNameWithoutExtension(context.Request.Files[0].FileName);
Stream stream = context.Request.Files[0].InputStream;
var fileLength = Math.Round((double)stream.Length / 1024, 2);
//文件过大禁止上传
if (fileLength > 10240)
{
jsonHelper.AddItem("status_error", "上传文件不能超过10M.");
jsonHelper.ItemOk();
}
else
{
//保存
string dirPath = Server.MapPath("~/website_Upload");
string tmp=DateTime.Now.ToString("yyyyMMdd");
string filetype=knowledge_id.Substring(0, 3);
dirPath += "\\" + filetype + "\\" + tmp.Substring(0, 4) + "\\" + tmp.Substring(4, 2);
string filePath = "website_Upload/" + filetype + "/" + tmp.Substring(0, 4) + "/" + tmp.Substring(4, 2);
if (!Directory.Exists(dirPath))
{
Directory.CreateDirectory(dirPath);
}
dirPath += "\\" + strFileName;
filePath += "/" + strFileName;
context.Request.Files[0].SaveAs(dirPath);
jsonHelper.AddItem("status_error", "OK");
jsonHelper.AddItem("url", filePath);
jsonHelper.AddItem("name", strFileName);
jsonHelper.AddItem("ext", strExtension);
jsonHelper.AddItem("filesize", fileLength.ToString());
jsonHelper.AddItem("uploader", CommonMethods.GetUserName(account));
jsonHelper.ItemOk();
}
strJson = jsonHelper.ToString();
}
/// <summary>
/// 上传附件控制
/// </summary>
/// <param name="context"></param>
/// <param name="knowledge_id"></param>
private void UploadAttachment(HttpContext context, string knowledge_id)
{
JSONHelper jsonHelper = new JSONHelper();
int attachmentType = 0;
int.TryParse(context.Request["attachmentType"], out attachmentType);
string account = CommonMethods.IdentityName();
string strFileName = Path.GetFileName(context.Request.Files[0].FileName);
string strExtension = Path.GetExtension(context.Request.Files[0].FileName).ToLower();
string strFileNameNoExt = Path.GetFileNameWithoutExtension(context.Request.Files[0].FileName);
Stream stream = context.Request.Files[0].InputStream;
var fileLength = Math.Round((double)stream.Length / 1024, 2);
//文件过大禁止上传
if (fileLength > 10240)
{
jsonHelper.AddItem("status_error", "上传文件不能超过10M.");
jsonHelper.ItemOk();
}
else
{
//int currentVer = 0;
////检查文件名是否已经存在,如果存在需要在后面加(1),(2)...
//using (var dataContext = ULTDBHelper.DataContext)
//{
// var obj = (from r in dataContext.Tbl_UltAttachment
// where r.AttachmentName.Trim().Equals(strFileName.Trim())
// orderby r.FileLastV descending
// select r.FileLastV).FirstOrDefault();
// //已经存在相同的文件名
// if (obj != null)
// {
// currentVer = obj.Value;
// //增加文件后缀数
// currentVer = currentVer + 1;
// strFileName = strFileNameNoExt + "(" + currentVer.ToString() + ")" + strExtension;
// }
//}
//存入MOSS数据库
//WssField[] fields = new WssField[] {
// new WssField { fieldName = AttachmentService.FORMID, fieldValue = knowledge_id},
// new WssField { fieldName = AttachmentService.NAME, fieldValue = strFileNameNoExt},//shortName},
// new WssField { fieldName = AttachmentService.SIZE, fieldValue = fileLength},
// new WssField { fieldName = AttachmentService.LABELID, fieldValue = "5"},
// new WssField { fieldName = AttachmentService.CREATOR, fieldValue = account},
// new WssField { fieldName = AttachmentService.CREATETIME, fieldValue = DateTime.Now},
// new WssField { fieldName = AttachmentService.FLAG, fieldValue = " "}
//};
/******************* modify by xml *********************
* 从2011.11.15号起附件存入SQLServer 2005,不存入MOSS中
*/
using (var ultContext = ULTDBHelper.DataContext)
{
try
{
byte[] data = new byte[stream.Length];
int length = data.Length;
stream.Read(data, 0, length);
stream.Close();
//存入website_database下的tbl_UltAttachment,获得附件编号attachmentId
string attachmentId = string.Empty;
ultContext.Usp_ULT_SaveAttachment(
knowledge_id,
attachmentType,
strFileName,
"SQLServer2005",
account,
(decimal)fileLength,
0,
0,
ref attachmentId);
//将内容存入website_attachment_database
using(var atcContext = ATCDBHelper.DataContext)
{
atcContext.Usp_ATC_UpdateAttachmentContent(attachmentId, data);
}
//Response.Write("{success: true}");
jsonHelper.AddItem("status_error", "OK");
jsonHelper.AddItem("Id", attachmentId);
jsonHelper.AddItem("fileId", "KBA" + attachmentId);
jsonHelper.AddItem("url", "_layouts/website_Resources/ExtPages/UploadService.aspx?action=DownLoad&id=");
jsonHelper.AddItem("name", strFileName);
jsonHelper.AddItem("uploader", CommonMethods.GetUserName(account));
jsonHelper.AddItem("filesize", fileLength.ToString());
jsonHelper.ItemOk();
}
catch
{
jsonHelper.AddItem("status_error", "OK");
jsonHelper.ItemOk();
}
}
//string linkName = string.Empty;
//string value = AttachmentService.Instance.UploadAttachment(stream, knowledge_id, strFileName, out linkName, fields);
////防止页面出现id冲突
//jsonHelper.AddItem("status_error", "OK");
//jsonHelper.AddItem("Id", value);
//jsonHelper.AddItem("fileId", "KBA" + value);
//jsonHelper.AddItem("url", linkName);
//jsonHelper.AddItem("name", strFileNameNoExt + strExtension);
//jsonHelper.AddItem("ext", strExtension);
//jsonHelper.AddItem("filesize", fileLength.ToString());
//jsonHelper.AddItem("uploader", CommonMethods.GetUserName(account));
//jsonHelper.AddItem("fileLastV", currentVer.ToString());
//jsonHelper.ItemOk();
}
strJson = jsonHelper.ToString();
}
}
}
posted on 2011-09-16 16:48
王豪 阅读(447)
评论(0) 编辑 收藏