设置Excel文档的ADRMS权限的工具类
2011-08-29 00:27
225 查看
设置Excel文档权限的工具类
引用Microsoft Office 12.0 Object Library
引用Microsoft Excel 12.0 Object Library
/// <summary>
/// 设置Excel文档权限的工具类
/// </summary>
public class RmsExcelHelper : IDisposable
{
/// <summary>
/// Excel应用程序对象
/// </summary>
private Microsoft.Office.Interop.Excel.ApplicationClass app;
/// <summary>
/// Excel文档路径
/// </summary>
private string filePath;
public string FilePath
{
get { return this.filePath; }
set { this.filePath = value; }
}
/// <summary>
/// 权限集合
/// </summary>
private List<RmsExcelPermission> rmsPerms = new List<RmsExcelPermission>();
public List<RmsExcelPermission> RmsPerms
{
get { return this.rmsPerms; }
}
/// <summary>
/// 空值
/// </summary>
private object MISSINGVALUE = System.Reflection.Missing.Value;
/// <summary>
/// 错误消息
/// </summary>
public string ErrMessage = string.Empty;
/// <summary>
/// 是否xlsx文档
/// </summary>
private bool is2007()
{
bool result = false;
result = System.IO.Path.GetExtension(this.filePath).ToLower() == "xlsx";
return result;
}
/// <summary>
/// Rms授权后的文件名
/// </summary>
private string GetRmsFileName()
{
string filename = string.Empty;
filename = System.IO.Path.Combine(System.IO.Path.GetDirectoryName(this.filePath), System.IO.Path.GetFileNameWithoutExtension(this.filePath) + "_RMS" + System.IO.Path.GetExtension(this.filePath));
return filename;
}
/// <summary>
/// 保存
/// </summary>
public bool Save()
{
//清除错误消息
this.ErrMessage = string.Empty;
bool result = false;
string filename_src = this.filePath;
string filename_dst = this.GetRmsFileName();
try
{
if (this.app == null)
{
this.app = new Microsoft.Office.Interop.Excel.ApplicationClass();
}
var doc = this.app.Workbooks.Open(filename_src, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);
try
{
doc.Activate();
doc.Permission.Enabled = true;
foreach (var permission in this.rmsPerms)
{
doc.Permission.Add(permission.UserId, permission.Perms, MISSINGVALUE);
}
doc.SaveAs(filename_dst, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
MISSINGVALUE, MISSINGVALUE, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,
MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);
result = true;
}
finally
{
doc.Close(MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);
}
}
catch (Exception ex)
{
this.ErrMessage = ex.Message;
}
return result;
}
/// <summary>
/// 退出Excel应用程序
/// </summary>
public void Dispose()
{
if (this.app != null)
{
this.app.Quit();
this.app = null;
}
}
}
public class RmsExcelPermission
{
public string UserId;
public Microsoft.Office.Core.MsoPermission Perms;
}
使用示例
using (RmsExcelHelper helper = new RmsExcelHelper())
{
helper.FilePath = filePath;
helper.RmsPerms.Add(new RmsExcelPermission() { UserId="Everyone", Perms= Microsoft.Office.Core.MsoPermission.msoPermissionRead });
if (helper.Save())
{
MessageBox.Show("ok");
}
else
{
MessageBox.Show(helper.ErrMessage);
}
}
引用Microsoft Office 12.0 Object Library
引用Microsoft Excel 12.0 Object Library
/// <summary>
/// 设置Excel文档权限的工具类
/// </summary>
public class RmsExcelHelper : IDisposable
{
/// <summary>
/// Excel应用程序对象
/// </summary>
private Microsoft.Office.Interop.Excel.ApplicationClass app;
/// <summary>
/// Excel文档路径
/// </summary>
private string filePath;
public string FilePath
{
get { return this.filePath; }
set { this.filePath = value; }
}
/// <summary>
/// 权限集合
/// </summary>
private List<RmsExcelPermission> rmsPerms = new List<RmsExcelPermission>();
public List<RmsExcelPermission> RmsPerms
{
get { return this.rmsPerms; }
}
/// <summary>
/// 空值
/// </summary>
private object MISSINGVALUE = System.Reflection.Missing.Value;
/// <summary>
/// 错误消息
/// </summary>
public string ErrMessage = string.Empty;
/// <summary>
/// 是否xlsx文档
/// </summary>
private bool is2007()
{
bool result = false;
result = System.IO.Path.GetExtension(this.filePath).ToLower() == "xlsx";
return result;
}
/// <summary>
/// Rms授权后的文件名
/// </summary>
private string GetRmsFileName()
{
string filename = string.Empty;
filename = System.IO.Path.Combine(System.IO.Path.GetDirectoryName(this.filePath), System.IO.Path.GetFileNameWithoutExtension(this.filePath) + "_RMS" + System.IO.Path.GetExtension(this.filePath));
return filename;
}
/// <summary>
/// 保存
/// </summary>
public bool Save()
{
//清除错误消息
this.ErrMessage = string.Empty;
bool result = false;
string filename_src = this.filePath;
string filename_dst = this.GetRmsFileName();
try
{
if (this.app == null)
{
this.app = new Microsoft.Office.Interop.Excel.ApplicationClass();
}
var doc = this.app.Workbooks.Open(filename_src, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);
try
{
doc.Activate();
doc.Permission.Enabled = true;
foreach (var permission in this.rmsPerms)
{
doc.Permission.Add(permission.UserId, permission.Perms, MISSINGVALUE);
}
doc.SaveAs(filename_dst, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE,
MISSINGVALUE, MISSINGVALUE, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,
MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);
result = true;
}
finally
{
doc.Close(MISSINGVALUE, MISSINGVALUE, MISSINGVALUE);
}
}
catch (Exception ex)
{
this.ErrMessage = ex.Message;
}
return result;
}
/// <summary>
/// 退出Excel应用程序
/// </summary>
public void Dispose()
{
if (this.app != null)
{
this.app.Quit();
this.app = null;
}
}
}
public class RmsExcelPermission
{
public string UserId;
public Microsoft.Office.Core.MsoPermission Perms;
}
使用示例
using (RmsExcelHelper helper = new RmsExcelHelper())
{
helper.FilePath = filePath;
helper.RmsPerms.Add(new RmsExcelPermission() { UserId="Everyone", Perms= Microsoft.Office.Core.MsoPermission.msoPermissionRead });
if (helper.Save())
{
MessageBox.Show("ok");
}
else
{
MessageBox.Show(helper.ErrMessage);
}
}
相关文章推荐
- 设置Word文档的ADRMS权限的工具类
- MFC创建新Excel文档并设置其中的格式和字体+底纹(OLE/COM)
- 给文档库设置项目级权限
- nginx设置目录文档访问权限
- js读取excel或者导出成excel时权限设置问题
- 如何在 Web 服务器文档根目录上设置只读文件权限 | Linux 中国
- C# 设置Excel打印选项及打印excel文档
- C# 设置Excel打印选项及打印excel文档
- Delphi7 导出Dbgrid数据到Excel 默认路径设置为我的文档
- MFC创建新Excel文档并设置其中的格式和字体
- Word2010怎么给文档设置权限用密码进行加密防止他人查看
- Java 实现Excel导入导出(包含一些简单样式设置)工具类
- EXCEL文档解析(xls,xlsx)工具类
- SharePoint 2013 共同编辑Office文档设置(work,excel,PPT等等)
- C# 对Excel文档打印时的页面设置
- 使用excel组件时的权限设置
- POI简易帮助文档系列--给Excel设置样式
- 支持将数据导出到Excel文档的时候设置单元格格式的.NET控件Spire.DataExport
- Decom中对Excel的访问权限的设置
- POI简易帮助文档系列--给Excel设置样式